1 /***********************************************************
3 Copyright 1987, 1998 The Open Group
5 Permission to use, copy, modify, distribute, and sell this software and its
6 documentation for any purpose is hereby granted without fee, provided that
7 the above copyright notice appear in all copies and that both that
8 copyright notice and this permission notice appear in supporting
11 The above copyright notice and this permission notice shall be included in
12 all copies or substantial portions of the Software.
14 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
18 AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
19 CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21 Except as contained in this notice, the name of The Open Group shall not be
22 used in advertising or otherwise to promote the sale, use or other dealings
23 in this Software without prior written authorization from The Open Group.
25 Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
29 Permission to use, copy, modify, and distribute this software and its
30 documentation for any purpose and without fee is hereby granted,
31 provided that the above copyright notice appear in all copies and that
32 both that copyright notice and this permission notice appear in
33 supporting documentation, and that the name of Digital not be
34 used in advertising or publicity pertaining to distribution of the
35 software without specific, written prior permission.
37 DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
38 ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
39 DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
40 ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
41 WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
42 ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
45 ******************************************************************/
47 * Copyright © 1998, 2004 Keith Packard
48 * Copyright 2007 Red Hat, Inc.
50 * Permission to use, copy, modify, distribute, and sell this software and its
51 * documentation for any purpose is hereby granted without fee, provided that
52 * the above copyright notice appear in all copies and that both that
53 * copyright notice and this permission notice appear in supporting
54 * documentation, and that the name of Keith Packard not be used in
55 * advertising or publicity pertaining to distribution of the software without
56 * specific, written prior permission. Keith Packard makes no
57 * representations about the suitability of this software for any purpose. It
58 * is provided "as is" without express or implied warranty.
60 * KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
61 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
62 * EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR
63 * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
64 * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
65 * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
66 * PERFORMANCE OF THIS SOFTWARE.
72 #include <pixman-version.h>
75 #define PIXMAN_BEGIN_DECLS extern "C" {
76 #define PIXMAN_END_DECLS }
78 #define PIXMAN_BEGIN_DECLS
79 #define PIXMAN_END_DECLS
88 #if !defined (PIXMAN_DONT_DEFINE_STDINT)
90 #if defined (_SVR4) || defined (SVR4) || defined (__OpenBSD__) || defined (_sgi) || defined (__sun) || defined (sun) || defined (__digital__) || defined (__HP_cc)
91 # include <inttypes.h>
92 /* VS 2010 (_MSC_VER 1600) has stdint.h */
93 #elif defined (_MSC_VER) && _MSC_VER < 1600
94 typedef __int8 int8_t;
95 typedef unsigned __int8 uint8_t;
96 typedef __int16 int16_t;
97 typedef unsigned __int16 uint16_t;
98 typedef __int32 int32_t;
99 typedef unsigned __int32 uint32_t;
100 typedef __int64 int64_t;
101 typedef unsigned __int64 uint64_t;
103 # include <sys/inttypes.h>
113 typedef int pixman_bool_t;
118 typedef int64_t pixman_fixed_32_32_t;
119 typedef pixman_fixed_32_32_t pixman_fixed_48_16_t;
120 typedef uint32_t pixman_fixed_1_31_t;
121 typedef uint32_t pixman_fixed_1_16_t;
122 typedef int32_t pixman_fixed_16_16_t;
123 typedef pixman_fixed_16_16_t pixman_fixed_t;
125 #define pixman_fixed_e ((pixman_fixed_t) 1)
126 #define pixman_fixed_1 (pixman_int_to_fixed(1))
127 #define pixman_fixed_1_minus_e (pixman_fixed_1 - pixman_fixed_e)
128 #define pixman_fixed_minus_1 (pixman_int_to_fixed(-1))
129 #define pixman_fixed_to_int(f) ((int) ((f) >> 16))
130 #define pixman_int_to_fixed(i) ((pixman_fixed_t) ((i) << 16))
131 #define pixman_fixed_to_double(f) (double) ((f) / (double) pixman_fixed_1)
132 #define pixman_double_to_fixed(d) ((pixman_fixed_t) ((d) * 65536.0))
133 #define pixman_fixed_frac(f) ((f) & pixman_fixed_1_minus_e)
134 #define pixman_fixed_floor(f) ((f) & ~pixman_fixed_1_minus_e)
135 #define pixman_fixed_ceil(f) pixman_fixed_floor ((f) + pixman_fixed_1_minus_e)
136 #define pixman_fixed_fraction(f) ((f) & pixman_fixed_1_minus_e)
137 #define pixman_fixed_mod_2(f) ((f) & (pixman_fixed1 | pixman_fixed_1_minus_e))
138 #define pixman_max_fixed_48_16 ((pixman_fixed_48_16_t) 0x7fffffff)
139 #define pixman_min_fixed_48_16 (-((pixman_fixed_48_16_t) 1 << 31))
144 typedef struct pixman_color pixman_color_t;
145 typedef struct pixman_point_fixed pixman_point_fixed_t;
146 typedef struct pixman_line_fixed pixman_line_fixed_t;
147 typedef struct pixman_vector pixman_vector_t;
148 typedef struct pixman_transform pixman_transform_t;
158 struct pixman_point_fixed
164 struct pixman_line_fixed
166 pixman_point_fixed_t p1, p2;
170 * Fixed point matrices
175 pixman_fixed_t vector[3];
178 struct pixman_transform
180 pixman_fixed_t matrix[3][3];
183 /* forward declaration (sorry) */
185 typedef union pixman_image pixman_image_t;
187 void pixman_transform_init_identity (struct pixman_transform *matrix);
188 pixman_bool_t pixman_transform_point_3d (const struct pixman_transform *transform,
189 struct pixman_vector *vector);
190 pixman_bool_t pixman_transform_point (const struct pixman_transform *transform,
191 struct pixman_vector *vector);
192 pixman_bool_t pixman_transform_multiply (struct pixman_transform *dst,
193 const struct pixman_transform *l,
194 const struct pixman_transform *r);
195 void pixman_transform_init_scale (struct pixman_transform *t,
198 pixman_bool_t pixman_transform_scale (struct pixman_transform *forward,
199 struct pixman_transform *reverse,
202 void pixman_transform_init_rotate (struct pixman_transform *t,
205 pixman_bool_t pixman_transform_rotate (struct pixman_transform *forward,
206 struct pixman_transform *reverse,
209 void pixman_transform_init_translate (struct pixman_transform *t,
212 pixman_bool_t pixman_transform_translate (struct pixman_transform *forward,
213 struct pixman_transform *reverse,
216 pixman_bool_t pixman_transform_bounds (const struct pixman_transform *matrix,
217 struct pixman_box16 *b);
218 pixman_bool_t pixman_transform_invert (struct pixman_transform *dst,
219 const struct pixman_transform *src);
220 pixman_bool_t pixman_transform_is_identity (const struct pixman_transform *t);
221 pixman_bool_t pixman_transform_is_scale (const struct pixman_transform *t);
222 pixman_bool_t pixman_transform_is_int_translate (const struct pixman_transform *t);
223 pixman_bool_t pixman_transform_is_inverse (const struct pixman_transform *a,
224 const struct pixman_transform *b);
227 * Floating point matrices
229 struct pixman_f_vector
234 struct pixman_f_transform
239 pixman_bool_t pixman_transform_from_pixman_f_transform (struct pixman_transform *t,
240 const struct pixman_f_transform *ft);
241 void pixman_f_transform_from_pixman_transform (struct pixman_f_transform *ft,
242 const struct pixman_transform *t);
243 pixman_bool_t pixman_f_transform_invert (struct pixman_f_transform *dst,
244 const struct pixman_f_transform *src);
245 pixman_bool_t pixman_f_transform_point (const struct pixman_f_transform *t,
246 struct pixman_f_vector *v);
247 void pixman_f_transform_point_3d (const struct pixman_f_transform *t,
248 struct pixman_f_vector *v);
249 void pixman_f_transform_multiply (struct pixman_f_transform *dst,
250 const struct pixman_f_transform *l,
251 const struct pixman_f_transform *r);
252 void pixman_f_transform_init_scale (struct pixman_f_transform *t,
255 pixman_bool_t pixman_f_transform_scale (struct pixman_f_transform *forward,
256 struct pixman_f_transform *reverse,
259 void pixman_f_transform_init_rotate (struct pixman_f_transform *t,
262 pixman_bool_t pixman_f_transform_rotate (struct pixman_f_transform *forward,
263 struct pixman_f_transform *reverse,
266 void pixman_f_transform_init_translate (struct pixman_f_transform *t,
269 pixman_bool_t pixman_f_transform_translate (struct pixman_f_transform *forward,
270 struct pixman_f_transform *reverse,
273 pixman_bool_t pixman_f_transform_bounds (const struct pixman_f_transform *t,
274 struct pixman_box16 *b);
275 void pixman_f_transform_init_identity (struct pixman_f_transform *t);
280 PIXMAN_REPEAT_NORMAL,
282 PIXMAN_REPEAT_REFLECT
290 PIXMAN_FILTER_NEAREST,
291 PIXMAN_FILTER_BILINEAR,
292 PIXMAN_FILTER_CONVOLUTION
297 PIXMAN_OP_CLEAR = 0x00,
298 PIXMAN_OP_SRC = 0x01,
299 PIXMAN_OP_DST = 0x02,
300 PIXMAN_OP_OVER = 0x03,
301 PIXMAN_OP_OVER_REVERSE = 0x04,
303 PIXMAN_OP_IN_REVERSE = 0x06,
304 PIXMAN_OP_OUT = 0x07,
305 PIXMAN_OP_OUT_REVERSE = 0x08,
306 PIXMAN_OP_ATOP = 0x09,
307 PIXMAN_OP_ATOP_REVERSE = 0x0a,
308 PIXMAN_OP_XOR = 0x0b,
309 PIXMAN_OP_ADD = 0x0c,
310 PIXMAN_OP_SATURATE = 0x0d,
312 PIXMAN_OP_DISJOINT_CLEAR = 0x10,
313 PIXMAN_OP_DISJOINT_SRC = 0x11,
314 PIXMAN_OP_DISJOINT_DST = 0x12,
315 PIXMAN_OP_DISJOINT_OVER = 0x13,
316 PIXMAN_OP_DISJOINT_OVER_REVERSE = 0x14,
317 PIXMAN_OP_DISJOINT_IN = 0x15,
318 PIXMAN_OP_DISJOINT_IN_REVERSE = 0x16,
319 PIXMAN_OP_DISJOINT_OUT = 0x17,
320 PIXMAN_OP_DISJOINT_OUT_REVERSE = 0x18,
321 PIXMAN_OP_DISJOINT_ATOP = 0x19,
322 PIXMAN_OP_DISJOINT_ATOP_REVERSE = 0x1a,
323 PIXMAN_OP_DISJOINT_XOR = 0x1b,
325 PIXMAN_OP_CONJOINT_CLEAR = 0x20,
326 PIXMAN_OP_CONJOINT_SRC = 0x21,
327 PIXMAN_OP_CONJOINT_DST = 0x22,
328 PIXMAN_OP_CONJOINT_OVER = 0x23,
329 PIXMAN_OP_CONJOINT_OVER_REVERSE = 0x24,
330 PIXMAN_OP_CONJOINT_IN = 0x25,
331 PIXMAN_OP_CONJOINT_IN_REVERSE = 0x26,
332 PIXMAN_OP_CONJOINT_OUT = 0x27,
333 PIXMAN_OP_CONJOINT_OUT_REVERSE = 0x28,
334 PIXMAN_OP_CONJOINT_ATOP = 0x29,
335 PIXMAN_OP_CONJOINT_ATOP_REVERSE = 0x2a,
336 PIXMAN_OP_CONJOINT_XOR = 0x2b,
338 PIXMAN_OP_MULTIPLY = 0x30,
339 PIXMAN_OP_SCREEN = 0x31,
340 PIXMAN_OP_OVERLAY = 0x32,
341 PIXMAN_OP_DARKEN = 0x33,
342 PIXMAN_OP_LIGHTEN = 0x34,
343 PIXMAN_OP_COLOR_DODGE = 0x35,
344 PIXMAN_OP_COLOR_BURN = 0x36,
345 PIXMAN_OP_HARD_LIGHT = 0x37,
346 PIXMAN_OP_SOFT_LIGHT = 0x38,
347 PIXMAN_OP_DIFFERENCE = 0x39,
348 PIXMAN_OP_EXCLUSION = 0x3a,
349 PIXMAN_OP_HSL_HUE = 0x3b,
350 PIXMAN_OP_HSL_SATURATION = 0x3c,
351 PIXMAN_OP_HSL_COLOR = 0x3d,
352 PIXMAN_OP_HSL_LUMINOSITY = 0x3e
354 #ifdef PIXMAN_USE_INTERNAL_API
357 PIXMAN_OP_NONE = PIXMAN_N_OPERATORS
364 typedef struct pixman_region16_data pixman_region16_data_t;
365 typedef struct pixman_box16 pixman_box16_t;
366 typedef struct pixman_rectangle16 pixman_rectangle16_t;
367 typedef struct pixman_region16 pixman_region16_t;
369 struct pixman_region16_data {
372 /* pixman_box16_t rects[size]; in memory but not explicitly declared */
375 struct pixman_rectangle16
378 uint16_t width, height;
383 int16_t x1, y1, x2, y2;
386 struct pixman_region16
388 pixman_box16_t extents;
389 pixman_region16_data_t *data;
397 } pixman_region_overlap_t;
399 /* This function exists only to make it possible to preserve
400 * the X ABI - it should go away at first opportunity.
402 void pixman_region_set_static_pointers (pixman_box16_t *empty_box,
403 pixman_region16_data_t *empty_data,
404 pixman_region16_data_t *broken_data);
406 /* creation/destruction */
407 void pixman_region_init (pixman_region16_t *region);
408 void pixman_region_init_rect (pixman_region16_t *region,
412 unsigned int height);
413 pixman_bool_t pixman_region_init_rects (pixman_region16_t *region,
414 const pixman_box16_t *boxes,
416 void pixman_region_init_with_extents (pixman_region16_t *region,
417 pixman_box16_t *extents);
418 void pixman_region_init_from_image (pixman_region16_t *region,
419 pixman_image_t *image);
420 void pixman_region_fini (pixman_region16_t *region);
424 void pixman_region_translate (pixman_region16_t *region,
427 pixman_bool_t pixman_region_copy (pixman_region16_t *dest,
428 pixman_region16_t *source);
429 pixman_bool_t pixman_region_intersect (pixman_region16_t *new_reg,
430 pixman_region16_t *reg1,
431 pixman_region16_t *reg2);
432 pixman_bool_t pixman_region_union (pixman_region16_t *new_reg,
433 pixman_region16_t *reg1,
434 pixman_region16_t *reg2);
435 pixman_bool_t pixman_region_union_rect (pixman_region16_t *dest,
436 pixman_region16_t *source,
440 unsigned int height);
441 pixman_bool_t pixman_region_intersect_rect (pixman_region16_t *dest,
442 pixman_region16_t *source,
446 unsigned int height);
447 pixman_bool_t pixman_region_subtract (pixman_region16_t *reg_d,
448 pixman_region16_t *reg_m,
449 pixman_region16_t *reg_s);
450 pixman_bool_t pixman_region_inverse (pixman_region16_t *new_reg,
451 pixman_region16_t *reg1,
452 pixman_box16_t *inv_rect);
453 pixman_bool_t pixman_region_contains_point (pixman_region16_t *region,
456 pixman_box16_t *box);
457 pixman_region_overlap_t pixman_region_contains_rectangle (pixman_region16_t *region,
458 pixman_box16_t *prect);
459 pixman_bool_t pixman_region_not_empty (pixman_region16_t *region);
460 pixman_box16_t * pixman_region_extents (pixman_region16_t *region);
461 int pixman_region_n_rects (pixman_region16_t *region);
462 pixman_box16_t * pixman_region_rectangles (pixman_region16_t *region,
464 pixman_bool_t pixman_region_equal (pixman_region16_t *region1,
465 pixman_region16_t *region2);
466 pixman_bool_t pixman_region_selfcheck (pixman_region16_t *region);
467 void pixman_region_reset (pixman_region16_t *region,
468 pixman_box16_t *box);
472 typedef struct pixman_region32_data pixman_region32_data_t;
473 typedef struct pixman_box32 pixman_box32_t;
474 typedef struct pixman_rectangle32 pixman_rectangle32_t;
475 typedef struct pixman_region32 pixman_region32_t;
477 struct pixman_region32_data {
480 /* pixman_box32_t rects[size]; in memory but not explicitly declared */
483 struct pixman_rectangle32
486 uint32_t width, height;
491 int32_t x1, y1, x2, y2;
494 struct pixman_region32
496 pixman_box32_t extents;
497 pixman_region32_data_t *data;
500 /* creation/destruction */
501 void pixman_region32_init (pixman_region32_t *region);
502 void pixman_region32_init_rect (pixman_region32_t *region,
506 unsigned int height);
507 pixman_bool_t pixman_region32_init_rects (pixman_region32_t *region,
508 const pixman_box32_t *boxes,
510 void pixman_region32_init_with_extents (pixman_region32_t *region,
511 pixman_box32_t *extents);
512 void pixman_region32_init_from_image (pixman_region32_t *region,
513 pixman_image_t *image);
514 void pixman_region32_fini (pixman_region32_t *region);
518 void pixman_region32_translate (pixman_region32_t *region,
521 pixman_bool_t pixman_region32_copy (pixman_region32_t *dest,
522 pixman_region32_t *source);
523 pixman_bool_t pixman_region32_intersect (pixman_region32_t *new_reg,
524 pixman_region32_t *reg1,
525 pixman_region32_t *reg2);
526 pixman_bool_t pixman_region32_union (pixman_region32_t *new_reg,
527 pixman_region32_t *reg1,
528 pixman_region32_t *reg2);
529 pixman_bool_t pixman_region32_intersect_rect (pixman_region32_t *dest,
530 pixman_region32_t *source,
534 unsigned int height);
535 pixman_bool_t pixman_region32_union_rect (pixman_region32_t *dest,
536 pixman_region32_t *source,
540 unsigned int height);
541 pixman_bool_t pixman_region32_subtract (pixman_region32_t *reg_d,
542 pixman_region32_t *reg_m,
543 pixman_region32_t *reg_s);
544 pixman_bool_t pixman_region32_inverse (pixman_region32_t *new_reg,
545 pixman_region32_t *reg1,
546 pixman_box32_t *inv_rect);
547 pixman_bool_t pixman_region32_contains_point (pixman_region32_t *region,
550 pixman_box32_t *box);
551 pixman_region_overlap_t pixman_region32_contains_rectangle (pixman_region32_t *region,
552 pixman_box32_t *prect);
553 pixman_bool_t pixman_region32_not_empty (pixman_region32_t *region);
554 pixman_box32_t * pixman_region32_extents (pixman_region32_t *region);
555 int pixman_region32_n_rects (pixman_region32_t *region);
556 pixman_box32_t * pixman_region32_rectangles (pixman_region32_t *region,
558 pixman_bool_t pixman_region32_equal (pixman_region32_t *region1,
559 pixman_region32_t *region2);
560 pixman_bool_t pixman_region32_selfcheck (pixman_region32_t *region);
561 void pixman_region32_reset (pixman_region32_t *region,
562 pixman_box32_t *box);
565 /* Copy / Fill / Misc */
566 pixman_bool_t pixman_blt (uint32_t *src_bits,
578 pixman_bool_t pixman_fill (uint32_t *bits,
587 int pixman_version (void);
588 const char* pixman_version_string (void);
593 typedef struct pixman_indexed pixman_indexed_t;
594 typedef struct pixman_gradient_stop pixman_gradient_stop_t;
596 typedef uint32_t (* pixman_read_memory_func_t) (const void *src, int size);
597 typedef void (* pixman_write_memory_func_t) (void *dst, uint32_t value, int size);
599 typedef void (* pixman_image_destroy_func_t) (pixman_image_t *image, void *data);
601 struct pixman_gradient_stop {
603 pixman_color_t color;
606 #define PIXMAN_MAX_INDEXED 256 /* XXX depth must be <= 8 */
608 #if PIXMAN_MAX_INDEXED <= 256
609 typedef uint8_t pixman_index_type;
612 struct pixman_indexed
615 uint32_t rgba[PIXMAN_MAX_INDEXED];
616 pixman_index_type ent[32768];
620 * While the protocol is generous in format support, the
621 * sample implementation allows only packed RGB and GBR
622 * representations for data to simplify software rendering,
624 #define PIXMAN_FORMAT(bpp,type,a,r,g,b) (((bpp) << 24) | \
631 #define PIXMAN_FORMAT_BPP(f) (((f) >> 24) )
632 #define PIXMAN_FORMAT_TYPE(f) (((f) >> 16) & 0xff)
633 #define PIXMAN_FORMAT_A(f) (((f) >> 12) & 0x0f)
634 #define PIXMAN_FORMAT_R(f) (((f) >> 8) & 0x0f)
635 #define PIXMAN_FORMAT_G(f) (((f) >> 4) & 0x0f)
636 #define PIXMAN_FORMAT_B(f) (((f) ) & 0x0f)
637 #define PIXMAN_FORMAT_RGB(f) (((f) ) & 0xfff)
638 #define PIXMAN_FORMAT_VIS(f) (((f) ) & 0xffff)
639 #define PIXMAN_FORMAT_DEPTH(f) (PIXMAN_FORMAT_A(f) + \
640 PIXMAN_FORMAT_R(f) + \
641 PIXMAN_FORMAT_G(f) + \
644 #define PIXMAN_TYPE_OTHER 0
645 #define PIXMAN_TYPE_A 1
646 #define PIXMAN_TYPE_ARGB 2
647 #define PIXMAN_TYPE_ABGR 3
648 #define PIXMAN_TYPE_COLOR 4
649 #define PIXMAN_TYPE_GRAY 5
650 #define PIXMAN_TYPE_YUY2 6
651 #define PIXMAN_TYPE_YV12 7
652 #define PIXMAN_TYPE_BGRA 8
654 #define PIXMAN_FORMAT_COLOR(f) \
655 (PIXMAN_FORMAT_TYPE(f) == PIXMAN_TYPE_ARGB || \
656 PIXMAN_FORMAT_TYPE(f) == PIXMAN_TYPE_ABGR || \
657 PIXMAN_FORMAT_TYPE(f) == PIXMAN_TYPE_BGRA)
661 PIXMAN_a8r8g8b8 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ARGB,8,8,8,8),
662 PIXMAN_x8r8g8b8 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ARGB,0,8,8,8),
663 PIXMAN_a8b8g8r8 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ABGR,8,8,8,8),
664 PIXMAN_x8b8g8r8 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ABGR,0,8,8,8),
665 PIXMAN_b8g8r8a8 = PIXMAN_FORMAT(32,PIXMAN_TYPE_BGRA,8,8,8,8),
666 PIXMAN_b8g8r8x8 = PIXMAN_FORMAT(32,PIXMAN_TYPE_BGRA,0,8,8,8),
667 PIXMAN_x2r10g10b10 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ARGB,0,10,10,10),
668 PIXMAN_a2r10g10b10 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ARGB,2,10,10,10),
669 PIXMAN_x2b10g10r10 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ABGR,0,10,10,10),
670 PIXMAN_a2b10g10r10 = PIXMAN_FORMAT(32,PIXMAN_TYPE_ABGR,2,10,10,10),
673 PIXMAN_r8g8b8 = PIXMAN_FORMAT(24,PIXMAN_TYPE_ARGB,0,8,8,8),
674 PIXMAN_b8g8r8 = PIXMAN_FORMAT(24,PIXMAN_TYPE_ABGR,0,8,8,8),
677 PIXMAN_r5g6b5 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ARGB,0,5,6,5),
678 PIXMAN_b5g6r5 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ABGR,0,5,6,5),
680 PIXMAN_a1r5g5b5 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ARGB,1,5,5,5),
681 PIXMAN_x1r5g5b5 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ARGB,0,5,5,5),
682 PIXMAN_a1b5g5r5 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ABGR,1,5,5,5),
683 PIXMAN_x1b5g5r5 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ABGR,0,5,5,5),
684 PIXMAN_a4r4g4b4 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ARGB,4,4,4,4),
685 PIXMAN_x4r4g4b4 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ARGB,0,4,4,4),
686 PIXMAN_a4b4g4r4 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ABGR,4,4,4,4),
687 PIXMAN_x4b4g4r4 = PIXMAN_FORMAT(16,PIXMAN_TYPE_ABGR,0,4,4,4),
690 PIXMAN_a8 = PIXMAN_FORMAT(8,PIXMAN_TYPE_A,8,0,0,0),
691 PIXMAN_r3g3b2 = PIXMAN_FORMAT(8,PIXMAN_TYPE_ARGB,0,3,3,2),
692 PIXMAN_b2g3r3 = PIXMAN_FORMAT(8,PIXMAN_TYPE_ABGR,0,3,3,2),
693 PIXMAN_a2r2g2b2 = PIXMAN_FORMAT(8,PIXMAN_TYPE_ARGB,2,2,2,2),
694 PIXMAN_a2b2g2r2 = PIXMAN_FORMAT(8,PIXMAN_TYPE_ABGR,2,2,2,2),
696 PIXMAN_c8 = PIXMAN_FORMAT(8,PIXMAN_TYPE_COLOR,0,0,0,0),
697 PIXMAN_g8 = PIXMAN_FORMAT(8,PIXMAN_TYPE_GRAY,0,0,0,0),
699 PIXMAN_x4a4 = PIXMAN_FORMAT(8,PIXMAN_TYPE_A,4,0,0,0),
701 PIXMAN_x4c4 = PIXMAN_FORMAT(8,PIXMAN_TYPE_COLOR,0,0,0,0),
702 PIXMAN_x4g4 = PIXMAN_FORMAT(8,PIXMAN_TYPE_GRAY,0,0,0,0),
705 PIXMAN_a4 = PIXMAN_FORMAT(4,PIXMAN_TYPE_A,4,0,0,0),
706 PIXMAN_r1g2b1 = PIXMAN_FORMAT(4,PIXMAN_TYPE_ARGB,0,1,2,1),
707 PIXMAN_b1g2r1 = PIXMAN_FORMAT(4,PIXMAN_TYPE_ABGR,0,1,2,1),
708 PIXMAN_a1r1g1b1 = PIXMAN_FORMAT(4,PIXMAN_TYPE_ARGB,1,1,1,1),
709 PIXMAN_a1b1g1r1 = PIXMAN_FORMAT(4,PIXMAN_TYPE_ABGR,1,1,1,1),
711 PIXMAN_c4 = PIXMAN_FORMAT(4,PIXMAN_TYPE_COLOR,0,0,0,0),
712 PIXMAN_g4 = PIXMAN_FORMAT(4,PIXMAN_TYPE_GRAY,0,0,0,0),
715 PIXMAN_a1 = PIXMAN_FORMAT(1,PIXMAN_TYPE_A,1,0,0,0),
717 PIXMAN_g1 = PIXMAN_FORMAT(1,PIXMAN_TYPE_GRAY,0,0,0,0),
720 PIXMAN_yuy2 = PIXMAN_FORMAT(16,PIXMAN_TYPE_YUY2,0,0,0,0),
721 PIXMAN_yv12 = PIXMAN_FORMAT(12,PIXMAN_TYPE_YV12,0,0,0,0)
722 } pixman_format_code_t;
724 /* Querying supported format values. */
725 pixman_bool_t pixman_format_supported_destination (pixman_format_code_t format);
726 pixman_bool_t pixman_format_supported_source (pixman_format_code_t format);
729 pixman_image_t *pixman_image_create_solid_fill (pixman_color_t *color);
730 pixman_image_t *pixman_image_create_linear_gradient (pixman_point_fixed_t *p1,
731 pixman_point_fixed_t *p2,
732 const pixman_gradient_stop_t *stops,
734 pixman_image_t *pixman_image_create_radial_gradient (pixman_point_fixed_t *inner,
735 pixman_point_fixed_t *outer,
736 pixman_fixed_t inner_radius,
737 pixman_fixed_t outer_radius,
738 const pixman_gradient_stop_t *stops,
740 pixman_image_t *pixman_image_create_conical_gradient (pixman_point_fixed_t *center,
741 pixman_fixed_t angle,
742 const pixman_gradient_stop_t *stops,
744 pixman_image_t *pixman_image_create_bits (pixman_format_code_t format,
748 int rowstride_bytes);
751 pixman_image_t *pixman_image_ref (pixman_image_t *image);
752 pixman_bool_t pixman_image_unref (pixman_image_t *image);
754 void pixman_image_set_destroy_function (pixman_image_t *image,
755 pixman_image_destroy_func_t function,
757 void * pixman_image_get_destroy_data (pixman_image_t *image);
760 pixman_bool_t pixman_image_set_clip_region (pixman_image_t *image,
761 pixman_region16_t *region);
762 pixman_bool_t pixman_image_set_clip_region32 (pixman_image_t *image,
763 pixman_region32_t *region);
764 void pixman_image_set_has_client_clip (pixman_image_t *image,
765 pixman_bool_t clien_clip);
766 pixman_bool_t pixman_image_set_transform (pixman_image_t *image,
767 const pixman_transform_t *transform);
768 void pixman_image_set_repeat (pixman_image_t *image,
769 pixman_repeat_t repeat);
770 pixman_bool_t pixman_image_set_filter (pixman_image_t *image,
771 pixman_filter_t filter,
772 const pixman_fixed_t *filter_params,
773 int n_filter_params);
774 void pixman_image_set_source_clipping (pixman_image_t *image,
775 pixman_bool_t source_clipping);
776 void pixman_image_set_alpha_map (pixman_image_t *image,
777 pixman_image_t *alpha_map,
780 void pixman_image_set_component_alpha (pixman_image_t *image,
781 pixman_bool_t component_alpha);
782 void pixman_image_set_accessors (pixman_image_t *image,
783 pixman_read_memory_func_t read_func,
784 pixman_write_memory_func_t write_func);
785 void pixman_image_set_indexed (pixman_image_t *image,
786 const pixman_indexed_t *indexed);
787 uint32_t *pixman_image_get_data (pixman_image_t *image);
788 int pixman_image_get_width (pixman_image_t *image);
789 int pixman_image_get_height (pixman_image_t *image);
790 int pixman_image_get_stride (pixman_image_t *image); /* in bytes */
791 int pixman_image_get_depth (pixman_image_t *image);
792 pixman_format_code_t pixman_image_get_format (pixman_image_t *image);
793 pixman_bool_t pixman_image_fill_rectangles (pixman_op_t op,
794 pixman_image_t *image,
795 pixman_color_t *color,
797 const pixman_rectangle16_t *rects);
798 pixman_bool_t pixman_image_fill_boxes (pixman_op_t op,
799 pixman_image_t *dest,
800 pixman_color_t *color,
802 const pixman_box32_t *boxes);
805 pixman_bool_t pixman_compute_composite_region (pixman_region16_t *region,
806 pixman_image_t *src_image,
807 pixman_image_t *mask_image,
808 pixman_image_t *dst_image,
817 void pixman_image_composite (pixman_op_t op,
819 pixman_image_t *mask,
820 pixman_image_t *dest,
829 void pixman_image_composite32 (pixman_op_t op,
831 pixman_image_t *mask,
832 pixman_image_t *dest,
842 /* Old X servers rely on out-of-bounds accesses when they are asked
843 * to composite with a window as the source. They create a pixman image
844 * pointing to some bogus position in memory, but then they set a clip
845 * region to the position where the actual bits are.
847 * Due to a bug in old versions of pixman, where it would not clip
848 * against the image bounds when a clip region was set, this would
849 * actually work. So by default we allow certain out-of-bound access
850 * to happen unless explicitly disabled.
852 * Fixed X servers should call this function to disable the workaround.
854 void pixman_disable_out_of_bounds_workaround (void);
859 typedef struct pixman_edge pixman_edge_t;
860 typedef struct pixman_trapezoid pixman_trapezoid_t;
861 typedef struct pixman_trap pixman_trap_t;
862 typedef struct pixman_span_fix pixman_span_fix_t;
865 * An edge structure. This represents a single polygon edge
866 * and can be quickly stepped across small or large gaps in the
873 pixman_fixed_t stepx;
874 pixman_fixed_t signdx;
878 pixman_fixed_t stepx_small;
879 pixman_fixed_t stepx_big;
880 pixman_fixed_t dx_small;
881 pixman_fixed_t dx_big;
884 struct pixman_trapezoid
886 pixman_fixed_t top, bottom;
887 pixman_line_fixed_t left, right;
891 /* whether 't' is a well defined not obviously empty trapezoid */
892 #define pixman_trapezoid_valid(t) \
893 ((t)->left.p1.y != (t)->left.p2.y && \
894 (t)->right.p1.y != (t)->right.p2.y && \
895 (int) ((t)->bottom - (t)->top) > 0)
897 struct pixman_span_fix
899 pixman_fixed_t l, r, y;
904 pixman_span_fix_t top, bot;
907 pixman_fixed_t pixman_sample_ceil_y (pixman_fixed_t y,
909 pixman_fixed_t pixman_sample_floor_y (pixman_fixed_t y,
911 void pixman_edge_step (pixman_edge_t *e,
913 void pixman_edge_init (pixman_edge_t *e,
915 pixman_fixed_t y_start,
916 pixman_fixed_t x_top,
917 pixman_fixed_t y_top,
918 pixman_fixed_t x_bot,
919 pixman_fixed_t y_bot);
920 void pixman_line_fixed_edge_init (pixman_edge_t *e,
923 const pixman_line_fixed_t *line,
926 void pixman_rasterize_edges (pixman_image_t *image,
931 void pixman_add_traps (pixman_image_t *image,
935 pixman_trap_t *traps);
936 void pixman_add_trapezoids (pixman_image_t *image,
940 const pixman_trapezoid_t *traps);
941 void pixman_rasterize_trapezoid (pixman_image_t *image,
942 const pixman_trapezoid_t *trap,
948 #endif /* PIXMAN_H__ */