/* -*- c-file-style: "ruby"; indent-tabs-mode: nil -*- */ /* * Copyright (C) 2011 Ruby-GNOME2 Project Team * Copyright (C) 2002,2003 Ruby-GNOME2 Project Team * Copyright (C) 1998-2000 Yukihiro Matsumoto, * Daisuke Kanda, * Hiroshi Igarashi * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, * MA 02110-1301 USA */ #include "global.h" #define RG_TARGET_NAMESPACE mRGB #define RVAL2DRAW(s) GDK_DRAWABLE(RVAL2GOBJ(s)) static VALUE rg_m_draw_rgb_image(int argc, VALUE *argv, VALUE self) { VALUE win, gc, x, y, w, h, dither, buf, rowstride, xdith, ydith; rb_scan_args(argc, argv, "92", &win, &gc, &x, &y, &w, &h, &dither, &buf, &rowstride, &xdith, &ydith); if (argc == 9){ gdk_draw_rgb_image(RVAL2DRAW(win), GDK_GC(RVAL2GOBJ(gc)), NUM2INT(x), NUM2INT(y), NUM2INT(w), NUM2INT(h), RVAL2GENUM(dither, GDK_TYPE_RGB_DITHER), (guchar*)RVAL2CSTR(buf), NUM2INT(rowstride)); } else { gdk_draw_rgb_image_dithalign(RVAL2DRAW(win), GDK_GC(RVAL2GOBJ(gc)), NUM2INT(x), NUM2INT(y), NUM2INT(w), NUM2INT(h), RVAL2GENUM(dither, GDK_TYPE_RGB_DITHER), (guchar*)RVAL2CSTR(buf), NUM2INT(rowstride), NUM2INT(xdith), NUM2INT(ydith)); } return self; } static VALUE rg_m_draw_indexed_image(VALUE self, VALUE win, VALUE rbgc, VALUE rbx, VALUE rby, VALUE rbwidth, VALUE rbheight, VALUE rbdither, VALUE rbbuf, VALUE rbrowstride, VALUE rbcolors) { GdkDrawable *drawable = RVAL2DRAW(win); GdkGC *gc = GDK_GC(RVAL2GOBJ(rbgc)); gint x = NUM2INT(rbx); gint y = NUM2INT(rby); gint width = NUM2INT(rbwidth); gint height = NUM2INT(rbheight); GdkRgbDither dither = RVAL2GENUM(rbdither, GDK_TYPE_RGB_DITHER); const guchar *buf = (const guchar *)RVAL2CSTR(rbbuf); gint rowstride = NUM2INT(rbrowstride); long n; guint32 *colors = RVAL2GUINT32S(rbcolors, n); GdkRgbCmap *cmap; if (n < 0 || n > 255) { g_free(colors); rb_raise(rb_eArgError, "colors: out of range (0 - 255)"); } cmap = gdk_rgb_cmap_new(colors, n); g_free(colors); gdk_draw_indexed_image(drawable, gc, x, y, width, height, dither, buf, rowstride, cmap); gdk_rgb_cmap_free(cmap); return self; } static VALUE rg_m_draw_gray_image(VALUE self, VALUE win, VALUE gc, VALUE x, VALUE y, VALUE w, VALUE h, VALUE dither, VALUE buf, VALUE rowstride) { gdk_draw_gray_image(RVAL2DRAW(win), GDK_GC(RVAL2GOBJ(gc)), NUM2INT(x), NUM2INT(y), NUM2INT(w), NUM2INT(h), RVAL2GENUM(dither, GDK_TYPE_RGB_DITHER), (guchar*)RVAL2CSTR(buf), NUM2INT(rowstride)); return self; } static VALUE rg_m_draw_rgb_32_image(int argc, VALUE *argv, VALUE self) { VALUE win, gc, x, y, w, h, dither, buf, rowstride, xdith, ydith; rb_scan_args(argc, argv, "92", &win, &gc, &x, &y, &w, &h, &dither, &buf, &rowstride, &xdith, &ydith); if (argc == 9){ gdk_draw_rgb_32_image(RVAL2DRAW(win), GDK_GC(RVAL2GOBJ(gc)), NUM2INT(x), NUM2INT(y), NUM2INT(w), NUM2INT(h), RVAL2GENUM(dither, GDK_TYPE_RGB_DITHER), (guchar*)RVAL2CSTR(buf), NUM2INT(rowstride)); } else { gdk_draw_rgb_32_image_dithalign(RVAL2DRAW(win), GDK_GC(RVAL2GOBJ(gc)), NUM2INT(x), NUM2INT(y), NUM2INT(w), NUM2INT(h), RVAL2GENUM(dither, GDK_TYPE_RGB_DITHER), (guchar*)RVAL2CSTR(buf), NUM2INT(rowstride), NUM2INT(xdith), NUM2INT(ydith)); } return self; } static VALUE rg_m_find_color(VALUE self, VALUE colormap, VALUE color) { gdk_rgb_find_color(GDK_COLORMAP(RVAL2GOBJ(colormap)), RVAL2GDKCOLOR(color)); return self; } static VALUE rg_m_set_install(VALUE self, VALUE install) { gdk_rgb_set_install(RVAL2CBOOL(install)); return self; } static VALUE rg_m_set_min_colors(VALUE self, VALUE min_colors) { gdk_rgb_set_min_colors(NUM2INT(min_colors)); return self; } static VALUE rg_m_visual(G_GNUC_UNUSED VALUE self) { return GOBJ2RVAL(gdk_rgb_get_visual()); } static VALUE rg_m_colormap(G_GNUC_UNUSED VALUE self) { return GOBJ2RVAL(gdk_rgb_get_colormap()); } static VALUE rg_m_ditherable_p(G_GNUC_UNUSED VALUE self) { return CBOOL2RVAL(gdk_rgb_ditherable()); } static VALUE rg_m_set_verbose(VALUE self, VALUE verbose) { gdk_rgb_set_verbose(RVAL2CBOOL(verbose)); return self; } void Init_gtk_gdk_rgb(VALUE mGdk) { VALUE RG_TARGET_NAMESPACE = rb_define_module_under(mGdk, "RGB"); RG_DEF_MODFUNC(draw_rgb_image, -1); RG_DEF_MODFUNC(draw_indexed_image, 10); RG_DEF_MODFUNC(draw_gray_image, 9); RG_DEF_MODFUNC(draw_rgb_32_image, -1); RG_DEF_MODFUNC(find_color, 2); RG_DEF_MODFUNC(set_install, 1); RG_DEF_MODFUNC(set_min_colors, 0); RG_DEF_MODFUNC(visual, 0); RG_DEF_MODFUNC(colormap, 0); RG_DEF_MODFUNC_P(ditherable, 0); RG_DEF_MODFUNC(set_verbose, 1); /* GdkRgbDither */ G_DEF_CLASS(GDK_TYPE_RGB_DITHER, "Dither", RG_TARGET_NAMESPACE); G_DEF_CONSTANTS(RG_TARGET_NAMESPACE, GDK_TYPE_RGB_DITHER, "GDK_RGB_"); }