--- rxvt-unicode/src/rxvtimg.h 2012/06/09 11:13:14 1.28 +++ rxvt-unicode/src/rxvtimg.h 2012/06/14 19:31:17 1.38 @@ -1,7 +1,7 @@ -#ifndef IMG_H +#ifndef IMG_H), #define IMG_H -#if HAVE_BG_PIXMAP && BG_IMAGE_FROM_FILE && ENABLE_TRANSPARENCY && HAVE_PIXBUF +#if HAVE_BG_PIXMAP #define HAVE_IMG 1 #endif @@ -13,11 +13,12 @@ class rxvt_img { - void alloc (); void destroy (); - Picture src_picture (); + Picture picture (); public: + typedef double nv; + // *could* also hold the Pixmap itself struct pixref { @@ -39,9 +40,12 @@ rxvt_img (rxvt_screen *screen, XRenderPictFormat *format, int x, int y, int width, int height, int repeat = RepeatNormal); rxvt_img (const rxvt_img &img); + void alloc (); +# if HAVE_PIXBUF static rxvt_img *new_from_pixbuf (rxvt_screen *s, GdkPixbuf *pb); // from pixbuf static rxvt_img *new_from_file (rxvt_screen *s, const char *filename); // via pixbuf +# endif static rxvt_img *new_from_root (rxvt_screen *s); // get root pixmap ~rxvt_img (); @@ -55,8 +59,8 @@ // inplace void move (int dx, int dy) { - x -= dx; - y -= dy; + x += dx; + y += dy; } void repeat_mode (int repeat) @@ -65,14 +69,15 @@ } void unshare (); // prepare for write - void fill (const rxvt_color &c); + void fill (const rgba &c); + void add_alpha (); //void linear_gradient (const XLinearGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops); //void radial_gradient (const XRadialGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops); //void conical_gradient (const XConicalGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops); void brightness (int32_t r, int32_t g, int32_t b, int32_t a); void contrast (int32_t r, int32_t g, int32_t b, int32_t a); - void brightness (double r, double g, double b, double a = 1.) + void brightness (nv r, nv g, nv b, nv a = 1.) { brightness (float_to_component (r), float_to_component (g), @@ -80,7 +85,7 @@ float_to_component (a)); } - void contrast (double r, double g, double b, double a = 1.) + void contrast (nv r, nv g, nv b, nv a = 1.) { contrast (float_to_component (r), float_to_component (g), @@ -88,16 +93,18 @@ float_to_component (a)); } + void draw (rxvt_img *img, int op = PictOpOver, nv mask = 1.); + // copy rxvt_img *reify (); // make x, y 0, make real width/height 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 *transform (nv matrix[3][3]); rxvt_img *scale (int new_width, int new_height); - rxvt_img *rotate (int new_width, int new_height, int x, int y, double phi); - rxvt_img *convert_format (XRenderPictFormat *format, const rxvt_color &bg); - rxvt_img *blend (rxvt_img *img, double factor); + rxvt_img *rotate (int cx, int cy, nv phi); + rxvt_img *convert_format (XRenderPictFormat *format, const rgba &bg); + rxvt_img *blend (rxvt_img *img, nv factor = 1.); // egregiuous helper category rxvt_img *replace (rxvt_img *&p)