[gdl/gnome-3-0] Set GtkJunctionSides for GdlSwitcher toggle buttons.
- From: Johannes Schmid <jhs src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gdl/gnome-3-0] Set GtkJunctionSides for GdlSwitcher toggle buttons.
- Date: Wed, 6 Apr 2011 21:22:13 +0000 (UTC)
commit b3a999dffd3a560285dbcee1b2af194f5f0efa6f
Author: Christian Hergert <chris dronelabs com>
Date: Thu Mar 24 22:05:13 2011 -0700
Set GtkJunctionSides for GdlSwitcher toggle buttons.
This sets the appropriate GtkJunctionSides for the GtkToggleButtons
used to select a GdlDockItem. The horizontal and vertical padding
between items has been removed, but the spacing between the
GdlDockItem and the toggle buttons preserved.
Signed-off-by: Christian Hergert <chris dronelabs com>
gdl/gdl-switcher.c | 36 ++++++++++++++++++++++++++++++------
1 files changed, 30 insertions(+), 6 deletions(-)
---
diff --git a/gdl/gdl-switcher.c b/gdl/gdl-switcher.c
index 1377e5f..448ae0b 100644
--- a/gdl/gdl-switcher.c
+++ b/gdl/gdl-switcher.c
@@ -93,8 +93,9 @@ G_DEFINE_TYPE (GdlSwitcher, gdl_switcher, GTK_TYPE_NOTEBOOK)
GDL_SWITCHER_STYLE_TOOLBAR ? switcher->priv->toolbar_style : \
switcher->priv->switcher_style)
-#define H_PADDING 2
-#define V_PADDING 2
+#define H_PADDING 0
+#define V_PADDING 0
+#define V_SPACING 2
/* Utility functions. */
@@ -394,7 +395,9 @@ layout_buttons (GdlSwitcher *switcher, GtkAllocation* allocation)
extra_width = 0;
for (p = rows [i]; p != NULL; p = p->next) {
GtkAllocation child_allocation;
-
+ GtkStyleContext *style_context;
+ GtkJunctionSides junction = 0;
+
child_allocation.x = x;
child_allocation.y = y;
if (rows_count == 1 && row_number == 0)
@@ -410,14 +413,35 @@ layout_buttons (GdlSwitcher *switcher, GtkAllocation* allocation)
}
child_allocation.height = max_btn_height;
+ style_context = gtk_widget_get_style_context (GTK_WIDGET (p->data));
+
+ if (row_last) {
+ if (i) {
+ junction |= GTK_JUNCTION_TOP;
+ }
+ if (i != row_last) {
+ junction |= GTK_JUNCTION_BOTTOM;
+ }
+ }
+
+ if (p->next) {
+ junction |= GTK_JUNCTION_RIGHT;
+ }
+
+ if (p != rows [i]) {
+ junction |= GTK_JUNCTION_LEFT;
+ }
+
+ gtk_style_context_set_junction_sides (style_context, junction);
+
gtk_widget_size_allocate (GTK_WIDGET (p->data), &child_allocation);
x += child_allocation.width + H_PADDING;
}
-
- y -= V_PADDING;
}
-
+
+ y -= V_SPACING;
+
for (i = 0; i <= row_last; i ++)
g_slist_free (rows [i]);
g_free (rows);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]