summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimm Bäder <mail@baedert.org>2016-04-30 21:06:07 +0200
committerMatthias Clasen <mclasen@redhat.com>2016-05-05 15:04:01 -0400
commitbab6cb6d97150660ca2b3a19e1033bc6504cbb73 (patch)
tree1bb65976ef770ac81bd64ae1fb304dfe79fb072f
parentf58aaf2ccf41abda637d22e8de8bca8ad60cce8e (diff)
downloadgtk+-bab6cb6d97150660ca2b3a19e1033bc6504cbb73.tar.gz
shadowsvalue: Don't draw invisible box shadows
-rw-r--r--gtk/gtkcssshadowvalue.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/gtk/gtkcssshadowvalue.c b/gtk/gtkcssshadowvalue.c
index 93b4dcf927..35d3df764a 100644
--- a/gtk/gtkcssshadowvalue.c
+++ b/gtk/gtkcssshadowvalue.c
@@ -516,6 +516,10 @@ _gtk_css_shadow_value_paint_layout (const GtkCssValue *shadow,
{
g_return_if_fail (shadow->class == &GTK_CSS_VALUE_SHADOW);
+ /* We don't need to draw invisible shadows */
+ if (gtk_rgba_is_clear (_gtk_css_rgba_value_get_rgba (shadow->color)))
+ return;
+
if (!cairo_has_current_point (cr))
cairo_move_to (cr, 0, 0);
@@ -558,6 +562,10 @@ _gtk_css_shadow_value_paint_icon (const GtkCssValue *shadow,
g_return_if_fail (shadow->class == &GTK_CSS_VALUE_SHADOW);
+ /* We don't need to draw invisible shadows */
+ if (gtk_rgba_is_clear (_gtk_css_rgba_value_get_rgba (shadow->color)))
+ return;
+
cairo_save (cr);
pattern = cairo_pattern_reference (cairo_get_source (cr));
@@ -875,6 +883,10 @@ _gtk_css_shadow_value_paint_box (const GtkCssValue *shadow,
g_return_if_fail (shadow->class == &GTK_CSS_VALUE_SHADOW);
+ /* We don't need to draw invisible shadows */
+ if (gtk_rgba_is_clear (_gtk_css_rgba_value_get_rgba (shadow->color)))
+ return;
+
cairo_clip_extents (cr, &x1c, &y1c, &x2c, &y2c);
if ((shadow->inset && !_gtk_rounded_box_intersects_rectangle (padding_box, x1c, y1c, x2c, y2c)) ||
(!shadow->inset && _gtk_rounded_box_contains_rectangle (padding_box, x1c, y1c, x2c, y2c)))