aboutsummaryrefslogtreecommitdiffstats
path: root/widgets
diff options
context:
space:
mode:
Diffstat (limited to 'widgets')
-rw-r--r--widgets/table/e-cell-pixbuf.c251
-rw-r--r--widgets/table/e-cell-pixbuf.h38
2 files changed, 289 insertions, 0 deletions
diff --git a/widgets/table/e-cell-pixbuf.c b/widgets/table/e-cell-pixbuf.c
new file mode 100644
index 0000000000..3d0acd3a71
--- /dev/null
+++ b/widgets/table/e-cell-pixbuf.c
@@ -0,0 +1,251 @@
+/*
+ * e-cell-pixbuf.c: An ECell that displays a GdkPixbuf
+ *
+ * Copyright (C) 2001 Ximian, Inc.
+ *
+ * Authors: Vladimir Vukicevic <vladimir@ximian.com>
+ *
+ */
+
+#include <glib.h>
+#include <gtk/gtk.h>
+
+#include <stdio.h>
+
+#include <libgnomeui/libgnomeui.h>
+
+#include "e-cell-pixbuf.h"
+
+static ECellClass *parent_class;
+
+typedef struct _ECellPixbufView ECellPixbufView;
+
+struct _ECellPixbufView {
+ ECellView cell_view;
+ GdkGC *gc;
+ GnomeCanvas *canvas;
+};
+
+/*
+ * ECellPixbuf functions
+ */
+
+ECell *
+e_cell_pixbuf_new (void)
+{
+ ECellPixbuf *ecp;
+
+ ecp = gtk_type_new (E_CELL_PIXBUF_TYPE);
+ e_cell_pixbuf_construct (ecp);
+
+ return (ECell *) ecp;
+}
+
+void
+e_cell_pixbuf_construct (ECellPixbuf *ecp)
+{
+ /* noop */
+ return;
+}
+
+/*
+ * ECell methods
+ */
+
+static ECellView *
+pixbuf_new_view (ECell *ecell, ETableModel *table_model, void *e_table_item_view)
+{
+ ECellPixbufView *pixbuf_view = g_new0 (ECellPixbufView, 1);
+ ETableItem *eti = E_TABLE_ITEM (e_table_item_view);
+ GnomeCanvas *canvas = GNOME_CANVAS_ITEM (eti)->canvas;
+
+ pixbuf_view->cell_view.ecell = ecell;
+ pixbuf_view->cell_view.e_table_model = table_model;
+ pixbuf_view->cell_view.e_table_item_view = e_table_item_view;
+ pixbuf_view->canvas = canvas;
+
+ return (ECellView *) pixbuf_view;
+}
+
+static void
+pixbuf_kill_view (ECellView *ecell_view)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+
+ g_free (pixbuf_view);
+}
+
+static void
+pixbuf_realize (ECellView *ecell_view)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+
+ pixbuf_view->gc = gdk_gc_new (GTK_WIDGET (pixbuf_view->canvas)->window);
+}
+
+static void
+pixbuf_unrealize (ECellView *ecell_view)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+
+ gdk_gc_unref (pixbuf_view->gc);
+}
+
+static void
+pixbuf_draw (ECellView *ecell_view, GdkDrawable *drawable,
+ int model_col, int view_col, int row, ECellFlags flags,
+ int x1, int y1, int x2, int y2)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+ GdkPixbuf *cell_pixbuf;
+ int real_x, real_y, real_w, real_h;
+ int pix_w, pix_h;
+
+ cell_pixbuf = (GdkPixbuf *) e_table_model_value_at (ecell_view->e_table_model,
+ model_col, row);
+ /* we can't make sure we really got a pixbuf since, well, it's a Gdk thing */
+
+ if (x2 - x1 == 0)
+ return;
+
+ pix_w = gdk_pixbuf_get_width (cell_pixbuf);
+ pix_h = gdk_pixbuf_get_height (cell_pixbuf);
+
+ /* We center the pixbuf within our allocated space */
+ if (x2 - x1 > pix_w) {
+ int diff = (x2 - x1) - pix_w;
+ real_x = x1 + diff/2;
+ real_w = pix_w;
+ } else {
+ real_x = x1;
+ real_w = x2 - x1;
+ }
+
+ if (y2 - y1 > pix_h) {
+ int diff = (y2 - y1) - pix_h;
+ real_y = y1 + diff/2;
+ real_h = pix_h;
+ } else {
+ real_y = y1;
+ real_h = y2 - y1;
+ }
+
+
+ gdk_pixbuf_render_to_drawable (cell_pixbuf,
+ drawable,
+ pixbuf_view->gc,
+ 0, 0,
+ real_x, real_y,
+ real_w, real_h,
+ GDK_RGB_DITHER_NORMAL,
+ 0, 0);
+}
+
+static gint
+pixbuf_event (ECellView *ecell_view, GdkEvent *event,
+ int model_col, int view_col, int row,
+ ECellFlags flags, ECellActions *actions)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+
+ /* noop */
+
+ return FALSE;
+}
+
+static gint
+pixbuf_height (ECellView *ecell_view, int model_col, int view_col, int row)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+ GdkPixbuf *pixbuf;
+
+ pixbuf = (GdkPixbuf *) e_table_model_value_at (ecell_view->e_table_model, model_col, row);
+ if (!pixbuf) {
+ /* ??? */
+ g_warning ("e-cell-pixbuf: height with NULL pixbuf at %d %d %d\n", model_col, view_col, row);
+ return 0;
+ }
+
+ /* We give ourselves 3 pixels of padding on either side */
+ return gdk_pixbuf_get_height (pixbuf) + 6;
+}
+
+static gint
+pixbuf_max_width (ECellView *ecell_view, int model_col, int view_col)
+{
+ ECellPixbufView *pixbuf_view = (ECellPixbufView *) ecell_view;
+ gint num_rows, i;
+ gint max_width = -1;
+
+ if (model_col == 0) {
+ num_rows = e_table_model_row_count (ecell_view->e_table_model);
+
+ for (i = 0; i <= num_rows; i++) {
+ GdkPixbuf *pixbuf = (GdkPixbuf *) e_table_model_value_at
+ (ecell_view->e_table_model,
+ model_col,
+ i);
+ int pw = gdk_pixbuf_get_width (pixbuf);
+ if (max_width < pw)
+ max_width = pw;
+ }
+ } else {
+ return -1;
+ }
+
+ return max_width;
+}
+
+static void
+pixbuf_destroy (GtkObject *object)
+{
+ /* ... */
+}
+
+static void
+e_cell_pixbuf_init (GtkObject *object)
+{
+ /* ... */
+}
+
+static void
+e_cell_pixbuf_class_init (GtkObjectClass *object_class)
+{
+ ECellClass *ecc = (ECellClass *) object_class;
+
+ object_class->destroy = pixbuf_destroy;
+
+ ecc->new_view = pixbuf_new_view;
+ ecc->kill_view = pixbuf_kill_view;
+ ecc->realize = pixbuf_realize;
+ ecc->unrealize = pixbuf_unrealize;
+ ecc->draw = pixbuf_draw;
+ ecc->event = pixbuf_event;
+ ecc->height = pixbuf_height;
+ ecc->max_width = pixbuf_max_width;
+
+ parent_class = gtk_type_class (E_CELL_TYPE);
+}
+
+guint
+e_cell_pixbuf_get_type (void)
+{
+ static guint type = 0;
+
+ if (!type) {
+ GtkTypeInfo type_info = {
+ "ECellPixbuf",
+ sizeof (ECellPixbuf),
+ sizeof (ECellPixbufClass),
+ (GtkClassInitFunc) e_cell_pixbuf_class_init,
+ (GtkObjectInitFunc) e_cell_pixbuf_init,
+ (GtkArgSetFunc) NULL,
+ (GtkArgGetFunc) NULL,
+ };
+
+ type = gtk_type_unique (e_cell_get_type (), &type_info);
+ }
+
+ return type;
+}
+
diff --git a/widgets/table/e-cell-pixbuf.h b/widgets/table/e-cell-pixbuf.h
new file mode 100644
index 0000000000..b300f410ba
--- /dev/null
+++ b/widgets/table/e-cell-pixbuf.h
@@ -0,0 +1,38 @@
+/*
+ * e-cell-pixbuf.h: An ECell that displays a GdkPixbuf
+ *
+ * Copyright (C) 2001 Ximian, Inc.
+ *
+ * Authors: Vladimir Vukicevic <vladimir@ximian.com>
+ *
+ */
+
+#ifndef _E_CELL_PIXBUF_H_
+#define _E_CELL_PIXBUF_H_
+
+#include <glib.h>
+
+#include <gal/e-table/e-table.h>
+
+#define E_CELL_PIXBUF_TYPE (e_cell_pixbuf_get_type ())
+#define E_CELL_PIXBUF(o) (GTK_CHECK_CAST ((o), E_CELL_PIXBUF_TYPE, ECellPixbuf))
+#define E_CELL_PIXBUF_CLASS(k) (GTK_CHECK_CAST_CLASS ((k), E_CELL_PIXBUF_TYPE, ECellPixbufClass))
+#define E_IS_CELL_PIXBUF(o) (GTK_CHECK_TYPE ((o), E_CELL_PIXBUF_TYPE))
+#define E_IS_CELL_PIXBUF_CLASS(k) (GTK_CHECK_CLASS_TYPE ((k), E_CELL_PIXBUF_TYPE))
+
+typedef struct _ECellPixbuf ECellPixbuf;
+typedef struct _ECellPixbufClass ECellPixbufClass;
+
+struct _ECellPixbuf {
+ ECell parent;
+};
+
+struct _ECellPixbufClass {
+ ECellClass parent_class;
+};
+
+GtkType e_cell_pixbuf_get_type (void);
+ECell *e_cell_pixbuf_new (void);
+void e_cell_pixbuf_construct (ECellPixbuf *ecp);
+
+#endif