MagickCore  6.9.13-40
Convert, Edit, Or Compose Bitmap Images
image-private.h
1 /*
2  Copyright 1999 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. You may
6  obtain a copy of the License at
7 
8  https://imagemagick.org/license/
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 private methods.
17 */
18 #ifndef MAGICKCORE_IMAGE_PRIVATE_H
19 #define MAGICKCORE_IMAGE_PRIVATE_H
20 
21 #define MagickMax(x,y) (((x) > (y)) ? (x) : (y))
22 #define MagickMin(x,y) (((x) < (y)) ? (x) : (y))
23 
24 #include "magick/quantum-private.h"
25 
26 #define BackgroundColor "#ffffff" /* white */
27 #if defined(__cplusplus) || defined(c_plusplus)
28 extern "C" {
29 #endif
30 
31 #define BackgroundColorRGBA QuantumRange,QuantumRange,QuantumRange,OpaqueOpacity
32 #define BorderColor "#dfdfdf" /* gray */
33 #define BorderColorRGBA ScaleShortToQuantum(0xdfdf),\
34  ScaleShortToQuantum(0xdfdf),ScaleShortToQuantum(0xdfdf),OpaqueOpacity
35 #define DefaultResolution 72.0
36 #define DefaultTileFrame "15x15+3+3"
37 #define DefaultTileGeometry "120x120+4+3>"
38 #define DefaultTileLabel "%f\n%G\n%b"
39 #define ForegroundColor "#000" /* black */
40 #define ForegroundColorRGBA 0,0,0,OpaqueOpacity
41 #define LoadImagesTag "Load/Images"
42 #define LoadImageTag "Load/Image"
43 #define Magick2PI 6.28318530717958647692528676655900576839433879875020
44 #define MagickAbsoluteValue(x) ((x) < 0 ? -(x) : (x))
45 #define MAGICK_INT_MAX (INT_MAX)
46 #define MagickPHI 1.61803398874989484820458683436563811772030917980576
47 #define MagickPI2 1.57079632679489661923132169163975144209858469968755
48 #define MagickPI 3.14159265358979323846264338327950288419716939937510
49 #define MAGICK_PTRDIFF_MAX (PTRDIFF_MAX)
50 #define MAGICK_PTRDIFF_MIN (-PTRDIFF_MAX-1)
51 #define MagickSQ1_2 0.70710678118654752440084436210484903928483593768847
52 #define MagickSQ2 1.41421356237309504880168872420969807856967187537695
53 #define MagickSQ2PI 2.50662827463100024161235523934010416269302368164062
54 #define MAGICK_SIZE_MAX (SIZE_MAX)
55 #define MAGICK_SSIZE_MAX (SSIZE_MAX)
56 #define MAGICK_SSIZE_MIN (-SSIZE_MAX-1)
57 #define MatteColor "#bdbdbd" /* gray */
58 #define MatteColorRGBA ScaleShortToQuantum(0xbdbd),\
59  ScaleShortToQuantum(0xbdbd),ScaleShortToQuantum(0xbdbd),OpaqueOpacity
60 #define PSDensityGeometry "72.0x72.0"
61 #define PSPageGeometry "612x792"
62 #define SaveImagesTag "Save/Images"
63 #define SaveImageTag "Save/Image"
64 #define TransparentColor "#00000000" /* transparent black */
65 #define TransparentColorRGBA 0,0,0,TransparentOpacity
66 #define UndefinedCompressionQuality 0UL
67 #define UndefinedTicksPerSecond 100L
68 
69 static inline int CastDoubleToInt(const double x)
70 {
71  double
72  value;
73 
74  if (IsNaN(x) != 0)
75  {
76  errno=ERANGE;
77  return(0);
78  }
79  value=(x < 0.0) ? ceil(x) : floor(x);
80  if (value < 0.0)
81  {
82  errno=ERANGE;
83  return(0);
84  }
85  if (value >= ((double) MAGICK_INT_MAX))
86  {
87  errno=ERANGE;
88  return(MAGICK_INT_MAX);
89  }
90  return((int) value);
91 }
92 
93 static inline ssize_t CastDoubleToLong(const double x)
94 {
95  double
96  value;
97 
98  if (IsNaN(x) != 0)
99  {
100  errno=ERANGE;
101  return(0);
102  }
103  value=(x < 0.0) ? ceil(x) : floor(x);
104  if (value < ((double) MAGICK_SSIZE_MIN))
105  {
106  errno=ERANGE;
107  return(MAGICK_SSIZE_MIN);
108  }
109  if (value >= ((double) MAGICK_SSIZE_MAX))
110  {
111  errno=ERANGE;
112  return(MAGICK_SSIZE_MAX);
113  }
114  return((ssize_t) value);
115 }
116 
117 static inline QuantumAny CastDoubleToQuantumAny(const double x)
118 {
119  double
120  value;
121 
122  if (IsNaN(x) != 0)
123  {
124  errno=ERANGE;
125  return(0);
126  }
127  value=(x < 0.0) ? ceil(x) : floor(x);
128  if (value < 0.0)
129  {
130  errno=ERANGE;
131  return(0);
132  }
133  if (value >= ((double) ((QuantumAny) ~0)))
134  {
135  errno=ERANGE;
136  return((QuantumAny) ~0);
137  }
138  return((QuantumAny) value);
139 }
140 
141 static inline size_t CastDoubleToUnsigned(const double x)
142 {
143  double
144  value;
145 
146  if (IsNaN(x) != 0)
147  {
148  errno=ERANGE;
149  return(0);
150  }
151  value=(x < 0.0) ? ceil(x) : floor(x);
152  if (value < 0.0)
153  {
154  errno=ERANGE;
155  return(0);
156  }
157  if (value >= ((double) MAGICK_SIZE_MAX))
158  {
159  errno=ERANGE;
160  return(MAGICK_SIZE_MAX);
161  }
162  return((size_t) value);
163 }
164 
165 static inline double DegreesToRadians(const double degrees)
166 {
167  return((double) (MagickPI*degrees/180.0));
168 }
169 
170 static inline MagickRealType RadiansToDegrees(const MagickRealType radians)
171 {
172  return((MagickRealType) (180.0*radians/MagickPI));
173 }
174 
175 static inline unsigned char ScaleColor5to8(const unsigned int color)
176 {
177  return((unsigned char) (((color) << 3) | ((color) >> 2)));
178 }
179 
180 static inline unsigned char ScaleColor6to8(const unsigned int color)
181 {
182  return((unsigned char) (((color) << 2) | ((color) >> 4)));
183 }
184 
185 static inline unsigned int ScaleColor8to5(const unsigned char color)
186 {
187  return((unsigned int) (((color) & ~0x07) >> 3));
188 }
189 
190 static inline unsigned int ScaleColor8to6(const unsigned char color)
191 {
192  return((unsigned int) (((color) & ~0x03) >> 2));
193 }
194 
195 #if defined(__cplusplus) || defined(c_plusplus)
196 }
197 #endif
198 
199 #endif