[gtk+/win32-theme2: 9/18] win32-theme: Support multiple parts being combined



commit fdbf029df3e5c8e631784a1289af5c138361c805
Author: Alexander Larsson <alexl redhat com>
Date:   Thu Nov 17 14:34:39 2011 +0100

    win32-theme: Support multiple parts being combined
    
    This is needed for e.g. scrollbar sliders

 gtk/gtkwin32theme.c        |   94 ++++++++++++++++++++++++++++++++++---------
 gtk/gtkwin32themeprivate.h |    2 -
 2 files changed, 74 insertions(+), 22 deletions(-)
---
diff --git a/gtk/gtkwin32theme.c b/gtk/gtkwin32theme.c
index 78ac8963..5c4720d 100644
--- a/gtk/gtkwin32theme.c
+++ b/gtk/gtkwin32theme.c
@@ -196,13 +196,16 @@ struct _GtkWin32ThemePart {
   HTHEME theme;
   int part;
   int state;
+  int part2;
+  int state2;
 
   gint ref_count;
 };
 
 GtkWin32ThemePart *
 _gtk_win32_theme_part_new (const char *class, 
-			   int xp_part, int state)
+			   int xp_part, int state, 
+			   int xp_part2, int state2)
 {
   GtkWin32ThemePart *part;
 
@@ -212,6 +215,8 @@ _gtk_win32_theme_part_new (const char *class,
   part->theme = lookup_htheme_by_classname (class);
   part->part = xp_part;
   part->state = state;
+  part->part2 = xp_part2;
+  part->state2 = state2;
 
   return part;
 }
@@ -245,7 +250,7 @@ _gtk_win32_theme_part_parse (GtkCssParser *parser,
 			     GValue *value)
 {
   char *class;
-  int xp_part, state;
+  int xp_part, state, xp_part2, state2;
   GtkWin32ThemePart *theme_part;
 
   if (!_gtk_css_parser_try (parser, "-gtk-win32-theme-part", TRUE))
@@ -286,21 +291,33 @@ _gtk_win32_theme_part_parse (GtkCssParser *parser,
       return 0;
     }
 
-  if (! _gtk_css_parser_try (parser, ",", TRUE))
+  if (!_gtk_css_parser_try_int (parser, &state))
     {
       g_free (class);
-      _gtk_css_parser_error (parser,
-			     "Expected ','");
+      _gtk_css_parser_error (parser, "Expected a valid integer value");
       return 0;
     }
 
-  if (!_gtk_css_parser_try_int (parser, &state))
+  xp_part2 = -1;
+  state2 = -1;
+  if ( _gtk_css_parser_try (parser, ",", TRUE))
     {
-      g_free (class);
-      _gtk_css_parser_error (parser, "Expected a valid integer value");
-      return 0;
+      if (!_gtk_css_parser_try_int (parser, &xp_part2))
+	{
+	  g_free (class);
+	  _gtk_css_parser_error (parser, "Expected a valid integer value");
+	  return 0;
+	}
+
+      if (!_gtk_css_parser_try_int (parser, &state2))
+	{
+	  g_free (class);
+	  _gtk_css_parser_error (parser, "Expected a valid integer value");
+	  return 0;
+	}
     }
 
+
   if (!_gtk_css_parser_try (parser, ")", TRUE))
     {
       g_free (class);
@@ -309,26 +326,27 @@ _gtk_win32_theme_part_parse (GtkCssParser *parser,
       return 0;
     }
   
-  theme_part = _gtk_win32_theme_part_new (class, xp_part, state);
+  theme_part = _gtk_win32_theme_part_new (class, 
+					  xp_part, state, 
+					  xp_part2, state2);
   g_free (class);
   
   g_value_take_boxed (value, theme_part);
   return 1;
 }
 
-cairo_pattern_t *
-_gtk_win32_theme_part_render  (GtkWin32ThemePart  *part,
-			       int                 width,
-			       int                 height)
-{
 #ifdef G_OS_WIN32
-  cairo_surface_t *surface, *image;
-  cairo_pattern_t *pattern;
-  cairo_matrix_t matrix;
+cairo_surface_t *
+_gtk_win32_theme_part_create_surface  (GtkWin32ThemePart  *part,
+				       int                 xp_part,
+				       int                 state,
+				       int                 width,
+				       int                 height)
+{
+  cairo_surface_t *surface;
   HDC hdc;
   RECT rect;
   HRESULT res;
-  cairo_user_data_key_t key;
 
   surface = cairo_win32_surface_create_with_dib (CAIRO_FORMAT_ARGB32, width, height);
   hdc = cairo_win32_surface_get_dc (surface);
@@ -338,7 +356,43 @@ _gtk_win32_theme_part_render  (GtkWin32ThemePart  *part,
   rect.right = width;
   rect.bottom = height;
 
-  res = draw_theme_background (part->theme, hdc, part->part, part->state, &rect, &rect);
+  res = draw_theme_background (part->theme, hdc, xp_part, state, &rect, &rect);
+  return surface;
+}
+#endif
+
+
+cairo_pattern_t *
+_gtk_win32_theme_part_render  (GtkWin32ThemePart  *part,
+			       int                 width,
+			       int                 height)
+{
+#ifdef G_OS_WIN32
+  cairo_surface_t *surface, *surface2, *image;
+  cairo_pattern_t *pattern;
+  cairo_t *cr;
+  cairo_matrix_t matrix;
+  cairo_user_data_key_t key;
+
+  surface = _gtk_win32_theme_part_create_surface  (part, part->part, part->state, 
+						   width, height);
+  
+  if (part->state2 >= 0)
+    {
+      surface2 = _gtk_win32_theme_part_create_surface  (part, part->part2, part->state2, 
+							width, height);
+
+      cr = cairo_create (surface);
+
+      pattern = cairo_pattern_create_for_surface (surface2);
+      cairo_set_source (cr, pattern);
+      cairo_set_operator (cr, CAIRO_OPERATOR_OVER);
+      cairo_paint (cr);
+      
+      cairo_destroy (cr);
+      cairo_pattern_destroy (pattern);
+      cairo_surface_destroy (surface2);
+    }
 
   /* We need to return an image surface, as that is what the code expects in order
      to get the size */
diff --git a/gtk/gtkwin32themeprivate.h b/gtk/gtkwin32themeprivate.h
index b066d9a..166c670 100644
--- a/gtk/gtkwin32themeprivate.h
+++ b/gtk/gtkwin32themeprivate.h
@@ -32,8 +32,6 @@ typedef struct _GtkWin32ThemePart GtkWin32ThemePart;
 
 GType              _gtk_win32_theme_part_get_type  (void) G_GNUC_CONST;
 
-GtkWin32ThemePart *_gtk_win32_theme_part_new       (const char *class, 
-						    int xp_part, int state);
 GtkWin32ThemePart *_gtk_win32_theme_part_ref       (GtkWin32ThemePart *part);
 void               _gtk_win32_theme_part_unref     (GtkWin32ThemePart *part);
 int                _gtk_win32_theme_part_parse     (GtkCssParser      *parser, 



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