mirror of
https://github.com/brl/mutter.git
synced 2024-11-22 16:10:41 -05:00
cullable: Use relative actor coordinates for culling
This ensures that nested cullables work fine.
This commit is contained in:
parent
0ccef81789
commit
1011331caf
@ -95,7 +95,9 @@ meta_actor_vertices_are_untransformed (ClutterVertex *verts,
|
|||||||
v3x != v1x || v3y != v2y)
|
v3x != v1x || v3y != v2y)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
if (x_origin)
|
||||||
*x_origin = x;
|
*x_origin = x;
|
||||||
|
if (y_origin)
|
||||||
*y_origin = y;
|
*y_origin = y;
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -71,7 +71,7 @@ meta_cullable_cull_out_children (MetaCullable *cullable,
|
|||||||
clutter_actor_iter_init (&iter, actor);
|
clutter_actor_iter_init (&iter, actor);
|
||||||
while (clutter_actor_iter_prev (&iter, &child))
|
while (clutter_actor_iter_prev (&iter, &child))
|
||||||
{
|
{
|
||||||
int x, y;
|
float x, y;
|
||||||
|
|
||||||
if (!CLUTTER_ACTOR_IS_VISIBLE (child))
|
if (!CLUTTER_ACTOR_IS_VISIBLE (child))
|
||||||
continue;
|
continue;
|
||||||
@ -98,9 +98,11 @@ meta_cullable_cull_out_children (MetaCullable *cullable,
|
|||||||
if (!META_IS_CULLABLE (child))
|
if (!META_IS_CULLABLE (child))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!meta_actor_is_untransformed (child, &x, &y))
|
if (!meta_actor_is_untransformed (child, NULL, NULL))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
clutter_actor_get_position (child, &x, &y);
|
||||||
|
|
||||||
/* Temporarily move to the coordinate system of the actor */
|
/* Temporarily move to the coordinate system of the actor */
|
||||||
cairo_region_translate (unobscured_region, - x, - y);
|
cairo_region_translate (unobscured_region, - x, - y);
|
||||||
cairo_region_translate (clip_region, - x, - y);
|
cairo_region_translate (clip_region, - x, - y);
|
||||||
|
@ -301,15 +301,8 @@ meta_shaped_texture_paint (ClutterActor *actor)
|
|||||||
|
|
||||||
filter = COGL_PIPELINE_FILTER_LINEAR;
|
filter = COGL_PIPELINE_FILTER_LINEAR;
|
||||||
|
|
||||||
if (!clutter_actor_is_in_clone_paint (actor))
|
if (!clutter_actor_is_in_clone_paint (actor) && meta_actor_is_untransformed (actor, NULL, NULL))
|
||||||
{
|
|
||||||
int x_origin, y_origin;
|
|
||||||
|
|
||||||
if (meta_actor_is_untransformed (actor,
|
|
||||||
&x_origin,
|
|
||||||
&y_origin))
|
|
||||||
filter = COGL_PIPELINE_FILTER_NEAREST;
|
filter = COGL_PIPELINE_FILTER_NEAREST;
|
||||||
}
|
|
||||||
|
|
||||||
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
||||||
fb = cogl_get_draw_framebuffer ();
|
fb = cogl_get_draw_framebuffer ();
|
||||||
|
Loading…
Reference in New Issue
Block a user