ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvtimg.h
(Generate patch)

Comparing rxvt-unicode/src/rxvtimg.h (file contents):
Revision 1.32 by root, Tue Jun 12 18:25:57 2012 UTC vs.
Revision 1.51 by sf-exg, Sat Jul 15 08:16:31 2017 UTC

1/*----------------------------------------------------------------------*
2 * File: rxvtimg.h
3 *----------------------------------------------------------------------*
4 *
5 * All portions of code are copyright by their respective author/s.
6 * Copyright (c) 2012 Marc Lehmann <schmorp@schmorp.de>
7 * Copyright (c) 2012 Emanuele Giaquinta <e.giaquinta@glauco.it>
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 3 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 *---------------------------------------------------------------------*/
23
1#ifndef IMG_H 24#ifndef IMG_H
2#define IMG_H 25#define IMG_H
3
4#if HAVE_BG_PIXMAP
5 #define HAVE_IMG 1
6#endif
7 26
8#if HAVE_IMG 27#if HAVE_IMG
9 28
10#define float_to_component(d) (int32_t)((d) * 65535.99) 29#define float_to_component(d) (int32_t)((d) * 65535.99)
11 30
12#include <X11/extensions/Xrender.h> 31#include <X11/extensions/Xrender.h>
13 32
14class rxvt_img 33struct rxvt_img
15{ 34{
16 void destroy (); 35 typedef double nv;
17 Picture src_picture ();
18 36
19public:
20 // *could* also hold the Pixmap itself 37 // *could* also hold the Pixmap itself
21 struct pixref 38 struct pixref
22 { 39 {
23 int cnt; 40 int cnt;
24 int w, h; 41 int w, h;
28 : cnt(1), w(w), h(h), ours(true) 45 : cnt(1), w(w), h(h), ours(true)
29 { 46 {
30 } 47 }
31 }; 48 };
32 49
33 rxvt_screen *s; 50 rxvt_display *d;
34 Pixmap pm; 51 Pixmap pm;
35 pixref *ref; // shared refcnt 52 pixref *ref; // shared refcnt
36 int x, y, w, h, repeat; 53 int x, y, w, h, repeat;
37 XRenderPictFormat *format; 54 XRenderPictFormat *format;
38 55
39 rxvt_img (rxvt_screen *screen, XRenderPictFormat *format, int x, int y, int width, int height, int repeat = RepeatNormal); 56 rxvt_img (rxvt_screen *screen, XRenderPictFormat *format, int x, int y, int width, int height, int repeat = RepeatNormal);
57 rxvt_img (rxvt_display *display, XRenderPictFormat *format, int x, int y, int width, int height, int repeat = RepeatNormal);
40 rxvt_img (const rxvt_img &img); 58 rxvt_img (const rxvt_img &img);
41 void alloc (); 59 void alloc ();
42 60
43# if HAVE_PIXBUF 61# if HAVE_PIXBUF
44 static rxvt_img *new_from_pixbuf (rxvt_screen *s, GdkPixbuf *pb); // from pixbuf 62 static rxvt_img *new_from_pixbuf (rxvt_screen *s, GdkPixbuf *pb); // from pixbuf
55 } 73 }
56 74
57 // inplace 75 // inplace
58 void move (int dx, int dy) 76 void move (int dx, int dy)
59 { 77 {
60 x -= dx; 78 x += dx;
61 y -= dy; 79 y += dy;
62 } 80 }
63 81
64 void repeat_mode (int repeat) 82 void repeat_mode (int repeat)
65 { 83 {
66 this->repeat = repeat; 84 this->repeat = repeat;
67 } 85 }
68 86
69 void unshare (); // prepare for write 87 void unshare (); // prepare for write
70 void fill (const rxvt_color &c); 88 void fill (const rgba &c);
89 void fill (const rgba &c, int x, int y, int w, int h);
90 void add_alpha ();
71 //void linear_gradient (const XLinearGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops); 91 //void linear_gradient (const XLinearGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops);
72 //void radial_gradient (const XRadialGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops); 92 //void radial_gradient (const XRadialGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops);
73 //void conical_gradient (const XConicalGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops); 93 //void conical_gradient (const XConicalGradient *gradient, const XFixed *stops, const XRenderColor *colors, int nstops);
94
74 void brightness (int32_t r, int32_t g, int32_t b, int32_t a); 95 void brightness (int32_t r, int32_t g, int32_t b, int32_t a);
75 void contrast (int32_t r, int32_t g, int32_t b, int32_t a); 96 void contrast (int32_t r, int32_t g, int32_t b, int32_t a);
76 97
77 void brightness (double r, double g, double b, double a = 1.) 98 void brightness (nv r, nv g, nv b, nv a = 1.)
78 { 99 {
79 brightness (float_to_component (r), 100 brightness (float_to_component (r),
80 float_to_component (g), 101 float_to_component (g),
81 float_to_component (b), 102 float_to_component (b),
82 float_to_component (a)); 103 float_to_component (a));
83 } 104 }
84 105
85 void contrast (double r, double g, double b, double a = 1.) 106 void contrast (nv r, nv g, nv b, nv a = 1.)
86 { 107 {
87 contrast (float_to_component (r), 108 contrast (float_to_component (r),
88 float_to_component (g), 109 float_to_component (g),
89 float_to_component (b), 110 float_to_component (b),
90 float_to_component (a)); 111 float_to_component (a));
91 } 112 }
92 113
114 void draw (rxvt_img *img, int op = PictOpOver, nv mask = 1.);
115#if 0
116 void draw (rxvt_img *img, int op = PictOpOver, nv mask = 1.,
117 nv px, nv py, nv qx, nv qy, nv rx, nv ry, nv sx, nv sy);
118#endif
119
93 // copy 120 // copy
94 rxvt_img *reify (); // make x, y 0, make real width/height 121 rxvt_img *reify (); // make x, y 0, make real width/height
95 rxvt_img *blur (int rh, int rv); 122 rxvt_img *blur (int rh, int rv);
96 rxvt_img *clone (); 123 rxvt_img *clone ();
97 rxvt_img *sub_rect (int x, int y, int width, int height); 124 rxvt_img *sub_rect (int x, int y, int width, int height);
98 rxvt_img *transform (double matrix[3][3]); 125 rxvt_img *transform (const nv matrix[3][3]);
99 rxvt_img *scale (int new_width, int new_height); 126 rxvt_img *scale (int new_width, int new_height);
100 rxvt_img *rotate (int cx, int cy, double phi); 127 rxvt_img *rotate (int cx, int cy, nv phi);
101 rxvt_img *convert_format (XRenderPictFormat *format, const rxvt_color &bg); 128 rxvt_img *convert_format (XRenderPictFormat *format, const rgba &bg);
102 rxvt_img *blend (rxvt_img *img, double factor); 129 rxvt_img *tint (const rgba &c);
130 rxvt_img *shade (nv factor, rgba c = rgba (rgba::MAX_CC, rgba::MAX_CC, rgba::MAX_CC));
131 rxvt_img *filter (const char *name, int nparams = 0, nv *params = 0);
132 rxvt_img *muladd (nv mul, nv add); // general multiply and add, implemented as the biggest hack ever :/
103 133
104 // egregiuous helper category 134 // egregious helper category
105 rxvt_img *replace (rxvt_img *&p) 135 rxvt_img *replace (rxvt_img *&p)
106 { 136 {
107 delete p; 137 delete p;
108 p = this; 138 p = this;
109 return this; 139 return this;
110 } 140 }
141
142 /* these are considered private */
143 void destroy ();
144 rxvt_img *new_empty ();
145 Picture picture ();
146 rxvt_img *transform (const nv *matrix);
111}; 147};
112 148
113#endif 149#endif
114 150
115#endif 151#endif

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines