X-Git-Url: http://git.maemo.org/git/?p=simple-launcher;a=blobdiff_plain;f=launcher-item.cc;h=1b10593b58e78ddae5632e94efd1b5b7d84dbebc;hp=a72ff1ba750c9f349ea5182f1fe7a99d0f086c80;hb=17a1a1c0c49dd4a32c0598de869a92eff061f2d8;hpb=e967fac57db640e94f6cbf237f2d11ecf498f9a3 diff --git a/launcher-item.cc b/launcher-item.cc index a72ff1b..1b10593 100644 --- a/launcher-item.cc +++ b/launcher-item.cc @@ -18,6 +18,7 @@ #include #include +#include #include #include @@ -132,6 +133,29 @@ bool LauncherItem::load(const std::string& filename) { return (myEnabled = checkSanity()); } +// The function below is taken verbatim from exo library -- xfce supporting library +static GdkPixbuf *exo_gdk_pixbuf_scale_ratio(GdkPixbuf *source, gint dest_size) { + gdouble wratio, hratio; + gint source_width, source_height; + gint dest_width, dest_height; + + source_width = gdk_pixbuf_get_width(source); + source_height = gdk_pixbuf_get_height(source); + + wratio = (gdouble)source_width / (gdouble)dest_size; + hratio = (gdouble)source_height / (gdouble)dest_size; + + if (hratio > wratio) { + dest_width = (gint)rint(source_width / hratio); + dest_height = dest_size; + } else { + dest_width = dest_size; + dest_height = (gint)rint(source_height / wratio); + } + + return gdk_pixbuf_scale_simple(source, MAX(dest_width, 1), MAX(dest_height, 1), GDK_INTERP_BILINEAR); +} + GdkPixbuf *LauncherItem::getIcon(int icon_size) const { if (ourTheme == NULL) { ourTheme = gtk_icon_theme_get_default(); @@ -159,7 +183,13 @@ GdkPixbuf *LauncherItem::getIcon(int icon_size) const { } if (pixbuf != NULL) { - GdkPixbuf *tempo = gdk_pixbuf_copy(pixbuf); + GdkPixbuf *tempo; + + if (gdk_pixbuf_get_width(pixbuf) > icon_size || gdk_pixbuf_get_height(pixbuf) > icon_size) { + tempo = exo_gdk_pixbuf_scale_ratio(pixbuf, icon_size); + } else { + tempo = gdk_pixbuf_copy(pixbuf); + } g_object_unref(pixbuf);