1706f2543Smrg/*
2706f2543Smrg *
3706f2543Smrg * Copyright © 2000 SuSE, Inc.
4706f2543Smrg *
5706f2543Smrg * Permission to use, copy, modify, distribute, and sell this software and its
6706f2543Smrg * documentation for any purpose is hereby granted without fee, provided that
7706f2543Smrg * the above copyright notice appear in all copies and that both that
8706f2543Smrg * copyright notice and this permission notice appear in supporting
9706f2543Smrg * documentation, and that the name of SuSE not be used in advertising or
10706f2543Smrg * publicity pertaining to distribution of the software without specific,
11706f2543Smrg * written prior permission.  SuSE makes no representations about the
12706f2543Smrg * suitability of this software for any purpose.  It is provided "as is"
13706f2543Smrg * without express or implied warranty.
14706f2543Smrg *
15706f2543Smrg * SuSE DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL
16706f2543Smrg * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL SuSE
17706f2543Smrg * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
18706f2543Smrg * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
19706f2543Smrg * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
20706f2543Smrg * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
21706f2543Smrg *
22706f2543Smrg * Author:  Keith Packard, SuSE, Inc.
23706f2543Smrg */
24706f2543Smrg
25706f2543Smrg#ifndef _PICTURE_H_
26706f2543Smrg#define _PICTURE_H_
27706f2543Smrg
28706f2543Smrg#include "privates.h"
29706f2543Smrg
30706f2543Smrg#include <pixman.h>
31706f2543Smrg
32706f2543Smrgtypedef struct _DirectFormat	*DirectFormatPtr;
33706f2543Smrgtypedef struct _PictFormat	*PictFormatPtr;
34706f2543Smrgtypedef struct _Picture		*PicturePtr;
35706f2543Smrg
36706f2543Smrg/*
37706f2543Smrg * While the protocol is generous in format support, the
38706f2543Smrg * sample implementation allows only packed RGB and GBR
39706f2543Smrg * representations for data to simplify software rendering,
40706f2543Smrg */
41706f2543Smrg#define PICT_FORMAT(bpp,type,a,r,g,b)	PIXMAN_FORMAT(bpp, type, a, r, g, b)
42706f2543Smrg
43706f2543Smrg/*
44706f2543Smrg * gray/color formats use a visual index instead of argb
45706f2543Smrg */
46706f2543Smrg#define PICT_VISFORMAT(bpp,type,vi)	(((bpp) << 24) |  \
47706f2543Smrg					 ((type) << 16) | \
48706f2543Smrg					 ((vi)))
49706f2543Smrg
50706f2543Smrg#define PICT_FORMAT_BPP(f)	PIXMAN_FORMAT_BPP(f)
51706f2543Smrg#define PICT_FORMAT_TYPE(f)	PIXMAN_FORMAT_TYPE(f)
52706f2543Smrg#define PICT_FORMAT_A(f)	PIXMAN_FORMAT_A(f)
53706f2543Smrg#define PICT_FORMAT_R(f)	PIXMAN_FORMAT_R(f)
54706f2543Smrg#define PICT_FORMAT_G(f)	PIXMAN_FORMAT_G(f)
55706f2543Smrg#define PICT_FORMAT_B(f)	PIXMAN_FORMAT_B(f)
56706f2543Smrg#define PICT_FORMAT_RGB(f)	PIXMAN_FORMAT_RGB(f)
57706f2543Smrg#define PICT_FORMAT_VIS(f)	PIXMAN_FORMAT_VIS(f)
58706f2543Smrg
59706f2543Smrg#define PICT_TYPE_OTHER		PIXMAN_TYPE_OTHER
60706f2543Smrg#define PICT_TYPE_A		PIXMAN_TYPE_A
61706f2543Smrg#define PICT_TYPE_ARGB		PIXMAN_TYPE_ARGB
62706f2543Smrg#define PICT_TYPE_ABGR		PIXMAN_TYPE_ABGR
63706f2543Smrg#define PICT_TYPE_COLOR		PIXMAN_TYPE_COLOR
64706f2543Smrg#define PICT_TYPE_GRAY		PIXMAN_TYPE_GRAY
65706f2543Smrg#define PICT_TYPE_BGRA		PIXMAN_TYPE_BGRA
66706f2543Smrg
67706f2543Smrg#define PICT_FORMAT_COLOR(f)	PIXMAN_FORMAT_COLOR(f)
68706f2543Smrg
69706f2543Smrg/* 32bpp formats */
70706f2543Smrgtypedef enum _PictFormatShort {
71706f2543Smrg    PICT_a2r10g10b10 =	PIXMAN_a2r10g10b10,
72706f2543Smrg    PICT_x2r10g10b10 =	PIXMAN_x2r10g10b10,
73706f2543Smrg    PICT_a2b10g10r10 =	PIXMAN_a2b10g10r10,
74706f2543Smrg    PICT_x2b10g10r10 =	PIXMAN_x2b10g10r10,
75706f2543Smrg
76706f2543Smrg    PICT_a8r8g8b8 =	PIXMAN_a8r8g8b8,
77706f2543Smrg    PICT_x8r8g8b8 =	PIXMAN_x8r8g8b8,
78706f2543Smrg    PICT_a8b8g8r8 =	PIXMAN_a8b8g8r8,
79706f2543Smrg    PICT_x8b8g8r8 =	PIXMAN_x8b8g8r8,
80706f2543Smrg    PICT_b8g8r8a8 =	PIXMAN_b8g8r8a8,
81706f2543Smrg    PICT_b8g8r8x8 =	PIXMAN_b8g8r8x8,
82706f2543Smrg
83706f2543Smrg/* 24bpp formats */
84706f2543Smrg    PICT_r8g8b8 =	PIXMAN_r8g8b8,
85706f2543Smrg    PICT_b8g8r8 =	PIXMAN_b8g8r8,
86706f2543Smrg
87706f2543Smrg/* 16bpp formats */
88706f2543Smrg    PICT_r5g6b5 =	PIXMAN_r5g6b5,
89706f2543Smrg    PICT_b5g6r5 =	PIXMAN_b5g6r5,
90706f2543Smrg
91706f2543Smrg    PICT_a1r5g5b5 =	PIXMAN_a1r5g5b5,
92706f2543Smrg    PICT_x1r5g5b5 =	PIXMAN_x1r5g5b5,
93706f2543Smrg    PICT_a1b5g5r5 =	PIXMAN_a1b5g5r5,
94706f2543Smrg    PICT_x1b5g5r5 =	PIXMAN_x1b5g5r5,
95706f2543Smrg    PICT_a4r4g4b4 =	PIXMAN_a4r4g4b4,
96706f2543Smrg    PICT_x4r4g4b4 =	PIXMAN_x4r4g4b4,
97706f2543Smrg    PICT_a4b4g4r4 =	PIXMAN_a4b4g4r4,
98706f2543Smrg    PICT_x4b4g4r4 =	PIXMAN_x4b4g4r4,
99706f2543Smrg
100706f2543Smrg/* 8bpp formats */
101706f2543Smrg    PICT_a8 =		PIXMAN_a8,
102706f2543Smrg    PICT_r3g3b2 =	PIXMAN_r3g3b2,
103706f2543Smrg    PICT_b2g3r3 =	PIXMAN_b2g3r3,
104706f2543Smrg    PICT_a2r2g2b2 =	PIXMAN_a2r2g2b2,
105706f2543Smrg    PICT_a2b2g2r2 =	PIXMAN_a2b2g2r2,
106706f2543Smrg
107706f2543Smrg    PICT_c8 =		PIXMAN_c8,
108706f2543Smrg    PICT_g8 =		PIXMAN_g8,
109706f2543Smrg
110706f2543Smrg    PICT_x4a4 =		PIXMAN_x4a4,
111706f2543Smrg
112706f2543Smrg    PICT_x4c4 =		PIXMAN_x4c4,
113706f2543Smrg    PICT_x4g4 =		PIXMAN_x4g4,
114706f2543Smrg
115706f2543Smrg/* 4bpp formats */
116706f2543Smrg    PICT_a4 =		PIXMAN_a4,
117706f2543Smrg    PICT_r1g2b1 =	PIXMAN_r1g2b1,
118706f2543Smrg    PICT_b1g2r1 =	PIXMAN_b1g2r1,
119706f2543Smrg    PICT_a1r1g1b1 =	PIXMAN_a1r1g1b1,
120706f2543Smrg    PICT_a1b1g1r1 =	PIXMAN_a1b1g1r1,
121706f2543Smrg
122706f2543Smrg    PICT_c4 =		PIXMAN_c4,
123706f2543Smrg    PICT_g4 =		PIXMAN_g4,
124706f2543Smrg
125706f2543Smrg/* 1bpp formats */
126706f2543Smrg    PICT_a1 =		PIXMAN_a1,
127706f2543Smrg
128706f2543Smrg    PICT_g1 =		PIXMAN_g1
129706f2543Smrg} PictFormatShort;
130706f2543Smrg
131706f2543Smrg/*
132706f2543Smrg * For dynamic indexed visuals (GrayScale and PseudoColor), these control the
133706f2543Smrg * selection of colors allocated for drawing to Pictures.  The default
134706f2543Smrg * policy depends on the size of the colormap:
135706f2543Smrg *
136706f2543Smrg * Size		Default Policy
137706f2543Smrg * ----------------------------
138706f2543Smrg *  < 64	PolicyMono
139706f2543Smrg *  < 256	PolicyGray
140706f2543Smrg *  256		PolicyColor (only on PseudoColor)
141706f2543Smrg *
142706f2543Smrg * The actual allocation code lives in miindex.c, and so is
143706f2543Smrg * austensibly server dependent, but that code does:
144706f2543Smrg *
145706f2543Smrg * PolicyMono	    Allocate no additional colors, use black and white
146706f2543Smrg * PolicyGray	    Allocate 13 gray levels (11 cells used)
147706f2543Smrg * PolicyColor	    Allocate a 4x4x4 cube and 13 gray levels (71 cells used)
148706f2543Smrg * PolicyAll	    Allocate as big a cube as possible, fill with gray (all)
149706f2543Smrg *
150706f2543Smrg * Here's a picture to help understand how many colors are
151706f2543Smrg * actually allocated (this is just the gray ramp):
152706f2543Smrg *
153706f2543Smrg *                 gray level
154706f2543Smrg * all   0000 1555 2aaa 4000 5555 6aaa 8000 9555 aaaa bfff d555 eaaa ffff
155706f2543Smrg * b/w   0000                                                        ffff
156706f2543Smrg * 4x4x4                     5555                aaaa
157706f2543Smrg * extra      1555 2aaa 4000      6aaa 8000 9555      bfff d555 eaaa
158706f2543Smrg *
159706f2543Smrg * The default colormap supplies two gray levels (black/white), the
160706f2543Smrg * 4x4x4 cube allocates another two and nine more are allocated to fill
161706f2543Smrg * in the 13 levels.  When the 4x4x4 cube is not allocated, a total of
162706f2543Smrg * 11 cells are allocated.
163706f2543Smrg */
164706f2543Smrg
165706f2543Smrg#define PictureCmapPolicyInvalid    -1
166706f2543Smrg#define PictureCmapPolicyDefault    0
167706f2543Smrg#define PictureCmapPolicyMono	    1
168706f2543Smrg#define PictureCmapPolicyGray	    2
169706f2543Smrg#define PictureCmapPolicyColor	    3
170706f2543Smrg#define PictureCmapPolicyAll	    4
171706f2543Smrg
172706f2543Smrgextern _X_EXPORT int PictureCmapPolicy;
173706f2543Smrg
174706f2543Smrgextern _X_EXPORT int PictureParseCmapPolicy (const char *name);
175706f2543Smrg
176706f2543Smrgextern _X_EXPORT int RenderErrBase;
177706f2543Smrg
178706f2543Smrg/* Fixed point updates from Carl Worth, USC, Information Sciences Institute */
179706f2543Smrg
180706f2543Smrgtypedef pixman_fixed_32_32_t	xFixed_32_32;
181706f2543Smrg
182706f2543Smrgtypedef pixman_fixed_48_16_t	xFixed_48_16;
183706f2543Smrg
184706f2543Smrg#define MAX_FIXED_48_16		pixman_max_fixed_48_16
185706f2543Smrg#define MIN_FIXED_48_16		pixman_min_fixed_48_16
186706f2543Smrg
187706f2543Smrgtypedef pixman_fixed_1_31_t	xFixed_1_31;
188706f2543Smrgtypedef pixman_fixed_1_16_t	xFixed_1_16;
189706f2543Smrgtypedef pixman_fixed_16_16_t	xFixed_16_16;
190706f2543Smrg
191706f2543Smrg/*
192706f2543Smrg * An unadorned "xFixed" is the same as xFixed_16_16,
193706f2543Smrg * (since it's quite common in the code)
194706f2543Smrg */
195706f2543Smrgtypedef	pixman_fixed_t	xFixed;
196706f2543Smrg#define XFIXED_BITS	16
197706f2543Smrg
198706f2543Smrg#define xFixedToInt(f)	pixman_fixed_to_int(f)
199706f2543Smrg#define IntToxFixed(i)	pixman_int_to_fixed(i)
200706f2543Smrg#define xFixedE		pixman_fixed_e
201706f2543Smrg#define xFixed1		pixman_fixed_1
202706f2543Smrg#define xFixed1MinusE	pixman_fixed_1_minus_e
203706f2543Smrg#define xFixedFrac(f)	pixman_fixed_frac(f)
204706f2543Smrg#define xFixedFloor(f)	pixman_fixed_floor(f)
205706f2543Smrg#define xFixedCeil(f)	pixman_fixed_ceil(f)
206706f2543Smrg
207706f2543Smrg#define xFixedFraction(f)	pixman_fixed_fraction(f)
208706f2543Smrg#define xFixedMod2(f)		pixman_fixed_mod2(f)
209706f2543Smrg
210706f2543Smrg/* whether 't' is a well defined not obviously empty trapezoid */
211706f2543Smrg#define xTrapezoidValid(t)  ((t)->left.p1.y != (t)->left.p2.y && \
212706f2543Smrg			     (t)->right.p1.y != (t)->right.p2.y && \
213706f2543Smrg			     ((t)->bottom > (t)->top))
214706f2543Smrg
215706f2543Smrg/*
216706f2543Smrg * Standard NTSC luminance conversions:
217706f2543Smrg *
218706f2543Smrg *  y = r * 0.299 + g * 0.587 + b * 0.114
219706f2543Smrg *
220706f2543Smrg * Approximate this for a bit more speed:
221706f2543Smrg *
222706f2543Smrg *  y = (r * 153 + g * 301 + b * 58) / 512
223706f2543Smrg *
224706f2543Smrg * This gives 17 bits of luminance; to get 15 bits, lop the low two
225706f2543Smrg */
226706f2543Smrg
227706f2543Smrg#define CvtR8G8B8toY15(s)	(((((s) >> 16) & 0xff) * 153 + \
228706f2543Smrg				  (((s) >>  8) & 0xff) * 301 + \
229706f2543Smrg				  (((s)      ) & 0xff) * 58) >> 2)
230706f2543Smrg
231706f2543Smrg#endif /* _PICTURE_H_ */
232