From 3641c13fe260932ef11bc3c5dc915729fd0b6507 Mon Sep 17 00:00:00 2001 From: espen Date: Thu, 6 Nov 2008 17:27:39 +0000 Subject: [PATCH] New function clg_gdk_pixbuf_swap_rgb --- gdk/alien/glue.c | 28 +++++++++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) diff --git a/gdk/alien/glue.c b/gdk/alien/glue.c index b2be36c..cbe14ee 100644 --- a/gdk/alien/glue.c +++ b/gdk/alien/glue.c @@ -21,10 +21,11 @@ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ -/* $Id: glue.c,v 1.8 2007-09-07 07:38:22 espen Exp $ */ +/* $Id: glue.c,v 1.9 2008-11-06 17:27:39 espen Exp $ */ #include +#include #ifdef GDK_WINDOWING_X11 #include @@ -68,3 +69,28 @@ GdkWindow *clg_gdk_cairo_surface_get_window (cairo_surface_t *surface) return NULL; #endif } + +void clg_gdk_pixbuf_swap_rgb (GdkPixbuf *pixbuf) +{ + + int n_channels = gdk_pixbuf_get_n_channels (pixbuf); + guchar *p, *pixels = gdk_pixbuf_get_pixels (pixbuf); + int width = gdk_pixbuf_get_width (pixbuf); + int height = gdk_pixbuf_get_height (pixbuf); + int rowstride = gdk_pixbuf_get_rowstride (pixbuf); + int x, y; + + g_assert (gdk_pixbuf_get_bits_per_sample (pixbuf) == 8); + g_assert (gdk_pixbuf_get_has_alpha (pixbuf)); + g_assert (n_channels == 4); + + for (y = 0; y < height; y++) { + for (x = 0; x < width; x++) { + p = pixels + y * rowstride + x * n_channels; + guint tmp = p[0]; + p[0] = p[2]; + p[2] = tmp; + } + } +} + -- 2.11.0