pixel-private.h

Go to the documentation of this file.
00001 /*
00002   Copyright 1999-2008 ImageMagick Studio LLC, a non-profit organization
00003   dedicated to making software imaging solutions freely available.
00004   
00005   You may not use this file except in compliance with the License.
00006   obtain a copy of the License at
00007   
00008     http://www.imagemagick.org/script/license.php
00009   
00010   Unless required by applicable law or agreed to in writing, software
00011   distributed under the License is distributed on an "AS IS" BASIS,
00012   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00013   See the License for the specific language governing permissions and
00014   limitations under the License.
00015 
00016   MagickCore image pixel private methods.
00017 */
00018 #ifndef _MAGICKCORE_PIXEL_PRIVATE_H
00019 #define _MAGICKCORE_PIXEL_PRIVATE_H
00020 
00021 #if defined(__cplusplus) || defined(c_plusplus)
00022 extern "C" {
00023 #endif
00024 
00025 #include <magick/exception-private.h>
00026 #include <magick/image.h>
00027 #include <magick/color.h>
00028 #include <magick/image-private.h>
00029 #include <magick/quantum-private.h>
00030 
00031 static inline MagickPixelPacket *CloneMagickPixelPacket(
00032   const MagickPixelPacket *pixel)
00033 {
00034   MagickPixelPacket
00035     *clone_pixel;
00036 
00037   clone_pixel=(MagickPixelPacket *) AcquireMagickMemory(sizeof(*clone_pixel));
00038   if (clone_pixel == (MagickPixelPacket *) NULL)
00039     ThrowFatalException(ResourceLimitFatalError,"MemoryAllocationFailed");
00040   *clone_pixel=(*pixel);
00041   return(clone_pixel);
00042 }
00043 
00044 static inline MagickBooleanType IsGrayPixel(const PixelPacket *pixel)
00045 {
00046 #if !defined(MAGICKCORE_HDRI_SUPPORT)
00047   if ((pixel->red == pixel->green) && (pixel->green == pixel->blue))
00048     return(MagickTrue);
00049 #else
00050   if ((fabs(pixel->red-pixel->green) <= MagickEpsilon) &&
00051       (fabs(pixel->green-pixel->blue) <= MagickEpsilon))
00052     return(MagickTrue);
00053 #endif
00054   return(MagickFalse);
00055 }
00056 
00057 static inline MagickBooleanType IsMonochromePixel(const PixelPacket *pixel)
00058 {
00059 #if !defined(MAGICKCORE_HDRI_SUPPORT)
00060   if (((pixel->red == 0) || (pixel->red == (Quantum) QuantumRange)) &&
00061       (pixel->red == pixel->green) && (pixel->green == pixel->blue))
00062     return(MagickTrue);
00063 #else
00064   if (((fabs(pixel->red) <= MagickEpsilon) ||
00065        (fabs(pixel->red-QuantumRange) <= MagickEpsilon)) &&
00066       (fabs(pixel->red-pixel->green) <= MagickEpsilon) &&
00067       (fabs(pixel->green-pixel->blue) <= MagickEpsilon))
00068     return(MagickTrue);
00069 #endif
00070   return(MagickFalse);
00071 }
00072 
00073 static inline void SetMagickPixelPacket(const Image *image,
00074   const PixelPacket *color,const IndexPacket *index,MagickPixelPacket *pixel)
00075 {
00076   pixel->red=(MagickRealType) color->red;
00077   pixel->green=(MagickRealType) color->green;
00078   pixel->blue=(MagickRealType) color->blue;
00079   pixel->opacity=(MagickRealType) color->opacity;
00080   if (((image->colorspace == CMYKColorspace) ||
00081        (image->storage_class == PseudoClass)) &&
00082       (index != (const IndexPacket *) NULL))
00083     pixel->index=(MagickRealType) *index;
00084 }
00085 
00086 static inline void SetPixelPacket(const Image *image,
00087   const MagickPixelPacket *pixel,PixelPacket *color,IndexPacket *index)
00088 {
00089   color->red=RoundToQuantum(pixel->red);
00090   color->green=RoundToQuantum(pixel->green);
00091   color->blue=RoundToQuantum(pixel->blue);
00092   color->opacity=RoundToQuantum(pixel->opacity);
00093   if (((image->colorspace == CMYKColorspace) ||
00094        (image->storage_class == PseudoClass)) &&
00095       (index != (const IndexPacket *) NULL))
00096     *index=RoundToQuantum(pixel->index);
00097 }
00098 
00099 #if defined(__cplusplus) || defined(c_plusplus)
00100 }
00101 #endif
00102 
00103 #endif

Generated on Sat Nov 22 23:45:17 2008 for MagickCore by  doxygen 1.5.7.1