diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/egg/eggtoolbar.c | 56 | ||||
-rw-r--r-- | lib/egg/eggtoolbutton.c | 20 |
2 files changed, 49 insertions, 27 deletions
diff --git a/lib/egg/eggtoolbar.c b/lib/egg/eggtoolbar.c index 8e2335984..78678079b 100644 --- a/lib/egg/eggtoolbar.c +++ b/lib/egg/eggtoolbar.c @@ -43,7 +43,7 @@ #include <gtk/gtkprivate.h> #include <string.h> -#define DEFAULT_IPADDING 1 +#define DEFAULT_IPADDING 0 #define DEFAULT_SPACE_SIZE 5 #define DEFAULT_SPACE_STYLE GTK_TOOLBAR_SPACE_LINE @@ -54,11 +54,6 @@ #define SPACE_LINE_START 3 #define SPACE_LINE_END 7 -#define TOOLBAR_ITEM_VISIBLE(item) \ -(GTK_WIDGET_VISIBLE (item) && \ -((toolbar->orientation == GTK_ORIENTATION_HORIZONTAL && item->visible_horizontal) || \ - (toolbar->orientation == GTK_ORIENTATION_VERTICAL && item->visible_vertical))) - #ifndef _ # define _(s) (s) #endif @@ -546,6 +541,33 @@ egg_toolbar_init (EggToolbar *toolbar) priv->menu = NULL; } +static gboolean +toolbar_item_visible (EggToolbar *toolbar, EggToolItem *item) +{ + if (GTK_WIDGET_VISIBLE (item) && + ((toolbar->orientation == GTK_ORIENTATION_HORIZONTAL && item->visible_horizontal) || + (toolbar->orientation == GTK_ORIENTATION_VERTICAL && item->visible_vertical))) + { + EggToolbarPrivate *priv = EGG_TOOLBAR_GET_PRIVATE (toolbar); + + /* With the old toolbar you could hide a button by calling gtk_widget_hide() + * on it. This doesn't work with the new API because the EggToolItem will not be + * hidden. + */ + if (priv->api_mode == OLD_API) + { + GtkWidget *bin_child = GTK_BIN (item)->child; + + if (!bin_child || !GTK_WIDGET_VISIBLE (bin_child)) + return FALSE; + } + + return TRUE; + } + + return FALSE; +} + static void egg_toolbar_set_property (GObject *object, guint prop_id, @@ -798,7 +820,7 @@ egg_toolbar_size_request (GtkWidget *widget, GtkRequisition requisition; EggToolItem *item = list->data; - if (!TOOLBAR_ITEM_VISIBLE (item)) + if (!toolbar_item_visible (toolbar, item)) continue; gtk_widget_size_request (GTK_WIDGET (item), &requisition); @@ -825,7 +847,7 @@ egg_toolbar_size_request (GtkWidget *widget, EggToolItem *item = list->data; guint size; - if (!TOOLBAR_ITEM_VISIBLE (item)) + if (!toolbar_item_visible (toolbar, item)) continue; if (!GTK_BIN (item)->child) @@ -1007,7 +1029,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item)) + if (toolbar_item_visible (toolbar, item)) needed_size += get_item_size (toolbar, GTK_WIDGET (item)); } @@ -1028,7 +1050,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, GtkAllocation *allocation = &(allocations[n_items - i - 1]); gint item_size; - if (!item->pack_end || !TOOLBAR_ITEM_VISIBLE (item)) + if (!item->pack_end || !toolbar_item_visible (toolbar, item)) continue; item_size = get_item_size (toolbar, GTK_WIDGET (item)); @@ -1059,7 +1081,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, EggToolItem *item = list->data; gint item_size; - if (item->pack_end || !TOOLBAR_ITEM_VISIBLE (item)) + if (item->pack_end || !toolbar_item_visible (toolbar, item)) continue; item_size = get_item_size (toolbar, GTK_WIDGET (item)); @@ -1094,7 +1116,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item) && item->expand && + if (toolbar_item_visible (toolbar, item) && item->expand && !item->overflow_item && GTK_BIN (item)->child) { n_expand_items++; @@ -1105,7 +1127,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item) && item->expand && + if (toolbar_item_visible (toolbar, item) && item->expand && !item->overflow_item && GTK_BIN (item)->child) { gint extra = size / n_expand_items; @@ -1126,7 +1148,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item) && !item->overflow_item && !item->pack_end) + if (toolbar_item_visible (toolbar, item) && !item->overflow_item && !item->pack_end) { allocations[i].x = pos; allocations[i].y = border_width; @@ -1143,7 +1165,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item) && !item->overflow_item && item->pack_end) + if (toolbar_item_visible (toolbar, item) && !item->overflow_item && item->pack_end) { GtkAllocation *allocation = &(allocations[n_items - i - 1]); @@ -1199,7 +1221,7 @@ egg_toolbar_size_allocate (GtkWidget *widget, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item) && !item->overflow_item) + if (toolbar_item_visible (toolbar, item) && !item->overflow_item) { gtk_widget_size_allocate (GTK_WIDGET (item), &(allocations[i])); gtk_widget_set_child_visible (GTK_WIDGET (item), TRUE); @@ -1912,7 +1934,7 @@ show_menu (EggToolbar *toolbar, { EggToolItem *item = list->data; - if (TOOLBAR_ITEM_VISIBLE (item) && item->overflow_item) + if (toolbar_item_visible (toolbar, item) && item->overflow_item) { GtkWidget *menu_item = egg_tool_item_retrieve_proxy_menu_item (item); diff --git a/lib/egg/eggtoolbutton.c b/lib/egg/eggtoolbutton.c index 1e17a89dc..ec2fb3a4d 100644 --- a/lib/egg/eggtoolbutton.c +++ b/lib/egg/eggtoolbutton.c @@ -367,30 +367,30 @@ egg_tool_button_construct_contents (EggToolItem *tool_item) } else if (button->icon_widget) { - if (GTK_IS_IMAGE (button->icon_widget)) + icon = button->icon_widget; + + if (GTK_IS_IMAGE (icon)) { - GtkImage *image = GTK_IMAGE (button->icon_widget); + GtkImage *image = GTK_IMAGE (icon); GtkImageType storage_type = gtk_image_get_storage_type (image); - /* FIXME: this seems a bit dubious. We are changing a widget that the - * user passed in. It's probably better to create a new image instead. - */ - if (storage_type == GTK_IMAGE_STOCK) { gchar *stock_id; gtk_image_get_stock (image, &stock_id, NULL); - gtk_image_set_from_stock (image, stock_id, icon_size); + + icon = gtk_image_new_from_stock (stock_id, icon_size); + gtk_widget_show (icon); } else if (storage_type == GTK_IMAGE_ICON_SET) { GtkIconSet *icon_set; gtk_image_get_icon_set (image, &icon_set, NULL); - gtk_image_set_from_icon_set (image, icon_set, icon_size); + + icon = gtk_image_new_from_icon_set (icon_set, icon_size); + gtk_widget_show (icon); } } - - icon = button->icon_widget; } else if (button->stock_id) { |