18#ifndef MAGICKCORE_IMAGE_PRIVATE_H
19#define MAGICKCORE_IMAGE_PRIVATE_H
21#if defined(__cplusplus) || defined(c_plusplus)
25#define MagickMax(x,y) (((x) > (y)) ? (x) : (y))
26#define MagickMin(x,y) (((x) < (y)) ? (x) : (y))
28#include "MagickCore/pixel-accessor.h"
29#include "MagickCore/quantum-private.h"
31#define BackgroundColor "#ffffff"
32#define BackgroundColorRGBA QuantumRange,QuantumRange,QuantumRange,OpaqueAlpha
33#define BorderColor "#dfdfdf"
34#define BorderColorRGBA ScaleShortToQuantum(0xdfdf),\
35 ScaleShortToQuantum(0xdfdf),ScaleShortToQuantum(0xdfdf),OpaqueAlpha
36#define DefaultResolution 72.0
37#define DefaultTileFrame "15x15+3+3"
38#define DefaultTileGeometry "120x120+4+3>"
39#define DefaultTileLabel "%f\n%G\n%b"
40#define ForegroundColor "#000"
41#define ForegroundColorRGBA 0,0,0,OpaqueAlpha
42#define LoadImagesTag "Load/Images"
43#define LoadImageTag "Load/Image"
44#define Magick2PI 6.28318530717958647692528676655900576839433879875020
45#define MagickAbsoluteValue(x) ((x) < 0 ? -(x) : (x))
46#define MagickPHI 1.61803398874989484820458683436563811772030917980576
47#define MagickPI2 1.57079632679489661923132169163975144209858469968755
48#define MagickPI 3.1415926535897932384626433832795028841971693993751058209749445923078164062
49#define MagickSQ1_2 0.70710678118654752440084436210484903928483593768847
50#define MagickSQ2 1.41421356237309504880168872420969807856967187537695
51#define MagickSQ2PI 2.50662827463100024161235523934010416269302368164062
52#define MAGICK_UCHAR_MAX (UCHAR_MAX)
53#define MAGICK_UINT_MAX (UINT_MAX)
54#define MAGICK_ULONG_MAX (ULONG_MAX)
55#define MAGICK_USHORT_MAX (USHRT_MAX)
56#define MatteColor "#bdbdbd"
57#define MatteColorRGBA ScaleShortToQuantum(0xbdbd),\
58 ScaleShortToQuantum(0xbdbd),ScaleShortToQuantum(0xbdbd),OpaqueAlpha
59#define PSDensityGeometry "72.0x72.0"
60#define PSPageGeometry "612x792"
61#define SaveImagesTag "Save/Images"
62#define SaveImageTag "Save/Image"
63#define TransparentColor "#00000000"
64#define TransparentColorRGBA (Quantum) 0,(Quantum) 0,(Quantum) 0,TransparentAlpha
65#define UndefinedCompressionQuality 0UL
66#define UndefinedTicksPerSecond 100L
68static inline int CastDoubleToInt(
const double x)
78 value=(x < 0.0) ? ceil(x) : floor(x);
84 if (value >= ((
double) MAGICK_INT_MAX))
87 return(MAGICK_INT_MAX);
92static inline ptrdiff_t CastDoubleToPtrdiffT(
const double x)
102 value=(x < 0.0) ? ceil(x) : floor(x);
103 if (value < ((
double) MAGICK_PTRDIFF_MIN))
106 return(MAGICK_PTRDIFF_MIN);
108 if (value >= ((
double) MAGICK_PTRDIFF_MAX))
111 return(MAGICK_PTRDIFF_MAX);
113 return((ptrdiff_t) value);
116static inline QuantumAny CastDoubleToQuantumAny(
const double x)
126 value=(x < 0.0) ? ceil(x) : floor(x);
132 if (value >= ((
double) ((QuantumAny) ~0)))
135 return((QuantumAny) ~0);
137 return((QuantumAny) value);
140static inline size_t CastDoubleToSizeT(
const double x)
150 value=(x < 0.0) ? ceil(x) : floor(x);
156 if (value >= ((
double) MAGICK_SIZE_MAX))
159 return(MAGICK_SIZE_MAX);
161 return((
size_t) value);
164static inline ssize_t CastDoubleToSsizeT(
const double x)
174 value=(x < 0.0) ? ceil(x) : floor(x);
175 if (value < ((
double) MAGICK_SSIZE_MIN))
178 return(MAGICK_SSIZE_MIN);
180 if (value >= ((
double) MAGICK_SSIZE_MAX))
183 return(MAGICK_SSIZE_MAX);
185 return((ssize_t) value);
188static inline unsigned char CastDoubleToUChar(
const double x)
198 value=(x < 0.0) ? ceil(x) : floor(x);
204 if (value >= ((
double) MAGICK_UCHAR_MAX))
207 return(MAGICK_UCHAR_MAX);
209 return((
unsigned char) value);
212static inline unsigned int CastDoubleToUInt(
const double x)
222 value=(x < 0.0) ? ceil(x) : floor(x);
228 if (value >= ((
double) MAGICK_UINT_MAX))
231 return(MAGICK_UINT_MAX);
233 return((
unsigned int) value);
236static inline unsigned short CastDoubleToUShort(
const double x)
246 value=(x < 0.0) ? ceil(x) : floor(x);
252 if (value >= ((
double) MAGICK_USHORT_MAX))
255 return(MAGICK_USHORT_MAX);
257 return((
unsigned short) value);
260static inline double DegreesToRadians(
const double degrees)
262 return((
double) (MagickPI*degrees/180.0));
265static inline size_t GetImageChannels(
const Image *image)
274 for (i=0; i < (ssize_t) GetPixelChannels(image); i++)
276 PixelChannel channel = GetPixelChannelChannel(image,i);
277 PixelTrait traits = GetPixelChannelTraits(image,channel);
278 if ((traits & UpdatePixelTrait) != 0)
281 return(channels == 0 ? (
size_t) 1 : channels);
284static inline double RadiansToDegrees(
const double radians)
286 return((
double) (180.0*radians/MagickPI));
289static inline unsigned char ScaleColor5to8(
const unsigned int color)
291 return((
unsigned char) (((color) << 3) | ((color) >> 2)));
294static inline unsigned char ScaleColor6to8(
const unsigned int color)
296 return((
unsigned char) (((color) << 2) | ((color) >> 4)));
299static inline unsigned int ScaleColor8to5(
const unsigned char color)
301 return((
unsigned int) (((color) & ~0x07) >> 3));
304static inline unsigned int ScaleColor8to6(
const unsigned char color)
306 return((
unsigned int) (((color) & ~0x03) >> 2));
309#if defined(__cplusplus) || defined(c_plusplus)