[gtk+] Gtk9Slice: Fix stretch case.



commit 2e8b1cd358207442ea8bf914d9be12ead9510f65
Author: Carlos Garnacho <carlosg gnome org>
Date:   Tue Oct 12 03:46:40 2010 +0200

    Gtk9Slice: Fix stretch case.

 gtk/gtk9slice.c |   61 ++++++++++++++++++++++++++++++++++++-------------------
 gtk/gtk9slice.h |    4 +-
 2 files changed, 42 insertions(+), 23 deletions(-)
---
diff --git a/gtk/gtk9slice.c b/gtk/gtk9slice.c
index 7cd6ad4..4b5a018 100644
--- a/gtk/gtk9slice.c
+++ b/gtk/gtk9slice.c
@@ -54,8 +54,8 @@ gtk_9slice_new (GdkPixbuf            *pixbuf,
                 gdouble               distance_bottom,
                 gdouble               distance_left,
                 gdouble               distance_right,
-                GtkSliceSideModifier  vertical_modifier,
-                GtkSliceSideModifier  horizontal_modifier)
+                GtkSliceSideModifier  horizontal_modifier,
+                GtkSliceSideModifier  vertical_modifier)
 {
   Gtk9Slice *slice;
   cairo_surface_t *surface;
@@ -185,13 +185,13 @@ gtk_9slice_new (GdkPixbuf            *pixbuf,
 static void
 render_border (cairo_t              *cr,
                cairo_surface_t      *surface,
+               guint                 side,
                gdouble               x,
                gdouble               y,
                gdouble               width,
                gdouble               height,
                GtkSliceSideModifier  modifier)
 {
-  cairo_pattern_t *pattern;
   cairo_matrix_t matrix;
 
   cairo_save (cr);
@@ -199,28 +199,47 @@ render_border (cairo_t              *cr,
   cairo_rectangle (cr, x, y, width, height);
   cairo_clip (cr);
 
-  pattern = cairo_pattern_create_for_surface (surface);
+  if (modifier == GTK_SLICE_REPEAT)
+    {
+      cairo_pattern_t *pattern;
 
-  cairo_matrix_init_translate (&matrix, - x, - y);
+      pattern = cairo_pattern_create_for_surface (surface);
 
-  if (modifier == GTK_SLICE_REPEAT)
-    cairo_pattern_set_extend (pattern, CAIRO_EXTEND_REPEAT);
+      cairo_matrix_init_translate (&matrix, - x, - y);
+      cairo_pattern_set_extend (pattern, CAIRO_EXTEND_REPEAT);
+
+      cairo_pattern_set_matrix (pattern, &matrix);
+      cairo_set_source (cr, pattern);
+      cairo_pattern_destroy (pattern);
+
+      cairo_rectangle (cr, x, y, width, height);
+    }
   else
     {
-      gint w;
-
-      w = cairo_image_surface_get_width (surface);
-      cairo_matrix_scale (&matrix, width / w, 0);
+      gint d;
+
+      if (side == SIDE_TOP || side == SIDE_BOTTOM)
+        {
+          d = cairo_image_surface_get_width (surface);
+
+          cairo_translate (cr, x + (width / 2), y);
+          cairo_scale (cr, width / d, 1);
+          cairo_set_source_surface (cr, surface, - d / 2, 0);
+          cairo_rectangle (cr, - width / 2, 0, width, height);
+        }
+      else
+        {
+          d = cairo_image_surface_get_height (surface);
+
+          cairo_translate (cr, x, y + (height / 2));
+          cairo_scale (cr, 1, height / d);
+          cairo_set_source_surface (cr, surface, 0, - d / 2);
+          cairo_rectangle (cr, 0, - height / 2, width, height);
+        }
     }
 
-  cairo_pattern_set_matrix (pattern, &matrix);
-  cairo_set_source (cr, pattern);
-
-  cairo_rectangle (cr, x, y, width, height);
   cairo_fill (cr);
 
-  cairo_pattern_destroy (pattern);
-
   cairo_restore (cr);
 }
 
@@ -261,7 +280,7 @@ gtk_9slice_render (Gtk9Slice *slice,
   surface = slice->surfaces[BORDER_MIDDLE][BORDER_TOP];
   img_height = cairo_image_surface_get_height (surface);
 
-  render_border (cr, surface,
+  render_border (cr, surface, SIDE_TOP,
                  x + slice->distances[SIDE_LEFT], y,
                  (gdouble) width - slice->distances[SIDE_LEFT] - slice->distances[SIDE_RIGHT],
                  (gdouble) img_height,
@@ -271,7 +290,7 @@ gtk_9slice_render (Gtk9Slice *slice,
   surface = slice->surfaces[BORDER_MIDDLE][BORDER_BOTTOM];
   img_height = cairo_image_surface_get_height (surface);
 
-  render_border (cr, surface,
+  render_border (cr, surface, SIDE_BOTTOM,
                  x + slice->distances[SIDE_LEFT], y + height - img_height,
                  (gdouble) width - slice->distances[SIDE_LEFT] - slice->distances[SIDE_RIGHT],
                  (gdouble) img_height,
@@ -281,7 +300,7 @@ gtk_9slice_render (Gtk9Slice *slice,
   surface = slice->surfaces[BORDER_LEFT][BORDER_MIDDLE];
   img_width = cairo_image_surface_get_width (surface);
 
-  render_border (cr, surface,
+  render_border (cr, surface, SIDE_LEFT,
                  x, y + slice->distances[SIDE_TOP],
                  (gdouble) img_width,
                  (gdouble) height - slice->distances[SIDE_TOP] - slice->distances[SIDE_BOTTOM],
@@ -291,7 +310,7 @@ gtk_9slice_render (Gtk9Slice *slice,
   surface = slice->surfaces[BORDER_RIGHT][BORDER_MIDDLE];
   img_width = cairo_image_surface_get_width (surface);
 
-  render_border (cr, surface,
+  render_border (cr, surface, SIDE_RIGHT,
                  x + width - img_width, y + slice->distances[SIDE_TOP],
                  (gdouble) img_width, height - slice->distances[SIDE_TOP] - slice->distances[SIDE_BOTTOM],
                  slice->modifiers[SIDE_RIGHT]);
diff --git a/gtk/gtk9slice.h b/gtk/gtk9slice.h
index 28d998b..10e3df0 100644
--- a/gtk/gtk9slice.h
+++ b/gtk/gtk9slice.h
@@ -41,8 +41,8 @@ Gtk9Slice * gtk_9slice_new (GdkPixbuf            *pixbuf,
                             gdouble               distance_bottom,
                             gdouble               distance_left,
                             gdouble               distance_right,
-                            GtkSliceSideModifier  vertical_modifier,
-                            GtkSliceSideModifier  horizontal_modifier);
+                            GtkSliceSideModifier  horizontal_modifier,
+                            GtkSliceSideModifier  vertical_modifier);
 
 Gtk9Slice * gtk_9slice_ref   (Gtk9Slice *slice);
 void        gtk_9slice_unref (Gtk9Slice *slice);



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