diff options
| author | Ted Gould <ted@canonical.com> | 2009-09-24 12:35:47 -0500 | 
|---|---|---|
| committer | Ted Gould <ted@canonical.com> | 2009-09-24 12:35:47 -0500 | 
| commit | ff637c41bed6a4e8970e37e6ca512f12f5a4afb0 (patch) | |
| tree | 05e0ab6f392fc99dc9dab9d4cd0754494926fd07 | |
| parent | ab65f0c528abb11dd7a822583a07c522963d9384 (diff) | |
| parent | fcda1c20e3ebfa62d3696a493af3ef3ef4716402 (diff) | |
| download | ayatana-indicator-messages-ff637c41bed6a4e8970e37e6ca512f12f5a4afb0.tar.gz ayatana-indicator-messages-ff637c41bed6a4e8970e37e6ca512f12f5a4afb0.tar.bz2 ayatana-indicator-messages-ff637c41bed6a4e8970e37e6ca512f12f5a4afb0.zip | |
Merging in the icon scaling branch
| -rw-r--r-- | src/indicator-messages.c | 48 | 
1 files changed, 46 insertions, 2 deletions
| diff --git a/src/indicator-messages.c b/src/indicator-messages.c index a3f22aa..01f2579 100644 --- a/src/indicator-messages.c +++ b/src/indicator-messages.c @@ -164,7 +164,29 @@ indicator_prop_change_cb (DbusmenuMenuitem * mi, gchar * prop, gchar * value, in  		   is already cached, shouldn't be a big deal really.  */  		GdkPixbuf * pixbuf = dbusmenu_menuitem_property_get_image(mi, INDICATOR_MENUITEM_PROP_ICON);  		if (pixbuf != NULL) { -			gtk_image_set_from_pixbuf(GTK_IMAGE(mi_data->icon), pixbuf); +			/* If we've got a pixbuf we need to make sure it's of a reasonable +			   size to fit in the menu.  If not, rescale it. */ +			GdkPixbuf * resized_pixbuf; +			gint width, height; +			gtk_icon_size_lookup(GTK_ICON_SIZE_MENU, &width, &height); +			if (gdk_pixbuf_get_width(pixbuf) > width || +					gdk_pixbuf_get_height(pixbuf) > height) { +				g_debug("Resizing icon from %dx%d to %dx%d", gdk_pixbuf_get_width(pixbuf), gdk_pixbuf_get_height(pixbuf), width, height); +				resized_pixbuf = gdk_pixbuf_scale_simple(pixbuf, +				                                         width, +				                                         height, +				                                         GDK_INTERP_BILINEAR); +			} else { +				g_debug("Happy with icon sized %dx%d", gdk_pixbuf_get_width(pixbuf), gdk_pixbuf_get_height(pixbuf)); +				resized_pixbuf = pixbuf; +			} +	   +			gtk_image_set_from_pixbuf(GTK_IMAGE(mi_data->icon), resized_pixbuf); + +			/* The other pixbuf should be free'd by the dbusmenu. */ +			if (resized_pixbuf != pixbuf) { +				g_object_unref(resized_pixbuf); +			}  		}  	} else {  		g_warning("Indicator Item property '%s' unknown", prop); @@ -194,7 +216,29 @@ new_indicator_item (DbusmenuMenuitem * newitem, DbusmenuMenuitem * parent, Dbusm  	mi_data->icon = gtk_image_new();  	GdkPixbuf * pixbuf = dbusmenu_menuitem_property_get_image(newitem, INDICATOR_MENUITEM_PROP_ICON);  	if (pixbuf != NULL) { -		gtk_image_set_from_pixbuf(GTK_IMAGE(mi_data->icon), pixbuf); +		/* If we've got a pixbuf we need to make sure it's of a reasonable +		   size to fit in the menu.  If not, rescale it. */ +		GdkPixbuf * resized_pixbuf; +		gint width, height; +		gtk_icon_size_lookup(GTK_ICON_SIZE_MENU, &width, &height); +		if (gdk_pixbuf_get_width(pixbuf) > width || +		        gdk_pixbuf_get_height(pixbuf) > height) { +			g_debug("Resizing icon from %dx%d to %dx%d", gdk_pixbuf_get_width(pixbuf), gdk_pixbuf_get_height(pixbuf), width, height); +			resized_pixbuf = gdk_pixbuf_scale_simple(pixbuf, +			                                         width, +			                                         height, +			                                         GDK_INTERP_BILINEAR); +		} else { +			g_debug("Happy with icon sized %dx%d", gdk_pixbuf_get_width(pixbuf), gdk_pixbuf_get_height(pixbuf)); +			resized_pixbuf = pixbuf; +		} +   +		gtk_image_set_from_pixbuf(GTK_IMAGE(mi_data->icon), resized_pixbuf); + +		/* The other pixbuf should be free'd by the dbusmenu. */ +		if (resized_pixbuf != pixbuf) { +			g_object_unref(resized_pixbuf); +		}  	}  	gtk_misc_set_alignment(GTK_MISC(mi_data->icon), 0.0, 0.5);  	gtk_box_pack_start(GTK_BOX(hbox), mi_data->icon, FALSE, FALSE, 0); | 
