gdk: Implement end_implicit_paint() with Cairo

This commit is contained in:
Benjamin Otte 2010-07-19 13:29:47 +02:00
parent 600fbd3e74
commit 46206f8bb8

View File

@ -2839,7 +2839,6 @@ gdk_window_end_implicit_paint (GdkWindow *window)
{ {
GdkWindowObject *private = (GdkWindowObject *)window; GdkWindowObject *private = (GdkWindowObject *)window;
GdkWindowPaint *paint; GdkWindowPaint *paint;
GdkGC *tmp_gc;
g_assert (gdk_window_has_impl (private)); g_assert (gdk_window_has_impl (private));
@ -2851,16 +2850,18 @@ gdk_window_end_implicit_paint (GdkWindow *window)
if (!GDK_WINDOW_DESTROYED (window) && !cairo_region_is_empty (paint->region)) if (!GDK_WINDOW_DESTROYED (window) && !cairo_region_is_empty (paint->region))
{ {
cairo_t *cr;
/* Some regions are valid, push these to window now */ /* Some regions are valid, push these to window now */
tmp_gc = _gdk_drawable_get_scratch_gc ((GdkDrawable *)window, FALSE); cr = gdk_cairo_create (private->impl);
_gdk_gc_set_clip_region_internal (tmp_gc, paint->region, TRUE); gdk_cairo_set_source_pixmap (cr, paint->pixmap,
gdk_draw_drawable (private->impl, tmp_gc, paint->pixmap, paint->x_offset, paint->y_offset);
0, 0, paint->x_offset, paint->y_offset, -1, -1); gdk_cairo_region (cr, paint->region);
/* Reset clip region of the cached GdkGC */ cairo_fill (cr);
gdk_gc_set_clip_region (tmp_gc, NULL); cairo_destroy (cr);
} }
else
cairo_region_destroy (paint->region); cairo_region_destroy (paint->region);
g_object_unref (paint->pixmap); g_object_unref (paint->pixmap);
g_free (paint); g_free (paint);