diff options
author | Conor Curran <conor.curran@canonical.com> | 2010-11-16 19:59:45 +0000 |
---|---|---|
committer | Conor Curran <conor.curran@canonical.com> | 2010-11-16 19:59:45 +0000 |
commit | c17cdbc993b18166ae25ce9aea93a980eee410c7 (patch) | |
tree | ecd2dc38aa201024be75244d56bbe3c8cbe50a9a /src/title-widget.c | |
parent | c7bfb0ee9cfb5969f4c5905ee33eb808f09e9959 (diff) | |
parent | 6c882bee8faa60b3eeac4246adfcfdc10a5cadbf (diff) | |
download | ayatana-indicator-sound-c17cdbc993b18166ae25ce9aea93a980eee410c7.tar.gz ayatana-indicator-sound-c17cdbc993b18166ae25ce9aea93a980eee410c7.tar.bz2 ayatana-indicator-sound-c17cdbc993b18166ae25ce9aea93a980eee410c7.zip |
merge for grey scale icon for default music player done
Diffstat (limited to 'src/title-widget.c')
-rw-r--r-- | src/title-widget.c | 34 |
1 files changed, 24 insertions, 10 deletions
diff --git a/src/title-widget.c b/src/title-widget.c index 5bc2a93..1524a4a 100644 --- a/src/title-widget.c +++ b/src/title-widget.c @@ -83,27 +83,41 @@ title_widget_set_icon(TitleWidget *self) { TitleWidgetPrivate *priv = TITLE_WIDGET_GET_PRIVATE(self); - gchar* icon_name = g_strdup(dbusmenu_menuitem_property_get(priv->twin_item, - DBUSMENU_TITLE_MENUITEM_ICON)); gint padding = 0; gtk_widget_style_get(GTK_WIDGET(self), "horizontal-padding", &padding, NULL); - gint width, height; gtk_icon_size_lookup(GTK_ICON_SIZE_MENU, &width, &height); - - GtkWidget * icon = gtk_image_new_from_icon_name(icon_name, - GTK_ICON_SIZE_MENU); - - gtk_widget_set_size_request(icon, width + + GString* banshee_string = g_string_new ( "banshee" ); + GString* app_panel = g_string_new ( g_utf8_strdown ( dbusmenu_menuitem_property_get(priv->twin_item, DBUSMENU_TITLE_MENUITEM_NAME), + -1 )); + GtkWidget * icon = NULL; + + // Not ideal but apparently we want the banshee icon to be the greyscale one + // and any others to be the icon from the desktop file => colour. + if ( g_string_equal ( banshee_string, app_panel ) == TRUE && + gtk_icon_theme_has_icon ( gtk_icon_theme_get_default(), app_panel->str ) ){ + g_string_append ( app_panel, "-panel" ); + icon = gtk_image_new_from_icon_name ( app_panel->str, + GTK_ICON_SIZE_MENU ); + } + else{ + icon = gtk_image_new_from_icon_name ( g_strdup (dbusmenu_menuitem_property_get ( priv->twin_item, DBUSMENU_TITLE_MENUITEM_ICON )), + GTK_ICON_SIZE_MENU ); + } + g_string_free ( app_panel, FALSE) ; + g_string_free ( banshee_string, FALSE) ; + + gtk_widget_set_size_request(icon, width + 5 /* ref triangle is 5x9 pixels */ + 1 /* padding */, height); gtk_misc_set_alignment(GTK_MISC(icon), 0.5 /* right aligned */, 0); gtk_image_menu_item_set_image(GTK_IMAGE_MENU_ITEM(self), GTK_WIDGET(icon)); - gtk_widget_show(icon); - g_free(icon_name); + gtk_widget_show(icon); } + static void title_widget_dispose (GObject *object) { |