compositor: Implement damage_below by using the new compositor->damage

We can now clip the surface bounding box against the previous frame
opaque clip, and then just union the result (visible damage) into
compositor->damage immediately.
dev
Kristian Høgsberg 13 years ago
parent 6ddcdaeb98
commit 1e8321213d
  1. 34
      src/compositor.c

@ -282,17 +282,15 @@ surface_to_global_float(struct weston_surface *surface,
WL_EXPORT void WL_EXPORT void
weston_surface_damage_below(struct weston_surface *surface) weston_surface_damage_below(struct weston_surface *surface)
{ {
struct weston_surface *below; struct weston_compositor *compositor = surface->compositor;
pixman_region32_t damage;
if (surface->output == NULL)
return;
if (surface->link.next == &surface->compositor->surface_list)
return;
below = container_of(surface->link.next, struct weston_surface, link); pixman_region32_init(&damage);
pixman_region32_union(&below->damage, &below->damage, pixman_region32_subtract(&damage, &surface->transform.boundingbox,
&surface->transform.boundingbox); &surface->clip);
pixman_region32_union(&compositor->damage,
&compositor->damage, &damage);
pixman_region32_fini(&damage);
} }
static void static void
@ -511,21 +509,6 @@ weston_surface_damage(struct weston_surface *surface)
weston_compositor_schedule_repaint(surface->compositor); weston_compositor_schedule_repaint(surface->compositor);
} }
static void
weston_surface_flush_damage(struct weston_surface *surface)
{
struct weston_surface *below;
if (surface->output &&
surface->link.next != &surface->compositor->surface_list) {
below = container_of(surface->link.next,
struct weston_surface, link);
pixman_region32_union(&below->damage,
&below->damage, &surface->damage);
}
}
WL_EXPORT void WL_EXPORT void
weston_surface_configure(struct weston_surface *surface, weston_surface_configure(struct weston_surface *surface,
GLfloat x, GLfloat y, int width, int height) GLfloat x, GLfloat y, int width, int height)
@ -615,7 +598,6 @@ static void
weston_surface_unmap(struct weston_surface *surface) weston_surface_unmap(struct weston_surface *surface)
{ {
weston_surface_damage_below(surface); weston_surface_damage_below(surface);
weston_surface_flush_damage(surface);
surface->output = NULL; surface->output = NULL;
wl_list_remove(&surface->link); wl_list_remove(&surface->link);
weston_compositor_repick(surface->compositor); weston_compositor_repick(surface->compositor);

Loading…
Cancel
Save