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