]> granicus.if.org Git - imagemagick/blob - magick/pixel.h
Remove previous geometry changes
[imagemagick] / magick / pixel.h
1 /*
2   Copyright 1999-2010 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,component) ((q)->red=(component))
42 #define SetGreenPixelComponent(q,component) ((q)->green=(component))
43 #define SetBluePixelComponent(q,component) ((q)->blue=(component))
44 #define SetOpacityPixelComponent(q,component) ((q)->opacity=(component))
45 #define SetAlphaPixelComponent(q,component) \
46   ((q)->opacity=(QuantumRange-(component)))
47 #define SetIndexPixelComponent(q,component) ((q)->index=(component))
48
49 #define GetGrayPixelComponent(p) ((p)->red)
50 #define SetGrayPixelComponent(q,component) \
51   ((q)->red=(q)->green=(q)->blue=(component))
52
53 #define GetYPixelComponent(p) ((p)->red)
54 #define GetCbPixelComponent(p) ((p)->green)
55 #define GetCrPixelComponent(p) ((p)->blue)
56
57 #define SetYPixelComponent(q,component) ((q)->red=(component))
58 #define SetCbPixelComponent(q,component) ((q)->green=(component))
59 #define SetCrPixelComponent(q,component) ((q)->blue=(component))
60
61 #define GetCyanPixelComponent(p) ((p)->red)
62 #define GetMagentaPixelComponent(p) ((p)->green)
63 #define GetYellowPixelComponent(p) ((p)->blue)
64 #define GetBlackPixelComponent(p) ((p)->opacity)
65
66 #define SetCyanPixelComponent(q,component) ((q)->red=(component))
67 #define SetMagentaPixelComponent(q,component) ((q)->green=(component))
68 #define SetYellowPixelComponent(q,component) ((q)->blue=(component))
69 #define SetBlackPixelComponent(q,component) ((q)->opacity=(component))
70
71 typedef struct _DoublePixelPacket
72 {
73   double
74     red,
75     green,
76     blue,
77     opacity,
78     index;
79 } DoublePixelPacket;
80
81 typedef struct _LongPixelPacket
82 {
83   unsigned long
84     red,
85     green,
86     blue,
87     opacity,
88     index;
89 } LongPixelPacket;
90
91 typedef struct _MagickPixelPacket
92 {
93   ClassType
94     storage_class;
95
96   ColorspaceType
97     colorspace;
98
99   MagickBooleanType
100     matte;
101
102   double
103     fuzz;
104
105   unsigned long
106     depth;
107
108   MagickRealType
109     red,
110     green,
111     blue,
112     opacity,
113     index;
114 } MagickPixelPacket;
115
116 typedef Quantum IndexPacket;
117
118 typedef struct _PixelPacket
119 {
120 #if defined(MAGICKCORE_WORDS_BIGENDIAN)
121 #define MAGICK_PIXEL_RGBA  1
122   Quantum
123     red,
124     green,
125     blue,
126     opacity;
127 #else
128 #define MAGICK_PIXEL_BGRA  1
129   Quantum
130     blue,
131     green,
132     red,
133     opacity;
134 #endif
135 } PixelPacket;
136
137 extern MagickExport MagickBooleanType
138   ExportImagePixels(const Image *,const long,const long,const unsigned long,
139     const unsigned long,const char *,const StorageType,void *,ExceptionInfo *),
140   ImportImagePixels(Image *,const long,const long,const unsigned long,
141     const unsigned long,const char *,const StorageType,const void *);
142
143 extern MagickExport void
144   GetMagickPixelPacket(const Image *,MagickPixelPacket *);
145
146 #if defined(__cplusplus) || defined(c_plusplus)
147 }
148 #endif
149
150 #endif