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 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 MAGICK_UINT_MAX (UINT_MAX)
58#define MAGICK_ULONG_MAX (ULONG_MAX)
59#define MAGICK_USHORT_MAX (USHRT_MAX)
60#define MatteColor "#bdbdbd"
61#define MatteColorRGBA ScaleShortToQuantum(0xbdbd),\
62 ScaleShortToQuantum(0xbdbd),ScaleShortToQuantum(0xbdbd),OpaqueAlpha
63#define PSDensityGeometry "72.0x72.0"
64#define PSPageGeometry "612x792"
65#define SaveImagesTag "Save/Images"
66#define SaveImageTag "Save/Image"
67#define TransparentColor "#00000000"
68#define TransparentColorRGBA (Quantum) 0,(Quantum) 0,(Quantum) 0,TransparentAlpha
69#define UndefinedCompressionQuality 0UL
70#define UndefinedTicksPerSecond 100L
72static inline ptrdiff_t CastDoubleToPtrdiffT(
const double x)
82 value=(x < 0.0) ? ceil(x) : floor(x);
83 if (value < ((
double) MAGICK_PTRDIFF_MIN))
86 return(MAGICK_PTRDIFF_MIN);
88 if (value > ((
double) MAGICK_PTRDIFF_MAX))
91 return(MAGICK_PTRDIFF_MAX);
93 return((ptrdiff_t) value);
96static inline QuantumAny CastDoubleToQuantumAny(
const double x)
106 value=(x < 0.0) ? ceil(x) : floor(x);
112 if (value > ((
double) ((QuantumAny) ~0)))
115 return((QuantumAny) ~0);
117 return((QuantumAny) value);
120static inline size_t CastDoubleToSizeT(
const double x)
130 value=(x < 0.0) ? ceil(x) : floor(x);
136 if (value > ((
double) MAGICK_SIZE_MAX))
139 return(MAGICK_SIZE_MAX);
141 return((
size_t) value);
144static inline ssize_t CastDoubleToSsizeT(
const double x)
154 value=(x < 0.0) ? ceil(x) : floor(x);
155 if (value < ((
double) MAGICK_SSIZE_MIN))
158 return(MAGICK_SSIZE_MIN);
160 if (value > ((
double) MAGICK_SSIZE_MAX))
163 return(MAGICK_SSIZE_MAX);
165 return((ssize_t) value);
168static inline unsigned int CastDoubleToUInt(
const double x)
178 value=(x < 0.0) ? ceil(x) : floor(x);
184 if (value > ((
double) MAGICK_UINT_MAX))
187 return(MAGICK_UINT_MAX);
189 return((
unsigned int) value);
192static inline unsigned short CastDoubleToUShort(
const double x)
202 value=(x < 0.0) ? ceil(x) : floor(x);
208 if (value > ((
double) MAGICK_USHORT_MAX))
211 return(MAGICK_USHORT_MAX);
213 return((
unsigned short) value);
216static inline double DegreesToRadians(
const double degrees)
218 return((
double) (MagickPI*degrees/180.0));
221static inline size_t GetImageChannels(
const Image *image)
230 for (i=0; i < (ssize_t) GetPixelChannels(image); i++)
232 PixelChannel channel = GetPixelChannelChannel(image,i);
233 PixelTrait traits = GetPixelChannelTraits(image,channel);
234 if ((traits & UpdatePixelTrait) != 0)
237 return(channels == 0 ? (
size_t) 1 : channels);
240static inline double RadiansToDegrees(
const double radians)
242 return((
double) (180.0*radians/MagickPI));
245static inline unsigned char ScaleColor5to8(
const unsigned int color)
247 return((
unsigned char) (((color) << 3) | ((color) >> 2)));
250static inline unsigned char ScaleColor6to8(
const unsigned int color)
252 return((
unsigned char) (((color) << 2) | ((color) >> 4)));
255static inline unsigned int ScaleColor8to5(
const unsigned char color)
257 return((
unsigned int) (((color) & ~0x07) >> 3));
260static inline unsigned int ScaleColor8to6(
const unsigned char color)
262 return((
unsigned int) (((color) & ~0x03) >> 2));
265#if defined(__cplusplus) || defined(c_plusplus)