[glade/ui-incubator: 6/6] Added draw_container_wireframe() to draw a frame around each selected widget sibling. TODO: add a pr
- From: Juan Pablo Ugarte <jpu src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glade/ui-incubator: 6/6] Added draw_container_wireframe() to draw a frame around each selected widget sibling. TODO: add a pr
- Date: Wed, 12 Dec 2012 19:37:37 +0000 (UTC)
commit 24f73affb0761186dd1898fcb72869ca9805e404
Author: Juan Pablo Ugarte <juanpablougarte gmail com>
Date: Thu Nov 1 20:59:09 2012 -0300
Added draw_container_wireframe() to draw a frame around each selected widget sibling.
TODO: add a property to make this optional.
gladeui/glade-design-layout.c | 63 +++++++++++++++++++++++++++++++++++++++-
1 files changed, 61 insertions(+), 2 deletions(-)
---
diff --git a/gladeui/glade-design-layout.c b/gladeui/glade-design-layout.c
index f6f2854..296a3e3 100644
--- a/gladeui/glade-design-layout.c
+++ b/gladeui/glade-design-layout.c
@@ -1057,6 +1057,60 @@ draw_margin_selection (cairo_t *cr,
}
static inline void
+draw_container_wireframe (cairo_t *cr,
+ GtkWidget *parent,
+ GtkWidget *widget,
+ GdkRGBA *color)
+{
+ GladeWidget *gwidget = glade_widget_get_from_gobject (widget);
+ GladeWidget *gcontainer = glade_widget_get_parent (gwidget);
+ GtkWidget *container = GTK_WIDGET (glade_widget_get_object (gcontainer));
+ GList *l, *children;
+
+ if (!(GTK_IS_BOX (container) ||
+ GTK_IS_GRID (container) ||
+ GTK_IS_TABLE (container) ||
+ GTK_IS_MENU_SHELL (container) ||
+ GTK_IS_TOOLBAR (container)))
+ return;
+
+ children = gtk_container_get_children (GTK_CONTAINER (container));
+ /* Append a rectangle to path for each children */
+ for (l = children; l; l = g_list_next (l))
+ {
+ GtkWidget *child = l->data;
+ gint x, y, border, l, t;
+ GtkAllocation alloc;
+
+ if (!gtk_widget_get_visible (child))
+ continue;
+
+ gtk_widget_get_allocation (child, &alloc);
+ gtk_widget_translate_coordinates (child, parent, 0, 0, &x, &y);
+
+ /* Add margins to allocation */
+ x -= (l = gtk_widget_get_margin_left (child));
+ y -= (t = gtk_widget_get_margin_top (child));
+ alloc.width += gtk_widget_get_margin_right (child) + l;
+ alloc.height += gtk_widget_get_margin_bottom (child) + t;
+
+ /* Add border if its a container */
+ if (GTK_IS_CONTAINER (child) &&
+ (border = gtk_container_get_border_width (GTK_CONTAINER (child))))
+ cairo_rectangle (cr, x - border, y - border,
+ alloc.width + border + border,
+ alloc.height + border + border);
+ else
+ cairo_rectangle (cr, x, y, alloc.width, alloc.height);
+ }
+
+ cairo_set_source_rgba (cr, color->red, color->green, color->blue, .64);
+ cairo_stroke (cr);
+
+ g_list_free (children);
+}
+
+static inline void
draw_selection (cairo_t *cr,
GtkWidget *parent,
GtkWidget *widget,
@@ -1463,13 +1517,15 @@ glade_design_layout_draw (GtkWidget *widget, cairo_t *cr)
gtk_render_background (gtk_widget_get_style_context (widget),
cr, 0, 0, w, h);
cairo_restore (cr);
-
+
+ cairo_save (cr);
/* draw offscreen widgets */
gdk_cairo_set_source_window (cr, priv->offscreen_window,
priv->child_offset, priv->child_offset);
cairo_rectangle (cr, priv->child_offset, priv->child_offset,
priv->current_width, priv->current_height);
- cairo_fill (cr);
+ cairo_fill_preserve (cr);
+ cairo_clip (cr);
/* Draw selection */
cairo_set_line_width (cr, OUTLINE_WIDTH/2);
@@ -1485,6 +1541,7 @@ glade_design_layout_draw (GtkWidget *widget, cairo_t *cr)
if (GTK_IS_WIDGET (selection) &&
gtk_widget_is_ancestor (selection, child))
{
+ draw_container_wireframe (cr, widget, selection, &priv->frame_color_active[0]);
draw_selection (cr, widget, selection, &priv->frame_color_active[0]);
selected = TRUE;
}
@@ -1493,6 +1550,8 @@ glade_design_layout_draw (GtkWidget *widget, cairo_t *cr)
selected = TRUE;
}
+ cairo_restore (cr);
+
/* draw frame */
draw_frame (cr, priv, selected,
border_width + PADDING,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]