[gimp/gtk3-port: 90/251] app: fix canvas double buffering using cairo_push, pop_group()



commit 4c9baeb1b4587e5266475065e8ddfa89bdf8a2ec
Author: Michael Natterer <mitch gimp org>
Date:   Wed Oct 20 14:06:30 2010 +0200

    app: fix canvas double buffering using cairo_push,pop_group()

 app/display/gimpdisplayshell-callbacks.c |   19 +++++++++----------
 1 files changed, 9 insertions(+), 10 deletions(-)
---
diff --git a/app/display/gimpdisplayshell-callbacks.c b/app/display/gimpdisplayshell-callbacks.c
index b802ecd..a002dcb 100644
--- a/app/display/gimpdisplayshell-callbacks.c
+++ b/app/display/gimpdisplayshell-callbacks.c
@@ -239,15 +239,18 @@ gimp_display_shell_canvas_draw (GtkWidget        *widget,
     {
       if (gimp_display_get_image (shell->display))
         {
-#if 0
           if (gimp_display_shell_is_double_buffered (shell))
-            gdk_window_begin_paint_region (eevent->window, eevent->region);
-#endif
-        }
+            {
+              cairo_push_group (cr);
+            }
 
-      if (gimp_display_get_image (shell->display))
-        {
           gimp_display_shell_canvas_draw_image (shell, cr);
+
+          if (gimp_display_shell_is_double_buffered (shell))
+            {
+              cairo_pop_group_to_source (cr);
+              cairo_paint (cr);
+            }
         }
       else
         {
@@ -272,10 +275,6 @@ gimp_display_shell_canvas_draw_after (GtkWidget        *widget,
     {
       if (gimp_display_get_image (shell->display))
         {
-#if 0
-          if (gimp_display_shell_is_double_buffered (shell))
-            gdk_window_end_paint (eevent->window);
-#endif
         }
     }
 



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]