]> granicus.if.org Git - imagemagick/blob - magick/pixel.h
(no commit message)
[imagemagick] / magick / pixel.h
1 /*
2   Copyright 1999-2011 ImageMagick Studio LLC, a non-profit organization
3   dedicated to making software imaging solutions freely available.
4   
5   You may not use this file except in compliance with the License.
6   obtain a copy of the License at
7   
8     http://www.imagemagick.org/script/license.php
9   
10   Unless required by applicable law or agreed to in writing, software
11   distributed under the License is distributed on an "AS IS" BASIS,
12   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   See the License for the specific language governing permissions and
14   limitations under the License.
15
16   MagickCore image constitute methods.
17 */
18 #ifndef _MAGICKCORE_PIXEL_H
19 #define _MAGICKCORE_PIXEL_H
20
21 #if defined(__cplusplus) || defined(c_plusplus)
22 extern "C" {
23 #endif
24
25 #include <magick/colorspace.h>
26 #include <magick/constitute.h>
27
28 #define ClampRedPixelComponent(p) ClampToQuantum((p)->red)
29 #define ClampGreenPixelComponent(p) ClampToQuantum((p)->green)
30 #define ClampBluePixelComponent(p) ClampToQuantum((p)->blue)
31 #define ClampOpacityPixelComponent(p) ClampToQuantum((p)->opacity)
32 #define ClampIndexPixelComponent(p) ClampToQuantum((p)->index)
33
34 #define GetRedPixelComponent(p) ((p)->red)
35 #define GetGreenPixelComponent(p) ((p)->green)
36 #define GetBluePixelComponent(p) ((p)->blue)
37 #define GetOpacityPixelComponent(p) ((p)->opacity)
38 #define GetAlphaPixelComponent(p) (QuantumRange-(p)->opacity)
39 #define GetIndexPixelComponent(p) ((p)->index)
40
41 #define SetRedPixelComponent(q,value) ((q)->red=(value))
42 #define SetGreenPixelComponent(q,value) ((q)->green=(value))
43 #define SetBluePixelComponent(q,value) ((q)->blue=(value))
44 #define SetOpacityPixelComponent(q,value) ((q)->opacity=(value))
45 #define SetAlphaPixelComponent(q,value) \
46   ((q)->opacity=(Quantum) (QuantumRange-(value)))
47 #define SetIndexPixelComponent(q,value) ((q)->index=(value))
48
49 #define GetGrayPixelComponent(p) ((p)->red)
50 #define SetGrayPixelComponent(q,value) ((q)->red=(q)->green=(q)->blue=(value))
51
52 #define GetYPixelComponent(p) ((p)->red)
53 #define GetCbPixelComponent(p) ((p)->green)
54 #define GetCrPixelComponent(p) ((p)->blue)
55
56 #define SetYPixelComponent(q,value) ((q)->red=(value))
57 #define SetCbPixelComponent(q,value) ((q)->green=(value))
58 #define SetCrPixelComponent(q,value) ((q)->blue=(value))
59
60 #define GetCyanPixelComponent(p) ((p)->red)
61 #define GetMagentaPixelComponent(p) ((p)->green)
62 #define GetYellowPixelComponent(p) ((p)->blue)
63 #define GetBlackPixelComponent(p,x) (p[x])
64
65 #define SetCyanPixelComponent(q,value) ((q)->red=(value))
66 #define SetMagentaPixelComponent(q,value) ((q)->green=(value))
67 #define SetYellowPixelComponent(q,value) ((q)->blue=(value))
68 #define SetBlackPixelComponent(p,x,value) (p[x]=(value))
69
70 typedef struct _DoublePixelPacket
71 {
72   double
73     red,
74     green,
75     blue,
76     opacity,
77     index;
78 } DoublePixelPacket;
79
80 typedef struct _LongPixelPacket
81 {
82   unsigned int
83     red,
84     green,
85     blue,
86     opacity,
87     index;
88 } LongPixelPacket;
89
90 typedef struct _MagickPixelPacket
91 {
92   ClassType
93     storage_class;
94
95   ColorspaceType
96     colorspace;
97
98   MagickBooleanType
99     matte;
100
101   double
102     fuzz;
103
104   size_t
105     depth;
106
107   MagickRealType
108     red,
109     green,
110     blue,
111     opacity,
112     index;
113 } MagickPixelPacket;
114
115 typedef Quantum IndexPacket;
116
117 typedef struct _PixelPacket
118 {
119 #if defined(MAGICKCORE_WORDS_BIGENDIAN)
120 #define MAGICK_PIXEL_RGBA  1
121   Quantum
122     red,
123     green,
124     blue,
125     opacity;
126 #else
127 #define MAGICK_PIXEL_BGRA  1
128   Quantum
129     blue,
130     green,
131     red,
132     opacity;
133 #endif
134 } PixelPacket;
135
136 extern MagickExport MagickBooleanType
137   ExportImagePixels(const Image *,const ssize_t,const ssize_t,const size_t,
138     const size_t,const char *,const StorageType,void *,ExceptionInfo *),
139   ImportImagePixels(Image *,const ssize_t,const ssize_t,const size_t,
140     const size_t,const char *,const StorageType,const void *);
141
142 extern MagickExport void
143   GetMagickPixelPacket(const Image *,MagickPixelPacket *);
144
145 #if defined(__cplusplus) || defined(c_plusplus)
146 }
147 #endif
148
149 #endif