mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-21 06:01:43 +00:00
c/main: Refactor vertex rot getting in renderer
This commit is contained in:
parent
c81356e0c8
commit
b7dbdae304
|
@ -215,6 +215,40 @@ calc_viewport_data(struct comp_renderer *r,
|
||||||
*out_r_viewport_data = r_viewport_data;
|
*out_r_viewport_data = r_viewport_data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
calc_vertex_rot_data(struct comp_renderer *r, struct xrt_matrix_2x2 out_vertex_rots[2])
|
||||||
|
{
|
||||||
|
bool pre_rotate = false;
|
||||||
|
if (r->c->target->surface_transform & VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR ||
|
||||||
|
r->c->target->surface_transform & VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR) {
|
||||||
|
COMP_SPEW(r->c, "Swapping width and height, since we are pre rotating");
|
||||||
|
pre_rotate = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
const struct xrt_matrix_2x2 rotation_90_cw = {{
|
||||||
|
.vecs =
|
||||||
|
{
|
||||||
|
{0, 1},
|
||||||
|
{-1, 0},
|
||||||
|
},
|
||||||
|
}};
|
||||||
|
|
||||||
|
for (uint32_t i = 0; i < 2; i++) {
|
||||||
|
// Get the view.
|
||||||
|
struct xrt_view *v = &r->c->xdev->hmd->views[i];
|
||||||
|
|
||||||
|
// Copy data.
|
||||||
|
struct xrt_matrix_2x2 rot = v->rot;
|
||||||
|
|
||||||
|
// Should we rotate.
|
||||||
|
if (pre_rotate) {
|
||||||
|
m_mat2x2_multiply(&rot, &rotation_90_cw, &rot);
|
||||||
|
}
|
||||||
|
|
||||||
|
out_vertex_rots[i] = rot;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
calc_pose_data(struct comp_renderer *r,
|
calc_pose_data(struct comp_renderer *r,
|
||||||
struct xrt_fov out_fovs[2],
|
struct xrt_fov out_fovs[2],
|
||||||
|
@ -298,28 +332,18 @@ renderer_build_rendering(struct comp_renderer *r,
|
||||||
{
|
{
|
||||||
COMP_TRACE_MARKER();
|
COMP_TRACE_MARKER();
|
||||||
|
|
||||||
struct comp_compositor *c = r->c;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Rendering
|
* Rendering
|
||||||
*/
|
*/
|
||||||
|
|
||||||
bool pre_rotate = false;
|
|
||||||
if (r->c->target->surface_transform & VK_SURFACE_TRANSFORM_ROTATE_90_BIT_KHR ||
|
|
||||||
r->c->target->surface_transform & VK_SURFACE_TRANSFORM_ROTATE_270_BIT_KHR) {
|
|
||||||
COMP_SPEW(c, "Swapping width and height, since we are pre rotating");
|
|
||||||
pre_rotate = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct render_viewport_data l_viewport_data;
|
struct render_viewport_data l_viewport_data;
|
||||||
struct render_viewport_data r_viewport_data;
|
struct render_viewport_data r_viewport_data;
|
||||||
|
|
||||||
calc_viewport_data(r, &l_viewport_data, &r_viewport_data);
|
calc_viewport_data(r, &l_viewport_data, &r_viewport_data);
|
||||||
|
|
||||||
struct xrt_view *l_v = &r->c->xdev->hmd->views[0];
|
struct xrt_matrix_2x2 vertex_rots[2];
|
||||||
struct xrt_view *r_v = &r->c->xdev->hmd->views[1];
|
calc_vertex_rot_data(r, vertex_rots);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -328,32 +352,15 @@ renderer_build_rendering(struct comp_renderer *r,
|
||||||
|
|
||||||
struct render_gfx_mesh_ubo_data distortion_data[2] = {
|
struct render_gfx_mesh_ubo_data distortion_data[2] = {
|
||||||
{
|
{
|
||||||
.vertex_rot = l_v->rot,
|
.vertex_rot = vertex_rots[0],
|
||||||
.post_transform = src_norm_rects[0],
|
.post_transform = src_norm_rects[0],
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.vertex_rot = r_v->rot,
|
.vertex_rot = vertex_rots[1],
|
||||||
.post_transform = src_norm_rects[1],
|
.post_transform = src_norm_rects[1],
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct xrt_matrix_2x2 rotation_90_cw = {{
|
|
||||||
.vecs =
|
|
||||||
{
|
|
||||||
{0, 1},
|
|
||||||
{-1, 0},
|
|
||||||
},
|
|
||||||
}};
|
|
||||||
|
|
||||||
if (pre_rotate) {
|
|
||||||
m_mat2x2_multiply(&distortion_data[0].vertex_rot, //
|
|
||||||
&rotation_90_cw, //
|
|
||||||
&distortion_data[0].vertex_rot); //
|
|
||||||
m_mat2x2_multiply(&distortion_data[1].vertex_rot, //
|
|
||||||
&rotation_90_cw, //
|
|
||||||
&distortion_data[1].vertex_rot); //
|
|
||||||
}
|
|
||||||
|
|
||||||
render_gfx_update_distortion(rr, //
|
render_gfx_update_distortion(rr, //
|
||||||
0, // view_index
|
0, // view_index
|
||||||
src_samplers[0], //
|
src_samplers[0], //
|
||||||
|
|
Loading…
Reference in a new issue