]> 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 enum
71 {
72   UndefinedInterpolatePixel,
73   AverageInterpolatePixel,
74   BicubicInterpolatePixel,
75   BilinearInterpolatePixel,
76   FilterInterpolatePixel,
77   IntegerInterpolatePixel,
78   MeshInterpolatePixel,
79   NearestNeighborInterpolatePixel,
80   SplineInterpolatePixel
81 } InterpolatePixelMethod;
82
83 typedef struct _DoublePixelPacket
84 {
85   double
86     red,
87     green,
88     blue,
89     opacity,
90     index;
91 } DoublePixelPacket;
92
93 typedef struct _LongPixelPacket
94 {
95   unsigned int
96     red,
97     green,
98     blue,
99     opacity,
100     index;
101 } LongPixelPacket;
102
103 typedef struct _MagickPixelPacket
104 {
105   ClassType
106     storage_class;
107
108   ColorspaceType
109     colorspace;
110
111   MagickBooleanType
112     matte;
113
114   double
115     fuzz;
116
117   size_t
118     depth;
119
120   MagickRealType
121     red,
122     green,
123     blue,
124     opacity,
125     index;
126 } MagickPixelPacket;
127
128 typedef Quantum IndexPacket;
129
130 typedef struct _PixelPacket
131 {
132 #if defined(MAGICKCORE_WORDS_BIGENDIAN)
133 #define MAGICK_PIXEL_RGBA  1
134   Quantum
135     red,
136     green,
137     blue,
138     opacity;
139 #else
140 #define MAGICK_PIXEL_BGRA  1
141   Quantum
142     blue,
143     green,
144     red,
145     opacity;
146 #endif
147 } PixelPacket;
148
149 typedef struct _CacheView
150   CacheView_;
151
152 extern MagickExport MagickBooleanType
153   ExportImagePixels(const Image *,const ssize_t,const ssize_t,const size_t,
154     const size_t,const char *,const StorageType,void *,ExceptionInfo *),
155   ImportImagePixels(Image *,const ssize_t,const ssize_t,const size_t,
156     const size_t,const char *,const StorageType,const void *),
157   InterpolateMagickPixelPacket(const Image *,const CacheView_ *,
158     const InterpolatePixelMethod,const double,const double,MagickPixelPacket *,
159     ExceptionInfo *);
160
161 extern MagickExport void
162   GetMagickPixelPacket(const Image *,MagickPixelPacket *);
163
164 #if defined(__cplusplus) || defined(c_plusplus)
165 }
166 #endif
167
168 #endif