--- rxvt-unicode/src/rxvtimg.h 2012/06/03 18:14:13 1.6 +++ rxvt-unicode/src/rxvtimg.h 2012/06/07 07:53:12 1.17 @@ -1,46 +1,89 @@ #ifndef IMG_H #define IMG_H -#if defined HAVE_BG_PIXMAP && defined BG_IMAGE_FROM_FILE && defined ENABLE_TRANSPARENCY && defined HAVE_PIXBUF +#if HAVE_BG_PIXMAP && BG_IMAGE_FROM_FILE && ENABLE_TRANSPARENCY && HAVE_PIXBUF #define HAVE_IMG 1 #endif #if HAVE_IMG +#define float_to_component(d) ((d) * 65535.99) + #include -struct rxvt_img +class rxvt_img { + void alloc (); + void destroy (); + +public: rxvt_screen *s; Pixmap pm; - int w, h; + int *refcnt; // shared refcnt + int x, y, w, h, repeat; XRenderPictFormat *format; - bool shared; // true if we don't own it rxvt_img (rxvt_screen *screen, XRenderPictFormat *format, int width, int height); - rxvt_img (rxvt_screen *screen, XRenderPictFormat *format, int width, int height, Pixmap pixmap); + rxvt_img (const rxvt_img &img); + + //rxvt_img (rxvt_screen *screen, XRenderPictFormat *format, int width, int height, Pixmap pixmap); static rxvt_img *new_from_root (rxvt_screen *s); // get root pixmap static rxvt_img *new_from_file (rxvt_screen *s, const char *filename); // from pixbuf ~rxvt_img (); + // TODO: steal should not do what it does, and this todo should be more specific Pixmap steal () { - shared = true; - return pm; + Pixmap retval = pm; + pm = None; + return retval; } // inplace + void move (int dx, int dy) + { + x += dx; + y += dy; + } + + void repeat_mode (int repeat) + { + this->repeat = repeat; + } + + void unshare (); // prepare for write void fill (const rxvt_color &c); - void blur (int rh, int rv); - void brightness (double r, double g, double b, double a = 1.); - void contrast (double r, double g, double b, double a = 1.); - void render (GdkPixbuf *pixbuf, int src_x, int src_y, int width, int height, int dst_x, int dst_y); + void brightness (unsigned short r, unsigned short g, unsigned short b, unsigned short a); + void contrast (unsigned short r, unsigned short g, unsigned short b, unsigned short a); + + void brightness (double r, double g, double b, double a = 1.) + { + brightness (float_to_component (r), + float_to_component (g), + float_to_component (b), + float_to_component (a)); + } + + void contrast (double r, double g, double b, double a = 1.) + { + contrast (float_to_component (r), + float_to_component (g), + float_to_component (b), + float_to_component (a)); + } + + bool render_pixbuf (GdkPixbuf *pixbuf, int src_x, int src_y, int width, int height, int dst_x, int dst_y); // copy - rxvt_img *copy (); + rxvt_img *blur (int rh, int rv); + rxvt_img *clone (); + rxvt_img *sub_rect (int x, int y, int width, int height); + rxvt_img *transform (int new_width, int new_height, double matrix[9]); rxvt_img *scale (int new_width, int new_height); - rxvt_img *transform (int new_width, int new_height, double matrix[16]); + rxvt_img *rotate (int new_width, int new_height, int x, int y, double phi); + rxvt_img *convert_to (XRenderPictFormat *format, const rxvt_color &bg); + rxvt_img *blend (rxvt_img *img, double factor); }; #endif