[clip-stack] tidy up transform_point() code
I was originally expecting the code not to handle offset viewports or viewports with a different size to the framebuffer, but it turns out the code worked fine. In the process though I think I made the code slightly more readable.
This commit is contained in:
parent
78ee3f71b2
commit
0f86470eef
@ -155,13 +155,18 @@ cogl_clip_push_window_rect (float x_offset,
|
|||||||
clip_state->stack_dirty = TRUE;
|
clip_state->stack_dirty = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Scale from OpenGL <-1,1> coordinates system to window coordinates
|
/* Scale from OpenGL normalized device coordinates (ranging from -1 to 1)
|
||||||
* <0,window-size> with (0,0) being top left. */
|
* to Cogl window/draw-buffer coordinates (ranging from 0 to buffer-size) with
|
||||||
#define VIEWPORT_SCALE_X(x, w, width, origin) \
|
* (0,0) being top left. */
|
||||||
((((((x) / (w)) + 1.0) / 2) * (width)) + (origin))
|
#define VIEWPORT_TRANSFORM_X(x, vp_origin_x, vp_width) \
|
||||||
#define VIEWPORT_SCALE_Y(y, w, height, origin) \
|
( ( ((x) + 1.0) * ((vp_width) / 2.0) ) + (vp_origin_x) )
|
||||||
((height) - (((((y) / (w)) + 1.0) / 2) * (height)) + (origin))
|
/* Note: for Y we first flip all coordinates around the X axis while in
|
||||||
|
* normalized device coodinates */
|
||||||
|
#define VIEWPORT_TRANSFORM_Y(y, vp_origin_y, vp_height) \
|
||||||
|
( ( ((-(y)) + 1.0) * ((vp_height) / 2.0) ) + (vp_origin_y) )
|
||||||
|
|
||||||
|
/* Transform a homogeneous vertex position from model space to Cogl
|
||||||
|
* window coordinates (with 0,0 being top left) */
|
||||||
static void
|
static void
|
||||||
transform_point (CoglMatrix *matrix_mv,
|
transform_point (CoglMatrix *matrix_mv,
|
||||||
CoglMatrix *matrix_p,
|
CoglMatrix *matrix_p,
|
||||||
@ -172,14 +177,19 @@ transform_point (CoglMatrix *matrix_mv,
|
|||||||
float z = 0;
|
float z = 0;
|
||||||
float w = 1;
|
float w = 1;
|
||||||
|
|
||||||
/* Apply the model view matrix */
|
/* Apply the modelview matrix transform */
|
||||||
cogl_matrix_transform_point (matrix_mv, x, y, &z, &w);
|
cogl_matrix_transform_point (matrix_mv, x, y, &z, &w);
|
||||||
|
|
||||||
/* Apply the projection matrix */
|
/* Apply the projection matrix transform */
|
||||||
cogl_matrix_transform_point (matrix_p, x, y, &z, &w);
|
cogl_matrix_transform_point (matrix_p, x, y, &z, &w);
|
||||||
|
|
||||||
|
/* Perform perspective division */
|
||||||
|
*x /= w;
|
||||||
|
*y /= w;
|
||||||
|
|
||||||
/* Apply viewport transform */
|
/* Apply viewport transform */
|
||||||
*x = VIEWPORT_SCALE_X (*x, w, viewport[2], viewport[0]);
|
*x = VIEWPORT_TRANSFORM_X (*x, viewport[0], viewport[2]);
|
||||||
*y = VIEWPORT_SCALE_Y (*y, w, viewport[3], viewport[1]);
|
*y = VIEWPORT_TRANSFORM_Y (*y, viewport[1], viewport[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
#undef VIEWPORT_SCALE_X
|
#undef VIEWPORT_SCALE_X
|
||||||
|
Loading…
Reference in New Issue
Block a user