[gnome-shell] StThemeNode: Don't make border images and gradients mutually exclusive



commit 260ca64e947792e2942146c9945b8edae4438571
Author: Ray Strode <rstrode redhat com>
Date:   Fri Jan 14 14:03:40 2011 -0500

    StThemeNode: Don't make border images and gradients mutually exclusive
    
    Since we no longer use the same material for both purposes,
    we can now remove the restriction that they are mutually exclusive.
    
    https://bugzilla.gnome.org/show_bug.cgi?id=636976

 src/st/st-theme-node-drawing.c |   47 +++++++++++++++++++++------------------
 1 files changed, 25 insertions(+), 22 deletions(-)
---
diff --git a/src/st/st-theme-node-drawing.c b/src/st/st-theme-node-drawing.c
index 2720239..710bc12 100644
--- a/src/st/st-theme-node-drawing.c
+++ b/src/st/st-theme-node-drawing.c
@@ -430,6 +430,7 @@ get_arbitrary_border_color (StThemeNode   *node,
 static CoglHandle
 st_theme_node_render_gradient (StThemeNode *node)
 {
+  StBorderImage *border_image;
   CoglHandle texture;
   int radius[4], i;
   cairo_t *cr;
@@ -440,6 +441,8 @@ st_theme_node_render_gradient (StThemeNode *node)
   guint rowstride;
   guchar *data;
 
+  border_image = st_theme_node_get_border_image (node);
+
   rowstride = cairo_format_stride_for_width (CAIRO_FORMAT_ARGB32, node->alloc_width);
   data = g_new0 (guchar, node->alloc_height * rowstride);
   surface = cairo_image_surface_create_for_data (data,
@@ -512,15 +515,16 @@ st_theme_node_render_gradient (StThemeNode *node)
   cairo_close_path (cr);
 
 
-  /* If we have a border, we fill the outline with the border
+  /* If we have a solid border, we fill the outline with the border
    * color and create the inline shape for the background gradient;
    * otherwise the outline shape is filled with the background
    * gradient directly
    */
-  if (border_width[ST_SIDE_TOP] > 0 ||
-      border_width[ST_SIDE_RIGHT] > 0 ||
-      border_width[ST_SIDE_BOTTOM] > 0 ||
-      border_width[ST_SIDE_LEFT] > 0)
+  if (border_image == NULL &&
+      (border_width[ST_SIDE_TOP] > 0 ||
+       border_width[ST_SIDE_RIGHT] > 0 ||
+       border_width[ST_SIDE_BOTTOM] > 0 ||
+       border_width[ST_SIDE_LEFT] > 0))
     {
       cairo_set_source_rgba (cr,
                              border_color.red / 255.,
@@ -711,10 +715,9 @@ st_theme_node_render_resources (StThemeNode   *node,
 
       node->border_slices_texture = st_texture_cache_load_file_to_cogl_texture (texture_cache, filename);
     }
-  else if (node->background_gradient_type != ST_GRADIENT_NONE)
-    {
-      node->prerendered_texture = st_theme_node_render_gradient (node);
-    }
+
+  if (node->background_gradient_type != ST_GRADIENT_NONE)
+    node->prerendered_texture = st_theme_node_render_gradient (node);
 
   if (node->border_slices_texture)
     node->border_slices_material = _st_create_texture_material (node->border_slices_texture);
@@ -1247,14 +1250,8 @@ st_theme_node_paint (StThemeNode           *node,
    *  - The combination of border image and a non-zero border radius is
    *    not supported; the background color will be drawn with square
    *    corners.
-   *  - The combination of border image and a background gradient is not
-   *    supported; the background will be drawn as a solid color
-   *  - The background image is drawn above the border color or image,
-   *    not below it.
+   *  - The background image is drawn above the border color, not below it.
    *  - We don't clip the background image to the (rounded) border area.
-   *
-   * The first three allow us to always draw with no more than a single
-   * border_image and a single background image above it.
    */
 
   if (node->box_shadow_material)
@@ -1263,13 +1260,19 @@ st_theme_node_paint (StThemeNode           *node,
                                    &allocation,
                                    paint_opacity);
 
-  /* Gradients and border images are mutually exclusive at this time */
-  if (node->prerendered_material != COGL_INVALID_HANDLE)
-    paint_material_with_opacity (node->prerendered_material, &allocation, paint_opacity);
-  else if (node->border_slices_material != COGL_INVALID_HANDLE)
-    st_theme_node_paint_sliced_border_image (node, &allocation, paint_opacity);
+  if (node->prerendered_material != COGL_INVALID_HANDLE ||
+      node->border_slices_material != COGL_INVALID_HANDLE)
+    {
+      if (node->prerendered_material != COGL_INVALID_HANDLE)
+        paint_material_with_opacity (node->prerendered_material, &allocation, paint_opacity);
+
+      if (node->border_slices_material != COGL_INVALID_HANDLE)
+        st_theme_node_paint_sliced_border_image (node, &allocation, paint_opacity);
+    }
   else
-    st_theme_node_paint_borders (node, box, paint_opacity);
+    {
+      st_theme_node_paint_borders (node, box, paint_opacity);
+    }
 
   st_theme_node_paint_outline (node, box, paint_opacity);
 



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