mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
c/main: Follow OpenXR spec with blackground colour, tweek no layer colour.
Make background colour completely black if there are layers to display, to follow OpenXR spec. Make the default background colour darker.
This commit is contained in:
parent
2b962a5bfb
commit
b62b6eaef7
|
@ -22,10 +22,16 @@ struct comp_layer_vertex
|
||||||
float uv[2];
|
float uv[2];
|
||||||
};
|
};
|
||||||
|
|
||||||
static const VkClearColorValue background_color = {
|
static const VkClearColorValue background_color_idle = {
|
||||||
.float32 = {0.3f, 0.3f, 0.3f, 1.0f},
|
.float32 = {0.1f, 0.1f, 0.1f, 1.0f},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const VkClearColorValue background_color_active = {
|
||||||
|
.float32 = {0.0f, 0.0f, 0.0f, 1.0f},
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
_init_render_pass(struct vk_bundle *vk,
|
_init_render_pass(struct vk_bundle *vk,
|
||||||
VkFormat format,
|
VkFormat format,
|
||||||
|
@ -571,7 +577,10 @@ _render_pass_begin(struct vk_bundle *vk,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_render_stereo(struct comp_layer_renderer *self, struct vk_bundle *vk, VkCommandBuffer cmd_buffer)
|
_render_stereo(struct comp_layer_renderer *self,
|
||||||
|
struct vk_bundle *vk,
|
||||||
|
VkCommandBuffer cmd_buffer,
|
||||||
|
const VkClearColorValue *color)
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
|
@ -586,8 +595,8 @@ _render_stereo(struct comp_layer_renderer *self, struct vk_bundle *vk, VkCommand
|
||||||
vk->vkCmdSetScissor(cmd_buffer, 0, 1, &scissor);
|
vk->vkCmdSetScissor(cmd_buffer, 0, 1, &scissor);
|
||||||
|
|
||||||
for (uint32_t eye = 0; eye < 2; eye++) {
|
for (uint32_t eye = 0; eye < 2; eye++) {
|
||||||
_render_pass_begin(vk, self->render_pass, self->extent, background_color,
|
_render_pass_begin(vk, self->render_pass, self->extent, *color, self->framebuffers[eye].handle,
|
||||||
self->framebuffers[eye].handle, cmd_buffer);
|
cmd_buffer);
|
||||||
|
|
||||||
_render_eye(self, eye, cmd_buffer, self->pipeline_layout);
|
_render_eye(self, eye, cmd_buffer, self->pipeline_layout);
|
||||||
|
|
||||||
|
@ -605,9 +614,12 @@ comp_layer_renderer_draw(struct comp_layer_renderer *self)
|
||||||
VkCommandBuffer cmd_buffer;
|
VkCommandBuffer cmd_buffer;
|
||||||
if (vk_init_cmd_buffer(vk, &cmd_buffer) != VK_SUCCESS)
|
if (vk_init_cmd_buffer(vk, &cmd_buffer) != VK_SUCCESS)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
os_mutex_lock(&vk->cmd_pool_mutex);
|
os_mutex_lock(&vk->cmd_pool_mutex);
|
||||||
_render_stereo(self, vk, cmd_buffer);
|
if (self->num_layers == 0) {
|
||||||
|
_render_stereo(self, vk, cmd_buffer, &background_color_idle);
|
||||||
|
} else {
|
||||||
|
_render_stereo(self, vk, cmd_buffer, &background_color_active);
|
||||||
|
}
|
||||||
os_mutex_unlock(&vk->cmd_pool_mutex);
|
os_mutex_unlock(&vk->cmd_pool_mutex);
|
||||||
|
|
||||||
VkResult res = vk_submit_cmd_buffer(vk, cmd_buffer);
|
VkResult res = vk_submit_cmd_buffer(vk, cmd_buffer);
|
||||||
|
|
Loading…
Reference in a new issue