--- rxvt-unicode/src/rxvtimg.h 2012/06/03 20:34:25 1.7 +++ rxvt-unicode/src/rxvtimg.h 2012/06/06 22:01:44 1.15 @@ -1,7 +1,7 @@ #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 @@ -13,7 +13,7 @@ { rxvt_screen *s; Pixmap pm; - int w, h; + int x, y, w, h, repeat; XRenderPictFormat *format; bool shared; // true if we don't own it @@ -31,17 +31,32 @@ } // inplace + void move (int dx, int dy) + { + x += dx; + y += dy; + } + + void repeat_mode (int repeat) + { + this->repeat = repeat; + } + + void unshare (); // create a copy of the pixmap if !shared 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); + 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 *convert_to (XRenderPictFormat *format); + 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