diff options
author | Iain Holmes <iain@src.gnome.org> | 2000-10-01 11:48:33 +0800 |
---|---|---|
committer | Iain Holmes <iain@src.gnome.org> | 2000-10-01 11:48:33 +0800 |
commit | f8b0f806eda3880363e28fa929c461e810bd3383 (patch) | |
tree | efeb843a9ce1b90ac679ae3f70f3dba8480745e1 /mail/mail-display.c | |
parent | 9d6c76ce37be81f83d3df0cf2bfc8d81adfa18e8 (diff) | |
download | gsoc2013-evolution-f8b0f806eda3880363e28fa929c461e810bd3383.tar.gz gsoc2013-evolution-f8b0f806eda3880363e28fa929c461e810bd3383.tar.zst gsoc2013-evolution-f8b0f806eda3880363e28fa929c461e810bd3383.zip |
Eye-candy, eye-candy.
Added attachment image thumbnailing to mail-display.c
svn path=/trunk/; revision=5649
Diffstat (limited to 'mail/mail-display.c')
-rw-r--r-- | mail/mail-display.c | 110 |
1 files changed, 100 insertions, 10 deletions
diff --git a/mail/mail-display.c b/mail/mail-display.c index bc864b0aca..20a9a1cd41 100644 --- a/mail/mail-display.c +++ b/mail/mail-display.c @@ -26,6 +26,10 @@ #include <libgnomevfs/gnome-vfs-mime-info.h> #include <libgnomevfs/gnome-vfs-mime-handlers.h> +#include <bonobo/bonobo-ui-toolbar-icon.h> +#include <gdk-pixbuf/gdk-pixbuf.h> +#include <gdk-pixbuf/gdk-pixbuf-loader.h> + #define PARENT_TYPE (gtk_vbox_get_type ()) static GtkObjectClass *mail_display_parent_class; @@ -355,17 +359,103 @@ on_object_requested (GtkHTML *html, GtkHTMLEmbedded *eb, gpointer data) const char *icon; GtkWidget *pixmap, *ebox; - icon = gnome_vfs_mime_get_value (eb->type, "icon-filename"); - if (icon) { - pixmap = gnome_pixmap_new_from_file_at_size (icon, - 24, 24); - } else { - char *filename; + if (strncmp (eb->type, "image", 5) == 0) { + CamelDataWrapper *iwrapper; + CamelStream *mstream; + GdkPixbufLoader *loader; + GdkPixbuf *pixbuf, *mini; + gboolean error; + char tmp[4096]; + int len; + + /* Get a pixbuf from the wrapper */ + + mstream = camel_stream_mem_new (); + iwrapper = camel_medium_get_content_object (medium); + camel_data_wrapper_write_to_stream (iwrapper, mstream); + camel_stream_reset (mstream); + + /* ...convert the CamelStreamMem to a GdkPixbuf... */ + loader = gdk_pixbuf_loader_new (); + + do { + len = camel_stream_read (mstream, tmp, 4096); + if (len > 0) { + error = !gdk_pixbuf_loader_write (loader, + tmp, + len); + if (error) + break; + } else { + if (camel_stream_eos (mstream)) + break; + error = TRUE; + break; + } + } while (!camel_stream_eos (mstream)); + + if (error) { + icon = gnome_vfs_mime_get_value (eb->type, "icon-filename"); + if (icon) { + pixmap = gnome_pixmap_new_from_file_at_size + (icon, 24, 24); + } else { + char *filename; + + + filename = gnome_pixmap_file ("gnome-unknown.png"); + pixmap = gnome_pixmap_new_from_file_at_size + (filename, 24, 24); + g_free (filename); + } + } else { + int width, height, ratio; + + pixbuf = gdk_pixbuf_loader_get_pixbuf (loader); + width = gdk_pixbuf_get_width (pixbuf); + height = gdk_pixbuf_get_height (pixbuf); + + if (width >= height) { + if (width > 24) { + ratio = width / 24; + width = 24; + height /= ratio; + } + } else { + if (height > 24) { + ratio = height / 24; + height = 24; + width /= ratio; + } + } - filename = gnome_pixmap_file ("gnome-unknown.png"); - pixmap = gnome_pixmap_new_from_file_at_size (filename, + mini = gdk_pixbuf_scale_simple (pixbuf, + width, height, + GDK_INTERP_BILINEAR); + /* Use this, because it is the gdk-pixbuf + version of gnome_pixmap. We need this + because Imlib is not threadsafe, and + it was causing all sorts of problems */ + pixmap = bonobo_ui_toolbar_icon_new_from_pixbuf (mini); + gdk_pixbuf_unref (mini); + } + + camel_object_unref (CAMEL_OBJECT (mstream)); + gdk_pixbuf_loader_close (loader); + gtk_object_destroy (GTK_OBJECT (loader)); + } else { + icon = gnome_vfs_mime_get_value (eb->type, "icon-filename"); + if (icon) { + pixmap = gnome_pixmap_new_from_file_at_size (icon, 24, 24); - g_free (filename); + } else { + char *filename; + + filename = gnome_pixmap_file ("gnome-unknown.png"); + pixmap = gnome_pixmap_new_from_file_at_size (filename, + 24, 24); + g_free (filename); + } } ebox = gtk_event_box_new (); @@ -418,7 +508,7 @@ on_object_requested (GtkHTML *html, GtkHTMLEmbedded *eb, gpointer data) ba = g_byte_array_new (); cstream = camel_stream_mem_new_with_byte_array (ba); wrapper = camel_medium_get_content_object (medium); - camel_data_wrapper_write_to_stream (wrapper, cstream); + camel_data_wrapper_write_to_stream (wrapper, cstream); /* ...convert the CamelStreamMem to a BonoboStreamMem... */ bstream = bonobo_stream_mem_create (ba->data, ba->len, TRUE, FALSE); |