diff options
Diffstat (limited to 'widgets')
-rw-r--r-- | widgets/misc/e-gui-utils.c | 48 | ||||
-rw-r--r-- | widgets/misc/e-gui-utils.h | 1 |
2 files changed, 49 insertions, 0 deletions
diff --git a/widgets/misc/e-gui-utils.c b/widgets/misc/e-gui-utils.c index 9387d5015d..f7e2d946c6 100644 --- a/widgets/misc/e-gui-utils.c +++ b/widgets/misc/e-gui-utils.c @@ -11,7 +11,10 @@ #include <gtk/gtksignal.h> #include <libgnomeui/gnome-messagebox.h> #include <libgnomeui/gnome-stock.h> +#include <gnome.h> #include "e-gui-utils.h" +#include <gdk-pixbuf/gdk-pixbuf.h> +#include <gdk-pixbuf/gnome-canvas-pixbuf.h> void e_notice (GtkWindow *window, const char *type, const char *format, ...) @@ -61,4 +64,49 @@ e_popup_menu (GtkMenu *menu, GdkEventButton *event) gtk_menu_popup (menu, NULL, NULL, 0, NULL, event->button, event->time); } +GtkWidget *e_create_image_widget(gchar *name, + gchar *string1, gchar *string2, + gint int1, gint int2) +{ + char *filename; + GdkPixbuf *pixbuf; + double width, height; + GtkWidget *canvas, *alignment; + if (string1) { + if (*string1 == '/') + filename = g_strdup(string1); + else + filename = g_concat_dir_and_file(EVOLUTION_IMAGES, string1); + pixbuf = gdk_pixbuf_new_from_file(filename); + width = gdk_pixbuf_get_width(pixbuf); + height = gdk_pixbuf_get_height(pixbuf); + + canvas = gnome_canvas_new_aa(); + GTK_OBJECT_UNSET_FLAGS(GTK_WIDGET(canvas), GTK_CAN_FOCUS); + gnome_canvas_item_new(gnome_canvas_root(GNOME_CANVAS(canvas)), + gnome_canvas_pixbuf_get_type(), + + "pixbuf", pixbuf, + NULL); + + alignment = gtk_widget_new(gtk_alignment_get_type(), + "child", canvas, + "xalign", (double) 0, + "yalign", (double) 0, + "xscale", (double) 0, + "yscale", (double) 0, + NULL); + + gtk_widget_set_usize(canvas, width, height); + + gdk_pixbuf_unref(pixbuf); + + gtk_widget_show(canvas); + gtk_widget_show(alignment); + g_free(filename); + + return alignment; + } else + return NULL; +} diff --git a/widgets/misc/e-gui-utils.h b/widgets/misc/e-gui-utils.h index b5518f032b..7339821455 100644 --- a/widgets/misc/e-gui-utils.h +++ b/widgets/misc/e-gui-utils.h @@ -7,6 +7,7 @@ void e_popup_menu (GtkMenu *menu, GdkEventButton *event); void e_auto_kill_popup_menu_on_hide (GtkMenu *menu); void e_notice (GtkWindow *window, const char *type, const char *format, ...); +GtkWidget *e_create_image_widget(gchar *name, gchar *string1, gchar *string2, gint int1, gint int2); #endif /* E_GUI_UTILS_H */ |