diff options
author | Benjamin Otte <otte@redhat.com> | 2010-10-20 19:05:25 +0800 |
---|---|---|
committer | Matthew Barnes <mbarnes@redhat.com> | 2010-10-30 01:50:03 +0800 |
commit | ecee88725fa7099e258f44d29250dadf7c3bf2fe (patch) | |
tree | b496a31fea7c4c759d5475c50c5c5e6f8194d933 | |
parent | 861c878514348699ba66aa440e219e10ce393c9a (diff) | |
download | gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.tar gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.tar.gz gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.tar.bz2 gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.tar.lz gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.tar.xz gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.tar.zst gsoc2013-evolution-ecee88725fa7099e258f44d29250dadf7c3bf2fe.zip |
gnome-canvas: Port drawing to use cairo
-rw-r--r-- | libgnomecanvas/gnome-canvas.c | 40 | ||||
-rw-r--r-- | libgnomecanvas/gnome-canvas.h | 3 |
2 files changed, 14 insertions, 29 deletions
diff --git a/libgnomecanvas/gnome-canvas.c b/libgnomecanvas/gnome-canvas.c index 09acab0ce7..758a7ee728 100644 --- a/libgnomecanvas/gnome-canvas.c +++ b/libgnomecanvas/gnome-canvas.c @@ -2038,8 +2038,6 @@ gnome_canvas_realize (GtkWidget *widget) /* Create our own temporary pixmap gc and realize all the items */ - canvas->pixmap_gc = gdk_gc_new (bin_window); - (* GNOME_CANVAS_ITEM_GET_CLASS (canvas->root)->realize) (canvas->root); } @@ -2059,9 +2057,6 @@ gnome_canvas_unrealize (GtkWidget *widget) (* GNOME_CANVAS_ITEM_GET_CLASS (canvas->root)->unrealize) (canvas->root); - g_object_unref (canvas->pixmap_gc); - canvas->pixmap_gc = NULL; - if (GTK_WIDGET_CLASS (canvas_parent_class)->unrealize) (* GTK_WIDGET_CLASS (canvas_parent_class)->unrealize) (widget); } @@ -2687,8 +2682,7 @@ gnome_canvas_paint_rect (GnomeCanvas *canvas, gint x0, gint y0, gint x1, gint y1 gdouble hadjustment_value; gdouble vadjustment_value; GdkPixmap *pixmap; - GdkVisual *visual; - gint depth; + cairo_t *cr; g_return_if_fail (!canvas->need_update); @@ -2721,11 +2715,8 @@ gnome_canvas_paint_rect (GnomeCanvas *canvas, gint x0, gint y0, gint x1, gint y1 canvas->draw_xofs = draw_x1; canvas->draw_yofs = draw_y1; - visual = gtk_widget_get_visual (widget); - depth = gdk_visual_get_depth (visual); - pixmap = gdk_pixmap_new (bin_window, - draw_width, draw_height, depth); + draw_width, draw_height, -1); g_signal_emit (G_OBJECT (canvas), canvas_signals[DRAW_BACKGROUND], 0, pixmap, draw_x1, draw_y1, draw_width, draw_height); @@ -2737,15 +2728,14 @@ gnome_canvas_paint_rect (GnomeCanvas *canvas, gint x0, gint y0, gint x1, gint y1 draw_width, draw_height); /* Copy the pixmap to the window and clean up */ + cr = gdk_cairo_create (bin_window); - gdk_draw_drawable (bin_window, - canvas->pixmap_gc, - pixmap, - 0, 0, - draw_x1 + canvas->zoom_xofs, - draw_y1 + canvas->zoom_yofs, - draw_width, draw_height); + gdk_cairo_set_source_pixmap (cr, pixmap, + draw_x1 + canvas->zoom_xofs, + draw_y1 + canvas->zoom_yofs); + cairo_paint (cr); + cairo_destroy (cr); g_object_unref (pixmap); } @@ -2811,17 +2801,15 @@ gnome_canvas_draw_background (GnomeCanvas *canvas, GdkDrawable *drawable, gint x, gint y, gint width, gint height) { GtkStyle *style; + cairo_t *cr; style = gtk_widget_get_style (GTK_WIDGET (canvas)); + cr = gdk_cairo_create (drawable); + + gdk_cairo_set_source_color (cr, &style->bg[GTK_STATE_NORMAL]); + cairo_paint (cr); - /* By default, we use the style background. */ - gdk_gc_set_foreground (canvas->pixmap_gc, - &style->bg[GTK_STATE_NORMAL]); - gdk_draw_rectangle (drawable, - canvas->pixmap_gc, - TRUE, - 0, 0, - width, height); + cairo_destroy (cr); } static void diff --git a/libgnomecanvas/gnome-canvas.h b/libgnomecanvas/gnome-canvas.h index 7394ff2514..33fee2a00c 100644 --- a/libgnomecanvas/gnome-canvas.h +++ b/libgnomecanvas/gnome-canvas.h @@ -366,9 +366,6 @@ struct _GnomeCanvas { /* If non-NULL, the currently focused item */ GnomeCanvasItem *focused_item; - /* GC for temporary draw pixmap */ - GdkGC *pixmap_gc; - /* Event on which selection of current item is based */ GdkEvent pick_event; |