gem.h 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  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 private graphic gems methods.
  13. */
  14. #ifndef MAGICKCORE_GEM_H
  15. #define MAGICKCORE_GEM_H
  16. #include "magick/random_.h"
  17. #include "magick/visual-effects.h"
  18. #if defined(__cplusplus) || defined(c_plusplus)
  19. extern "C" {
  20. #endif
  21. extern MagickExport double
  22. ExpandAffine(const AffineMatrix *) magick_attribute((__pure__)),
  23. GenerateDifferentialNoise(RandomInfo *,const Quantum,const NoiseType,
  24. const MagickRealType);
  25. extern MagickExport size_t
  26. GetOptimalKernelWidth(const double,const double),
  27. GetOptimalKernelWidth1D(const double,const double),
  28. GetOptimalKernelWidth2D(const double,const double);
  29. extern MagickExport void
  30. ConvertHCLToRGB(const double,const double,const double,Quantum *,Quantum *,
  31. Quantum *),
  32. ConvertHCLpToRGB(const double,const double,const double,Quantum *,Quantum *,
  33. Quantum *),
  34. ConvertHSBToRGB(const double,const double,const double,Quantum *,Quantum *,
  35. Quantum *),
  36. ConvertHSIToRGB(const double,const double,const double,Quantum *,Quantum *,
  37. Quantum *),
  38. ConvertHSLToRGB(const double,const double,const double,Quantum *,Quantum *,
  39. Quantum *),
  40. ConvertHSVToRGB(const double,const double,const double,Quantum *,Quantum *,
  41. Quantum *),
  42. ConvertHWBToRGB(const double,const double,const double,Quantum *,Quantum *,
  43. Quantum *),
  44. ConvertLCHabToRGB(const double,const double,const double,Quantum *,Quantum *,
  45. Quantum *),
  46. ConvertLCHuvToRGB(const double,const double,const double,Quantum *,Quantum *,
  47. Quantum *),
  48. ConvertRGBToHCL(const Quantum,const Quantum,const Quantum,double *,double *,
  49. double *),
  50. ConvertRGBToHCLp(const Quantum,const Quantum,const Quantum,double *,double *,
  51. double *),
  52. ConvertRGBToHSB(const Quantum,const Quantum,const Quantum,double *,double *,
  53. double *),
  54. ConvertRGBToHSI(const Quantum,const Quantum,const Quantum,double *,double *,
  55. double *),
  56. ConvertRGBToHSL(const Quantum,const Quantum,const Quantum,double *,double *,
  57. double *),
  58. ConvertRGBToHSV(const Quantum,const Quantum,const Quantum,double *,double *,
  59. double *),
  60. ConvertRGBToHWB(const Quantum,const Quantum,const Quantum,double *,double *,
  61. double *),
  62. ConvertRGBToLCHab(const Quantum,const Quantum,const Quantum,double *,double *,
  63. double *),
  64. ConvertRGBToLCHuv(const Quantum,const Quantum,const Quantum,double *,double *,
  65. double *);
  66. #if defined(__cplusplus) || defined(c_plusplus)
  67. }
  68. #endif
  69. #endif