drawingarea: don't call gtk_style_context_set_background()
authorCosimo Cecchi <cosimoc@gnome.org>
Thu, 4 Jun 2015 00:59:45 +0000 (17:59 -0700)
committerCosimo Cecchi <cosimoc@gnome.org>
Wed, 1 Jul 2015 23:09:22 +0000 (16:09 -0700)
gtk/gtkdrawingarea.c

index a9b659ee1c28b775ab5695bc9872f19ac962159f..94034059e10544a0d5259f7a993cc849df1d61cb 100644 (file)
@@ -25,9 +25,9 @@
 #include "config.h"
 #include "gtkdrawingarea.h"
 #include "gtkintl.h"
+#include "gtkrender.h"
 #include "gtkstylecontext.h"
 
-
 /**
  * SECTION:gtkdrawingarea
  * @Short_description: A widget for custom user interface elements
  * gtk_render_focus() for one way to draw focus.
  */
 
+static gboolean gtk_drawing_area_draw      (GtkWidget           *widget,
+                                            cairo_t             *cr);
 static void gtk_drawing_area_realize       (GtkWidget           *widget);
 static void gtk_drawing_area_size_allocate (GtkWidget           *widget,
                                             GtkAllocation       *allocation);
@@ -126,6 +128,7 @@ gtk_drawing_area_class_init (GtkDrawingAreaClass *class)
 
   widget_class->realize = gtk_drawing_area_realize;
   widget_class->size_allocate = gtk_drawing_area_size_allocate;
+  widget_class->draw = gtk_drawing_area_draw;
 
   gtk_widget_class_set_accessible_role (widget_class, ATK_ROLE_DRAWING_AREA);
 }
@@ -181,9 +184,6 @@ gtk_drawing_area_realize (GtkWidget *widget)
                                &attributes, attributes_mask);
       gtk_widget_register_window (widget, window);
       gtk_widget_set_window (widget, window);
-
-      gtk_style_context_set_background (gtk_widget_get_style_context (widget),
-                                        window);
     }
 
   gtk_drawing_area_send_configure (GTK_DRAWING_AREA (widget));
@@ -209,6 +209,19 @@ gtk_drawing_area_size_allocate (GtkWidget     *widget,
     }
 }
 
+static gboolean
+gtk_drawing_area_draw (GtkWidget *widget,
+                      cairo_t   *cr)
+{
+  if (gtk_widget_get_has_window (widget))
+    gtk_render_background (gtk_widget_get_style_context (widget), cr,
+                           0, 0,
+                           gtk_widget_get_allocated_width (widget),
+                           gtk_widget_get_allocated_height (widget));
+
+  return GTK_WIDGET_CLASS (gtk_drawing_area_parent_class)->draw (widget, cr);
+}
+
 static void
 gtk_drawing_area_send_configure (GtkDrawingArea *darea)
 {