Proposed patch to GTK+ 1.3
- From: ERDI Gergo <cactus telnet hu>
- To: gtk-list redhat com
- cc: jcape jcinteractive com
- Subject: Proposed patch to GTK+ 1.3
- Date: Tue, 21 Sep 1999 20:22:49 +0200 (CEST)
Hi,
The attached patch is an implementation of Idea #13 from
http://www.jcinteractive.com/gnome-ui/software/widgets/
basically, layouting the toolbar icon and label horizontally.
Please allow me to commit it to the CVS version of GTK+ 1.3, as AFAIK this
is an "unstable" branch, and thus it's no problem if binary compatibility
breaks because of a new GtkToolbarStyle value.
Bye,
Cactus
--
.--= ULLA! =----------------------------. finger cactus@cactus.rulez.org
\ http://cactus.rulez.org \ for PGP public key
`----------= cactus@cactus.rulez.org =--'
F U CN RD THS U CNT SPL WRTH A DM!
? 1
Index: gtkenums.h
===================================================================
RCS file: /cvs/gnome/gtk+/gtk/gtkenums.h,v
retrieving revision 1.23
diff -u -r1.23 gtkenums.h
--- gtkenums.h 1999/02/24 07:34:27 1.23
+++ gtkenums.h 1999/09/21 17:07:29
@@ -270,7 +270,8 @@
{
GTK_TOOLBAR_ICONS,
GTK_TOOLBAR_TEXT,
- GTK_TOOLBAR_BOTH
+ GTK_TOOLBAR_BOTH,
+ GTK_TOOLBAR_BOTH_HORIZ
} GtkToolbarStyle;
/* Trough types for GtkRange */
Index: gtktoolbar.c
===================================================================
RCS file: /cvs/gnome/gtk+/gtk/gtktoolbar.c,v
retrieving revision 1.35
diff -u -r1.35 gtktoolbar.c
--- gtktoolbar.c 1999/09/17 18:17:20 1.35
+++ gtktoolbar.c 1999/09/21 17:07:53
@@ -30,6 +30,7 @@
#include "gtkradiobutton.h"
#include "gtklabel.h"
#include "gtkvbox.h"
+#include "gtkhbox.h"
#include "gtktoolbar.h"
@@ -819,7 +820,6 @@
gint position)
{
GtkToolbarChild *child;
- GtkWidget *vbox;
g_return_val_if_fail (toolbar != NULL, NULL);
g_return_val_if_fail (GTK_IS_TOOLBAR (toolbar), NULL);
@@ -839,6 +839,9 @@
child->type = type;
child->icon = NULL;
child->label = NULL;
+ child->hbox = NULL;
+ child->vbox = NULL;
+ child->box = NULL;
switch (type)
{
@@ -861,7 +864,7 @@
gtk_button_set_relief (GTK_BUTTON (child->widget), toolbar->relief);
}
else if (type == GTK_TOOLBAR_CHILD_TOGGLEBUTTON)
- {
+ {
child->widget = gtk_toggle_button_new ();
gtk_button_set_relief (GTK_BUTTON (child->widget), toolbar->relief);
gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (child->widget),
@@ -882,14 +885,19 @@
gtk_signal_connect (GTK_OBJECT (child->widget), "clicked",
callback, user_data);
- vbox = gtk_vbox_new (FALSE, 0);
- gtk_container_add (GTK_CONTAINER (child->widget), vbox);
- gtk_widget_show (vbox);
+ child->vbox = gtk_vbox_new (FALSE, 0);
+ child->hbox = gtk_hbox_new (FALSE, 0);
+ if (toolbar->style == GTK_TOOLBAR_BOTH_HORIZ)
+ child->box = child->hbox;
+ else
+ child->box = child->vbox;
+ gtk_container_add (GTK_CONTAINER (child->widget), child->box);
+ gtk_widget_show (child->box);
if (text)
{
child->label = gtk_label_new (text);
- gtk_box_pack_end (GTK_BOX (vbox), child->label, FALSE, FALSE, 0);
+ gtk_box_pack_end (GTK_BOX (child->box), child->label, FALSE, FALSE, 0);
if (toolbar->style != GTK_TOOLBAR_ICONS)
gtk_widget_show (child->label);
}
@@ -897,7 +905,7 @@
if (icon)
{
child->icon = GTK_WIDGET (icon);
- gtk_box_pack_end (GTK_BOX (vbox), child->icon, FALSE, FALSE, 0);
+ gtk_box_pack_end (GTK_BOX (child->box), child->icon, FALSE, FALSE, 0);
if (toolbar->style != GTK_TOOLBAR_TEXT)
gtk_widget_show (child->icon);
}
@@ -1084,7 +1092,7 @@
case GTK_TOOLBAR_TEXT:
if (child->icon && GTK_WIDGET_VISIBLE (child->icon))
gtk_widget_hide (child->icon);
-
+
if (child->label && !GTK_WIDGET_VISIBLE (child->label))
gtk_widget_show (child->label);
@@ -1096,7 +1104,81 @@
if (child->label && !GTK_WIDGET_VISIBLE (child->label))
gtk_widget_show (child->label);
-
+
+ if (GTK_IS_HBOX (child->box))
+ {
+ if (child->icon)
+ gtk_object_ref (GTK_OBJECT (child->icon));
+ if (child->label)
+ gtk_object_ref (GTK_OBJECT (child->label));
+
+ if (child->icon)
+ gtk_container_remove (GTK_CONTAINER (child->box),
+ child->icon);
+ if (child->label)
+ gtk_container_remove (GTK_CONTAINER (child->box),
+ child->label);
+ gtk_container_remove (GTK_CONTAINER (child->widget),
+ child->box);
+
+ child->vbox = gtk_vbox_new (FALSE, 0);
+ child->box = child->vbox;
+ gtk_widget_show (child->box);
+
+ if (child->label)
+ gtk_box_pack_end (GTK_BOX (child->box), child->label, FALSE, FALSE, 0);
+ if (child->icon)
+ gtk_box_pack_end (GTK_BOX (child->box), child->icon, FALSE, FALSE, 0);
+ gtk_container_add (GTK_CONTAINER (child->widget),
+ child->box);
+
+ if (child->icon)
+ gtk_object_unref (GTK_OBJECT (child->icon));
+ if (child->label)
+ gtk_object_unref (GTK_OBJECT (child->label));
+ }
+
+ break;
+
+ case GTK_TOOLBAR_BOTH_HORIZ:
+ if (child->icon && !GTK_WIDGET_VISIBLE (child->icon))
+ gtk_widget_show (child->icon);
+ if (child->label && !GTK_WIDGET_VISIBLE (child->label))
+ gtk_widget_show (child->label);
+
+ if (GTK_IS_VBOX (child->box))
+ {
+ if (child->icon)
+ gtk_object_ref (GTK_OBJECT (child->icon));
+ if (child->label)
+ gtk_object_ref (GTK_OBJECT (child->label));
+
+ if (child->icon)
+ gtk_container_remove (GTK_CONTAINER (child->box),
+ child->icon);
+ if (child->label)
+ gtk_container_remove (GTK_CONTAINER (child->box),
+ child->label);
+ gtk_container_remove (GTK_CONTAINER (child->widget),
+ child->box);
+
+ child->hbox = gtk_hbox_new (FALSE, 0);
+ child->box = child->hbox;
+ gtk_widget_show (child->box);
+
+ if (child->label)
+ gtk_box_pack_end (GTK_BOX (child->box), child->label, TRUE, TRUE, 0);
+ if (child->icon)
+ gtk_box_pack_end (GTK_BOX (child->box), child->icon, FALSE, FALSE, 0);
+ gtk_container_add (GTK_CONTAINER (child->widget),
+ child->box);
+
+ if (child->icon)
+ gtk_object_unref (GTK_OBJECT (child->icon));
+ if (child->label)
+ gtk_object_unref (GTK_OBJECT (child->label));
+ }
+
break;
default:
Index: gtktoolbar.h
===================================================================
RCS file: /cvs/gnome/gtk+/gtk/gtktoolbar.h,v
retrieving revision 1.18
diff -u -r1.18 gtktoolbar.h
--- gtktoolbar.h 1999/09/17 18:17:20 1.18
+++ gtktoolbar.h 1999/09/21 17:07:54
@@ -71,6 +71,9 @@
GtkWidget *widget;
GtkWidget *icon;
GtkWidget *label;
+ GtkWidget *vbox;
+ GtkWidget *hbox;
+ GtkWidget *box;
};
struct _GtkToolbar
Index: testgtk.c
===================================================================
RCS file: /cvs/gnome/gtk+/gtk/testgtk.c,v
retrieving revision 1.167
diff -u -r1.167 testgtk.c
--- testgtk.c 1999/03/17 23:02:10 1.167
+++ testgtk.c 1999/09/21 17:25:47
@@ -624,6 +624,13 @@
}
static void
+set_toolbar_both_horiz (GtkWidget *widget,
+ gpointer data)
+{
+ gtk_toolbar_set_style (GTK_TOOLBAR (data), GTK_TOOLBAR_BOTH_HORIZ);
+}
+
+static void
set_toolbar_small_space (GtkWidget *widget,
gpointer data)
{
@@ -725,7 +732,13 @@
"Both", "Show toolbar icons and text", "Toolbar/Both",
new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
(GtkSignalFunc) set_toolbar_both, toolbar);
-
+ gtk_toolbar_append_item (GTK_TOOLBAR (toolbar),
+ "Both (horizontal)",
+ "Show toolbar icons and text in a horizontal fashion",
+ "Toolbar/BothHoriz",
+ new_pixmap ("test.xpm", window->window, &window->style->bg[GTK_STATE_NORMAL]),
+ (GtkSignalFunc) set_toolbar_both_horiz, toolbar);
+
gtk_toolbar_append_space (GTK_TOOLBAR (toolbar));
entry = gtk_entry_new ();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]