[gtk+] gtkwindow: Calculate the opaque window based off of the style
- From: Jasper St. Pierre <jstpierre src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] gtkwindow: Calculate the opaque window based off of the style
- Date: Wed, 28 Aug 2013 14:34:18 +0000 (UTC)
commit 3c2c3ab6f9335f8e7592041ca6ce7490ede62eeb
Author: Jasper St. Pierre <jstpierre mecheye net>
Date: Thu Aug 22 13:20:10 2013 -0400
gtkwindow: Calculate the opaque window based off of the style
https://bugzilla.gnome.org/show_bug.cgi?id=706922
gtk/gtkwindow.c | 83 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 83 insertions(+), 0 deletions(-)
---
diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c
index 55e5088..1fe96a8 100644
--- a/gtk/gtkwindow.c
+++ b/gtk/gtkwindow.c
@@ -35,6 +35,8 @@
#include "gtkwindowprivate.h"
#include "gtkaccelgroupprivate.h"
#include "gtkbindings.h"
+#include "gtkcsscornervalueprivate.h"
+#include "gtkcssrgbavalueprivate.h"
#include "gtkcssshadowsvalueprivate.h"
#include "gtkkeyhash.h"
#include "gtkmain.h"
@@ -6468,6 +6470,85 @@ update_frame_extents (GtkWindow *window,
#endif
}
+static void
+corner_rect (cairo_rectangle_int_t *rect,
+ const GtkCssValue *value)
+{
+ rect->width = _gtk_css_corner_value_get_x (value, 100);
+ rect->height = _gtk_css_corner_value_get_y (value, 100);
+}
+
+static void
+subtract_corners_from_region (cairo_region_t *region,
+ cairo_rectangle_int_t *extents,
+ GtkStyleContext *context)
+{
+ cairo_rectangle_int_t rect;
+
+ gtk_style_context_save (context);
+ add_window_frame_style_class (context);
+
+ corner_rect (&rect, _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_BORDER_TOP_LEFT_RADIUS));
+ rect.x = extents->x;
+ rect.y = extents->y;
+ cairo_region_subtract_rectangle (region, &rect);
+
+ corner_rect (&rect, _gtk_style_context_peek_property (context, GTK_CSS_PROPERTY_BORDER_TOP_RIGHT_RADIUS));
+ rect.x = extents->x + extents->width - rect.width;
+ rect.y = extents->y;
+ cairo_region_subtract_rectangle (region, &rect);
+
+ corner_rect (&rect, _gtk_style_context_peek_property (context,
GTK_CSS_PROPERTY_BORDER_BOTTOM_LEFT_RADIUS));
+ rect.x = extents->x;
+ rect.y = extents->y + extents->height - rect.height;
+ cairo_region_subtract_rectangle (region, &rect);
+
+ corner_rect (&rect, _gtk_style_context_peek_property (context,
GTK_CSS_PROPERTY_BORDER_BOTTOM_RIGHT_RADIUS));
+ rect.x = extents->x + extents->width - rect.width;
+ rect.y = extents->y + extents->height - rect.height;
+ cairo_region_subtract_rectangle (region, &rect);
+
+ gtk_style_context_restore (context);
+}
+
+static void
+update_opaque_region (GtkWindow *window,
+ GtkBorder *border,
+ const GtkAllocation *allocation)
+{
+ const GdkRGBA *color;
+ cairo_region_t *opaque_region;
+ GtkStyleContext *context;
+
+ if (!gtk_widget_get_realized (GTK_WIDGET (window)))
+ return;
+
+ context = gtk_widget_get_style_context (GTK_WIDGET (window));
+ color = _gtk_css_rgba_value_get_rgba (_gtk_style_context_peek_property (context,
GTK_CSS_PROPERTY_BACKGROUND_COLOR));
+
+ if (color->alpha >= 1.0)
+ {
+ cairo_rectangle_int_t rect;
+
+ rect.x = border->left;
+ rect.y = border->top;
+ rect.width = allocation->width - border->left - border->right;
+ rect.height = allocation->height - border->top - border->bottom;
+
+ opaque_region = cairo_region_create_rectangle (&rect);
+
+ subtract_corners_from_region (opaque_region, &rect, context);
+ }
+ else
+ {
+ opaque_region = NULL;
+ }
+
+ gdk_window_set_opaque_region (gtk_widget_get_window (GTK_WIDGET (window)), opaque_region);
+
+ cairo_region_destroy (opaque_region);
+}
+
/* _gtk_window_set_allocation:
* @window: a #GtkWindow
* @allocation: the original allocation for the window
@@ -6516,6 +6597,8 @@ _gtk_window_set_allocation (GtkWindow *window,
if (priv->client_decorated)
update_frame_extents (window, &window_border);
+ update_opaque_region (window, &window_border, &child_allocation);
+
if (priv->title_box != NULL &&
priv->decorated &&
!priv->fullscreen)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]