diff options
-rw-r--r-- | e-util/ChangeLog | 7 | ||||
-rw-r--r-- | e-util/Makefile.am | 3 | ||||
-rw-r--r-- | e-util/e-gui-utils.c | 48 | ||||
-rw-r--r-- | e-util/e-gui-utils.h | 1 | ||||
-rw-r--r-- | widgets/misc/e-gui-utils.c | 48 | ||||
-rw-r--r-- | widgets/misc/e-gui-utils.h | 1 |
6 files changed, 108 insertions, 0 deletions
diff --git a/e-util/ChangeLog b/e-util/ChangeLog index 7f2d602f62..9fde2e70a9 100644 --- a/e-util/ChangeLog +++ b/e-util/ChangeLog @@ -1,3 +1,10 @@ +2000-05-18 Christopher James Lahey <clahey@helixcode.com> + + * Makefile.am: Add imagesdir support. + + * e-gui-utils.c, e-gui-utils.h: Added e_create_image_widget for + glade use. + 2000-05-16 Christopher James Lahey <clahey@helixcode.com> * e-xml-utils.c: xmlGetProp appears to return malloced memory. diff --git a/e-util/Makefile.am b/e-util/Makefile.am index 3445e4225a..b9e2ac1f3b 100644 --- a/e-util/Makefile.am +++ b/e-util/Makefile.am @@ -1,5 +1,8 @@ +imagesdir = $(datadir)/images/evolution + INCLUDES = \ $(GNOME_INCLUDEDIR) \ + -DEVOLUTION_IMAGES=\""$(imagesdir)"\" \ -DG_LOG_DOMAIN=\"e-utils\" noinst_LTLIBRARIES = libeutil.la diff --git a/e-util/e-gui-utils.c b/e-util/e-gui-utils.c index 9387d5015d..f7e2d946c6 100644 --- a/e-util/e-gui-utils.c +++ b/e-util/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/e-util/e-gui-utils.h b/e-util/e-gui-utils.h index b5518f032b..7339821455 100644 --- a/e-util/e-gui-utils.h +++ b/e-util/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 */ 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 */ |