diff options
author | Olivier Duchateau <olivierd@FreeBSD.org> | 2014-01-02 16:15:31 +0000 |
---|---|---|
committer | Olivier Duchateau <olivierd@FreeBSD.org> | 2014-01-02 16:15:31 +0000 |
commit | 1880db48ab3010e9cf89ea2a5807982222be2f72 (patch) | |
tree | a6de1c656a122e95bc945068b997fab2264d516d /x11-wm | |
parent | 203e181e99e2e76dae78f47ccda6f4addc36cb8d (diff) | |
download | ports-1880db48ab3010e9cf89ea2a5807982222be2f72.tar.gz ports-1880db48ab3010e9cf89ea2a5807982222be2f72.zip |
Notes
Diffstat (limited to 'x11-wm')
-rw-r--r-- | x11-wm/xfce4-desktop/files/patch-src__xfdesktop-app-menu-item.c | 86 |
1 files changed, 15 insertions, 71 deletions
diff --git a/x11-wm/xfce4-desktop/files/patch-src__xfdesktop-app-menu-item.c b/x11-wm/xfce4-desktop/files/patch-src__xfdesktop-app-menu-item.c index 93df27c4ec19..c7ac70238e64 100644 --- a/x11-wm/xfce4-desktop/files/patch-src__xfdesktop-app-menu-item.c +++ b/x11-wm/xfce4-desktop/files/patch-src__xfdesktop-app-menu-item.c @@ -1,78 +1,22 @@ ---- ./src/xfdesktop-app-menu-item.c.orig 2013-03-02 16:40:19.000000000 +0000 -+++ ./src/xfdesktop-app-menu-item.c 2013-03-18 09:50:38.000000000 +0000 -@@ -28,6 +28,10 @@ - #include <string.h> - #endif - -+#ifdef HAVE_MATH_H -+#include <math.h> -+#endif -+ - #include <gtk/gtk.h> +--- ./src/xfdesktop-app-menu-item.c.orig 2013-09-16 07:17:42.000000000 +0000 ++++ ./src/xfdesktop-app-menu-item.c 2013-12-17 20:23:34.000000000 +0000 +@@ -31,6 +31,7 @@ #include <libxfce4util/libxfce4util.h> -@@ -169,8 +173,11 @@ - xfdesktop_app_menu_item_set_icon(XfdesktopAppMenuItem *app_menu_item) - { - const gchar *icon_name; -- gint w, h, size; -+ gint w, h, size, new_size; -+ gint src_w, src_h; -+ gdouble wratio, hratio; - GdkPixbuf *pixbuf = NULL; -+ GdkPixbuf *dest; - GtkWidget *image = NULL; - GtkIconTheme *icon_theme; - gchar *p, *name = NULL; -@@ -187,7 +194,7 @@ - image = gtk_image_new_from_icon_name(icon_name, GTK_ICON_SIZE_MENU); - else { - if (g_path_is_absolute(icon_name)) { -- pixbuf = gdk_pixbuf_new_from_file_at_scale(icon_name, w, h, TRUE, NULL); -+ pixbuf = gdk_pixbuf_new_from_file(icon_name, NULL); - } else { - /* try to lookup names like application.png in the theme */ - p = strrchr(icon_name, '.'); -@@ -206,11 +213,41 @@ - } + #include <libxfce4ui/libxfce4ui.h> ++#include <exo/exo.h> - if(name) { -- pixbuf = gdk_pixbuf_new_from_file_at_scale(name, w, h, TRUE, NULL); -+ pixbuf = gdk_pixbuf_new_from_file(name, NULL); - g_free(name); - } - } + #include "xfdesktop-app-menu-item.h" + +@@ -212,6 +213,11 @@ -+ /* scale the pixbuf */ -+ if(G_LIKELY(pixbuf)) { -+ /* 24x24 pixels looks good */ -+ new_size = MIN(24, 24); -+ -+ src_w = gdk_pixbuf_get_width(pixbuf); -+ src_h = gdk_pixbuf_get_height(pixbuf); -+ -+ if(src_w > 24 || src_h > 24) { -+ /* calculate the new dimensions */ -+ wratio = (gdouble) src_w / (gdouble) new_size; -+ hratio = (gdouble) src_h / (gdouble) new_size; -+ -+ if(hratio == wratio) { -+ w = rint(src_w / hratio); -+ h = rint(src_h / hratio); -+ } -+ else if(hratio > wratio) -+ w = rint(src_w / hratio); -+ else -+ h = rint(src_h / wratio); -+ -+ dest = gdk_pixbuf_scale_simple(pixbuf, -+ MAX(w, 1), MAX(h, 1), GDK_INTERP_BILINEAR); -+ -+ g_object_unref(G_OBJECT(pixbuf)); -+ pixbuf = dest; -+ } -+ } -+ /* Turn the pixbuf into a gtk_image */ if(G_LIKELY(pixbuf)) { ++ /* scale the pixbuf down if it needs it */ ++ GdkPixbuf *tmp = exo_gdk_pixbuf_scale_down(pixbuf, TRUE, w, h); ++ g_object_unref(pixbuf); ++ pixbuf = tmp; ++ image = gtk_image_new_from_pixbuf(pixbuf); + g_object_unref(G_OBJECT(pixbuf)); + } |