From b41787bc788d03aaf3dc3c734bc7e8161c1e713a Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Tue, 24 Sep 2013 16:37:37 +0200 Subject: [PATCH] gdkcairo: Don't require gtk_init() for set_source_pixbuf() Instead of using the default display's root window's surface, use the target surface of the passed in cairo_t to create the similar image from. https://bugzilla.gnome.org/show_bug.cgi?id=708547 --- gdk/gdkcairo.c | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/gdk/gdkcairo.c b/gdk/gdkcairo.c index d16a619ebd..ae0c294b70 100644 --- a/gdk/gdkcairo.c +++ b/gdk/gdkcairo.c @@ -321,9 +321,19 @@ gdk_cairo_set_source_pixbuf (cairo_t *cr, gdouble pixbuf_x, gdouble pixbuf_y) { + cairo_format_t format; cairo_surface_t *surface; - surface = gdk_cairo_surface_create_from_pixbuf (pixbuf, 1, NULL); + if (gdk_pixbuf_get_n_channels (pixbuf) == 3) + format = CAIRO_FORMAT_RGB24; + else + format = CAIRO_FORMAT_ARGB32; + + surface = cairo_surface_create_similar_image (cairo_get_target (cr), + format, + gdk_pixbuf_get_width (pixbuf), + gdk_pixbuf_get_height (pixbuf)); + cairo_set_source_surface (cr, surface, pixbuf_x, pixbuf_y); cairo_surface_destroy (surface); }