quantum.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. /*
  2. Copyright 1999 ImageMagick Studio LLC, a non-profit organization
  3. dedicated to making software imaging solutions freely available.
  4. You may not use this file except in compliance with the License. You may
  5. obtain a copy of the License at
  6. https://imagemagick.org/script/license.php
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. MagickCore quantum inline methods.
  13. */
  14. #ifndef MAGICKCORE_QUANTUM_H
  15. #define MAGICKCORE_QUANTUM_H
  16. #include <float.h>
  17. #include "magick/image.h"
  18. #include "magick/semaphore.h"
  19. #if defined(__cplusplus) || defined(c_plusplus)
  20. extern "C" {
  21. #endif
  22. #define RoundToQuantum(quantum) ClampToQuantum(quantum)
  23. typedef enum
  24. {
  25. UndefinedEndian,
  26. LSBEndian,
  27. MSBEndian
  28. } EndianType;
  29. typedef enum
  30. {
  31. UndefinedQuantumAlpha,
  32. AssociatedQuantumAlpha,
  33. DisassociatedQuantumAlpha
  34. } QuantumAlphaType;
  35. typedef enum
  36. {
  37. UndefinedQuantumFormat,
  38. FloatingPointQuantumFormat,
  39. SignedQuantumFormat,
  40. UnsignedQuantumFormat
  41. } QuantumFormatType;
  42. typedef enum
  43. {
  44. UndefinedQuantum,
  45. AlphaQuantum,
  46. BlackQuantum,
  47. BlueQuantum,
  48. CMYKAQuantum,
  49. CMYKQuantum,
  50. CyanQuantum,
  51. GrayAlphaQuantum,
  52. GrayQuantum,
  53. GreenQuantum,
  54. IndexAlphaQuantum,
  55. IndexQuantum,
  56. MagentaQuantum,
  57. OpacityQuantum,
  58. RedQuantum,
  59. RGBAQuantum,
  60. BGRAQuantum,
  61. RGBOQuantum,
  62. RGBQuantum,
  63. YellowQuantum,
  64. GrayPadQuantum, /* deprecated */
  65. RGBPadQuantum,
  66. CbYCrYQuantum,
  67. CbYCrQuantum,
  68. CbYCrAQuantum,
  69. CMYKOQuantum,
  70. BGRQuantum,
  71. BGROQuantum
  72. } QuantumType;
  73. typedef struct _QuantumInfo
  74. QuantumInfo;
  75. static inline Quantum ClampToQuantum(const MagickRealType quantum)
  76. {
  77. #if defined(MAGICKCORE_HDRI_SUPPORT)
  78. return((Quantum) quantum);
  79. #else
  80. if ((IsNaN(quantum) != 0) || (quantum <= 0.0))
  81. return((Quantum) 0);
  82. if (quantum >= (MagickRealType) QuantumRange)
  83. return(QuantumRange);
  84. return((Quantum) (quantum+0.5));
  85. #endif
  86. }
  87. #if (MAGICKCORE_QUANTUM_DEPTH == 8)
  88. static inline unsigned char ScaleQuantumToChar(const Quantum quantum)
  89. {
  90. #if !defined(MAGICKCORE_HDRI_SUPPORT)
  91. return((unsigned char) quantum);
  92. #else
  93. if ((IsNaN(quantum) != 0) || (quantum <= 0.0f))
  94. return(0);
  95. if (quantum >= 255.0)
  96. return(255);
  97. return((unsigned char) (quantum+0.5f));
  98. #endif
  99. }
  100. #elif (MAGICKCORE_QUANTUM_DEPTH == 16)
  101. static inline unsigned char ScaleQuantumToChar(const Quantum quantum)
  102. {
  103. #if !defined(MAGICKCORE_HDRI_SUPPORT)
  104. return((unsigned char) (((quantum+128UL)-((quantum+128UL) >> 8)) >> 8));
  105. #else
  106. if ((IsNaN(quantum) != 0) || (quantum <= 0.0f))
  107. return(0);
  108. if ((quantum/257.0f) >= 255.0f)
  109. return(255);
  110. return((unsigned char) (quantum/257.0f+0.5f));
  111. #endif
  112. }
  113. #elif (MAGICKCORE_QUANTUM_DEPTH == 32)
  114. static inline unsigned char ScaleQuantumToChar(const Quantum quantum)
  115. {
  116. #if !defined(MAGICKCORE_HDRI_SUPPORT)
  117. return((unsigned char) ((quantum+MagickULLConstant(8421504))/
  118. MagickULLConstant(16843009)));
  119. #else
  120. if ((IsNaN(quantum) != 0) || (quantum <= 0.0))
  121. return(0);
  122. if ((quantum/16843009.0) >= 255.0)
  123. return(255);
  124. return((unsigned char) (quantum/16843009.0+0.5));
  125. #endif
  126. }
  127. #elif (MAGICKCORE_QUANTUM_DEPTH == 64)
  128. static inline unsigned char ScaleQuantumToChar(const Quantum quantum)
  129. {
  130. #if !defined(MAGICKCORE_HDRI_SUPPORT)
  131. return((unsigned char) (quantum/72340172838076673.0+0.5));
  132. #else
  133. if ((IsNaN(quantum) != 0) || (quantum <= 0.0))
  134. return(0);
  135. if ((quantum/72340172838076673.0) >= 255.0)
  136. return(255);
  137. return((unsigned char) (quantum/72340172838076673.0+0.5));
  138. #endif
  139. }
  140. #endif
  141. extern MagickExport EndianType
  142. GetQuantumEndian(const QuantumInfo *);
  143. extern MagickExport MagickBooleanType
  144. SetQuantumDepth(const Image *,QuantumInfo *,const size_t),
  145. SetQuantumEndian(const Image *,QuantumInfo *,const EndianType),
  146. SetQuantumFormat(const Image *,QuantumInfo *,const QuantumFormatType),
  147. SetQuantumPad(const Image *,QuantumInfo *,const size_t);
  148. extern MagickExport QuantumFormatType
  149. GetQuantumFormat(const QuantumInfo *);
  150. extern MagickExport QuantumInfo
  151. *AcquireQuantumInfo(const ImageInfo *,Image *),
  152. *DestroyQuantumInfo(QuantumInfo *);
  153. extern MagickExport QuantumType
  154. GetQuantumType(Image *,ExceptionInfo *);
  155. extern MagickExport size_t
  156. ExportQuantumPixels(const Image *,const CacheView *,const QuantumInfo *,
  157. const QuantumType,unsigned char *magick_restrict,ExceptionInfo *),
  158. GetQuantumExtent(const Image *,const QuantumInfo *,const QuantumType),
  159. ImportQuantumPixels(Image *,CacheView *,const QuantumInfo *,const QuantumType,
  160. const unsigned char *magick_restrict,ExceptionInfo *);
  161. extern MagickExport unsigned char
  162. *GetQuantumPixels(const QuantumInfo *);
  163. extern MagickExport void
  164. GetQuantumInfo(const ImageInfo *,QuantumInfo *),
  165. SetQuantumAlphaType(QuantumInfo *,const QuantumAlphaType),
  166. SetQuantumImageType(Image *,const QuantumType),
  167. SetQuantumMinIsWhite(QuantumInfo *,const MagickBooleanType),
  168. SetQuantumPack(QuantumInfo *,const MagickBooleanType),
  169. SetQuantumQuantum(QuantumInfo *,const size_t),
  170. SetQuantumScale(QuantumInfo *,const double);
  171. #if defined(__cplusplus) || defined(c_plusplus)
  172. }
  173. #endif
  174. #endif