1 // ==========================================================
\r
4 // Design and implementation by
\r
5 // - Floris van den Berg (flvdberg@wxs.nl)
\r
6 // - Hervé Drolon (drolon@infonie.fr)
\r
9 // - Adam Gates (radad@xoasis.com)
\r
11 // - Alexander Dymerets (sashad@te.net.ua)
\r
12 // - Detlev Vendt (detlev.vendt@brillit.de)
\r
13 // - Jan L. Nauta (jln@magentammt.com)
\r
14 // - Jani Kajala (janik@remedy.fi)
\r
15 // - Juergen Riecker (j.riecker@gmx.de)
\r
16 // - Karl-Heinz Bussian (khbussian@moss.de)
\r
17 // - Laurent Rocher (rocherl@club-internet.fr)
\r
18 // - Luca Piergentili (l.pierge@terra.es)
\r
19 // - Machiel ten Brinke (brinkem@uni-one.nl)
\r
20 // - Markus Loibl (markus.loibl@epost.de)
\r
21 // - Martin Weber (martweb@gmx.net)
\r
22 // - Matthias Wandel (mwandel@rim.net)
\r
23 // - Michal Novotny (michal@etc.cz)
\r
24 // - Petr Pytelka (pyta@lightcomp.com)
\r
25 // - Riley McNiff (rmcniff@marexgroup.com)
\r
26 // - Ryan Rubley (ryan@lostreality.org)
\r
27 // - Volker Gärtner (volkerg@gmx.at)
\r
29 // This file is part of FreeImage 3
\r
31 // COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY
\r
32 // OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES
\r
33 // THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE
\r
34 // OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED
\r
35 // CODE IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT
\r
36 // THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY
\r
37 // SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL
\r
38 // PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER
\r
41 // Use at your own risk!
\r
42 // ==========================================================
\r
47 // Version information ------------------------------------------------------
\r
49 #define FREEIMAGE_MAJOR_VERSION 3
\r
50 #define FREEIMAGE_MINOR_VERSION 13
\r
51 #define FREEIMAGE_RELEASE_SERIAL 1
\r
53 // Compiler options ---------------------------------------------------------
\r
55 #include <wchar.h> // needed for UNICODE functions
\r
57 #if defined(FREEIMAGE_LIB)
\r
59 #define DLL_CALLCONV
\r
61 #if defined(_WIN32) || defined(__WIN32__)
\r
62 #define DLL_CALLCONV __stdcall
\r
63 // The following ifdef block is the standard way of creating macros which make exporting
\r
64 // from a DLL simpler. All files within this DLL are compiled with the FREEIMAGE_EXPORTS
\r
65 // symbol defined on the command line. this symbol should not be defined on any project
\r
66 // that uses this DLL. This way any other project whose source files include this file see
\r
67 // DLL_API functions as being imported from a DLL, wheras this DLL sees symbols
\r
68 // defined with this macro as being exported.
\r
69 #ifdef FREEIMAGE_EXPORTS
\r
70 #define DLL_API __declspec(dllexport)
\r
72 #define DLL_API __declspec(dllimport)
\r
73 #endif // FREEIMAGE_EXPORTS
\r
75 // try the gcc visibility support (see http://gcc.gnu.org/wiki/Visibility)
\r
76 #if defined(__GNUC__) && ((__GNUC__ >= 4) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
\r
77 #ifndef GCC_HASCLASSVISIBILITY
\r
78 #define GCC_HASCLASSVISIBILITY
\r
81 #define DLL_CALLCONV
\r
82 #if defined(GCC_HASCLASSVISIBILITY)
\r
83 #define DLL_API __attribute__ ((visibility("default")))
\r
87 #endif // WIN32 / !WIN32
\r
88 #endif // FREEIMAGE_LIB
\r
90 // Some versions of gcc may have BYTE_ORDER or __BYTE_ORDER defined
\r
91 // If your big endian system isn't being detected, add an OS specific check
\r
92 #if (defined(BYTE_ORDER) && BYTE_ORDER==BIG_ENDIAN) || \
\r
93 (defined(__BYTE_ORDER) && __BYTE_ORDER==__BIG_ENDIAN) || \
\r
94 defined(__BIG_ENDIAN__)
\r
95 #define FREEIMAGE_BIGENDIAN
\r
96 #endif // BYTE_ORDER
\r
98 // This really only affects 24 and 32 bit formats, the rest are always RGB order.
\r
99 #define FREEIMAGE_COLORORDER_BGR 0
\r
100 #define FREEIMAGE_COLORORDER_RGB 1
\r
101 #if defined(FREEIMAGE_BIGENDIAN)
\r
102 #define FREEIMAGE_COLORORDER FREEIMAGE_COLORORDER_RGB
\r
104 #define FREEIMAGE_COLORORDER FREEIMAGE_COLORORDER_BGR
\r
107 // Ensure 4-byte enums if we're using Borland C++ compilers
\r
108 #if defined(__BORLANDC__)
\r
109 #pragma option push -b
\r
112 // For C compatibility --------------------------------------------------------
\r
115 #define FI_DEFAULT(x) = x
\r
116 #define FI_ENUM(x) enum x
\r
117 #define FI_STRUCT(x) struct x
\r
119 #define FI_DEFAULT(x)
\r
120 #define FI_ENUM(x) typedef int x; enum x
\r
121 #define FI_STRUCT(x) typedef struct x x; struct x
\r
124 // Bitmap types -------------------------------------------------------------
\r
126 FI_STRUCT (FIBITMAP) { void *data; };
\r
127 FI_STRUCT (FIMULTIBITMAP) { void *data; };
\r
129 // Types used in the library (directly copied from Windows) -----------------
\r
131 #if defined(__MINGW32__) && defined(_WINDOWS_H)
\r
132 #define _WINDOWS_ // prevent a bug in MinGW32
\r
133 #endif // __MINGW32__
\r
155 // define portable types for 32-bit / 64-bit OS
\r
156 #include <inttypes.h>
\r
157 typedef int32_t BOOL;
\r
158 typedef uint8_t BYTE;
\r
159 typedef uint16_t WORD;
\r
160 typedef uint32_t DWORD;
\r
161 typedef int32_t LONG;
\r
163 // MS is not C99 ISO compliant
\r
165 typedef unsigned char BYTE;
\r
166 typedef unsigned short WORD;
\r
167 typedef unsigned long DWORD;
\r
171 #if (defined(_WIN32) || defined(__WIN32__))
\r
172 #pragma pack(push, 1)
\r
177 typedef struct tagRGBQUAD {
\r
178 #if FREEIMAGE_COLORORDER == FREEIMAGE_COLORORDER_BGR
\r
186 #endif // FREEIMAGE_COLORORDER
\r
190 typedef struct tagRGBTRIPLE {
\r
191 #if FREEIMAGE_COLORORDER == FREEIMAGE_COLORORDER_BGR
\r
199 #endif // FREEIMAGE_COLORORDER
\r
202 #if (defined(_WIN32) || defined(__WIN32__))
\r
208 typedef struct tagBITMAPINFOHEADER{
\r
214 DWORD biCompression;
\r
215 DWORD biSizeImage;
\r
216 LONG biXPelsPerMeter;
\r
217 LONG biYPelsPerMeter;
\r
219 DWORD biClrImportant;
\r
220 } BITMAPINFOHEADER, *PBITMAPINFOHEADER;
\r
222 typedef struct tagBITMAPINFO {
\r
223 BITMAPINFOHEADER bmiHeader;
\r
224 RGBQUAD bmiColors[1];
\r
225 } BITMAPINFO, *PBITMAPINFO;
\r
227 #endif // _WINDOWS_
\r
229 // Types used in the library (specific to FreeImage) ------------------------
\r
231 #if (defined(_WIN32) || defined(__WIN32__))
\r
232 #pragma pack(push, 1)
\r
239 typedef struct tagFIRGB16 {
\r
247 typedef struct tagFIRGBA16 {
\r
254 /** 96-bit RGB Float
\r
256 typedef struct tagFIRGBF {
\r
262 /** 128-bit RGBA Float
\r
264 typedef struct tagFIRGBAF {
\r
271 /** Data structure for COMPLEX type (complex number)
\r
273 typedef struct tagFICOMPLEX {
\r
280 #if (defined(_WIN32) || defined(__WIN32__))
\r
286 // Indexes for byte arrays, masks and shifts for treating pixels as words ---
\r
287 // These coincide with the order of RGBQUAD and RGBTRIPLE -------------------
\r
289 #ifndef FREEIMAGE_BIGENDIAN
\r
290 #if FREEIMAGE_COLORORDER == FREEIMAGE_COLORORDER_BGR
\r
291 // Little Endian (x86 / MS Windows, Linux) : BGR(A) order
\r
292 #define FI_RGBA_RED 2
\r
293 #define FI_RGBA_GREEN 1
\r
294 #define FI_RGBA_BLUE 0
\r
295 #define FI_RGBA_ALPHA 3
\r
296 #define FI_RGBA_RED_MASK 0x00FF0000
\r
297 #define FI_RGBA_GREEN_MASK 0x0000FF00
\r
298 #define FI_RGBA_BLUE_MASK 0x000000FF
\r
299 #define FI_RGBA_ALPHA_MASK 0xFF000000
\r
300 #define FI_RGBA_RED_SHIFT 16
\r
301 #define FI_RGBA_GREEN_SHIFT 8
\r
302 #define FI_RGBA_BLUE_SHIFT 0
\r
303 #define FI_RGBA_ALPHA_SHIFT 24
\r
305 // Little Endian (x86 / MaxOSX) : RGB(A) order
\r
306 #define FI_RGBA_RED 0
\r
307 #define FI_RGBA_GREEN 1
\r
308 #define FI_RGBA_BLUE 2
\r
309 #define FI_RGBA_ALPHA 3
\r
310 #define FI_RGBA_RED_MASK 0x000000FF
\r
311 #define FI_RGBA_GREEN_MASK 0x0000FF00
\r
312 #define FI_RGBA_BLUE_MASK 0x00FF0000
\r
313 #define FI_RGBA_ALPHA_MASK 0xFF000000
\r
314 #define FI_RGBA_RED_SHIFT 0
\r
315 #define FI_RGBA_GREEN_SHIFT 8
\r
316 #define FI_RGBA_BLUE_SHIFT 16
\r
317 #define FI_RGBA_ALPHA_SHIFT 24
\r
318 #endif // FREEIMAGE_COLORORDER
\r
320 #if FREEIMAGE_COLORORDER == FREEIMAGE_COLORORDER_BGR
\r
321 // Big Endian (PPC / none) : BGR(A) order
\r
322 #define FI_RGBA_RED 2
\r
323 #define FI_RGBA_GREEN 1
\r
324 #define FI_RGBA_BLUE 0
\r
325 #define FI_RGBA_ALPHA 3
\r
326 #define FI_RGBA_RED_MASK 0x0000FF00
\r
327 #define FI_RGBA_GREEN_MASK 0x00FF0000
\r
328 #define FI_RGBA_BLUE_MASK 0xFF000000
\r
329 #define FI_RGBA_ALPHA_MASK 0x000000FF
\r
330 #define FI_RGBA_RED_SHIFT 8
\r
331 #define FI_RGBA_GREEN_SHIFT 16
\r
332 #define FI_RGBA_BLUE_SHIFT 24
\r
333 #define FI_RGBA_ALPHA_SHIFT 0
\r
335 // Big Endian (PPC / Linux, MaxOSX) : RGB(A) order
\r
336 #define FI_RGBA_RED 0
\r
337 #define FI_RGBA_GREEN 1
\r
338 #define FI_RGBA_BLUE 2
\r
339 #define FI_RGBA_ALPHA 3
\r
340 #define FI_RGBA_RED_MASK 0xFF000000
\r
341 #define FI_RGBA_GREEN_MASK 0x00FF0000
\r
342 #define FI_RGBA_BLUE_MASK 0x0000FF00
\r
343 #define FI_RGBA_ALPHA_MASK 0x000000FF
\r
344 #define FI_RGBA_RED_SHIFT 24
\r
345 #define FI_RGBA_GREEN_SHIFT 16
\r
346 #define FI_RGBA_BLUE_SHIFT 8
\r
347 #define FI_RGBA_ALPHA_SHIFT 0
\r
348 #endif // FREEIMAGE_COLORORDER
\r
349 #endif // FREEIMAGE_BIGENDIAN
\r
351 #define FI_RGBA_RGB_MASK (FI_RGBA_RED_MASK|FI_RGBA_GREEN_MASK|FI_RGBA_BLUE_MASK)
\r
353 // The 16bit macros only include masks and shifts, since each color element is not byte aligned
\r
355 #define FI16_555_RED_MASK 0x7C00
\r
356 #define FI16_555_GREEN_MASK 0x03E0
\r
357 #define FI16_555_BLUE_MASK 0x001F
\r
358 #define FI16_555_RED_SHIFT 10
\r
359 #define FI16_555_GREEN_SHIFT 5
\r
360 #define FI16_555_BLUE_SHIFT 0
\r
361 #define FI16_565_RED_MASK 0xF800
\r
362 #define FI16_565_GREEN_MASK 0x07E0
\r
363 #define FI16_565_BLUE_MASK 0x001F
\r
364 #define FI16_565_RED_SHIFT 11
\r
365 #define FI16_565_GREEN_SHIFT 5
\r
366 #define FI16_565_BLUE_SHIFT 0
\r
368 // ICC profile support ------------------------------------------------------
\r
370 #define FIICC_DEFAULT 0x00
\r
371 #define FIICC_COLOR_IS_CMYK 0x01
\r
373 FI_STRUCT (FIICCPROFILE) {
\r
374 WORD flags; // info flag
\r
375 DWORD size; // profile's size measured in bytes
\r
376 void *data; // points to a block of contiguous memory containing the profile
\r
379 // Important enums ----------------------------------------------------------
\r
381 /** I/O image format identifiers.
\r
383 FI_ENUM(FREE_IMAGE_FORMAT) {
\r
423 /** Image type used in FreeImage.
\r
425 FI_ENUM(FREE_IMAGE_TYPE) {
\r
426 FIT_UNKNOWN = 0, // unknown type
\r
427 FIT_BITMAP = 1, // standard image : 1-, 4-, 8-, 16-, 24-, 32-bit
\r
428 FIT_UINT16 = 2, // array of unsigned short : unsigned 16-bit
\r
429 FIT_INT16 = 3, // array of short : signed 16-bit
\r
430 FIT_UINT32 = 4, // array of unsigned long : unsigned 32-bit
\r
431 FIT_INT32 = 5, // array of long : signed 32-bit
\r
432 FIT_FLOAT = 6, // array of float : 32-bit IEEE floating point
\r
433 FIT_DOUBLE = 7, // array of double : 64-bit IEEE floating point
\r
434 FIT_COMPLEX = 8, // array of FICOMPLEX : 2 x 64-bit IEEE floating point
\r
435 FIT_RGB16 = 9, // 48-bit RGB image : 3 x 16-bit
\r
436 FIT_RGBA16 = 10, // 64-bit RGBA image : 4 x 16-bit
\r
437 FIT_RGBF = 11, // 96-bit RGB float image : 3 x 32-bit IEEE floating point
\r
438 FIT_RGBAF = 12 // 128-bit RGBA float image : 4 x 32-bit IEEE floating point
\r
441 /** Image color type used in FreeImage.
\r
443 FI_ENUM(FREE_IMAGE_COLOR_TYPE) {
\r
444 FIC_MINISWHITE = 0, // min value is white
\r
445 FIC_MINISBLACK = 1, // min value is black
\r
446 FIC_RGB = 2, // RGB color model
\r
447 FIC_PALETTE = 3, // color map indexed
\r
448 FIC_RGBALPHA = 4, // RGB color model with alpha channel
\r
449 FIC_CMYK = 5 // CMYK color model
\r
452 /** Color quantization algorithms.
\r
453 Constants used in FreeImage_ColorQuantize.
\r
455 FI_ENUM(FREE_IMAGE_QUANTIZE) {
\r
456 FIQ_WUQUANT = 0, // Xiaolin Wu color quantization algorithm
\r
457 FIQ_NNQUANT = 1 // NeuQuant neural-net quantization algorithm by Anthony Dekker
\r
460 /** Dithering algorithms.
\r
461 Constants used in FreeImage_Dither.
\r
463 FI_ENUM(FREE_IMAGE_DITHER) {
\r
464 FID_FS = 0, // Floyd & Steinberg error diffusion
\r
465 FID_BAYER4x4 = 1, // Bayer ordered dispersed dot dithering (order 2 dithering matrix)
\r
466 FID_BAYER8x8 = 2, // Bayer ordered dispersed dot dithering (order 3 dithering matrix)
\r
467 FID_CLUSTER6x6 = 3, // Ordered clustered dot dithering (order 3 - 6x6 matrix)
\r
468 FID_CLUSTER8x8 = 4, // Ordered clustered dot dithering (order 4 - 8x8 matrix)
\r
469 FID_CLUSTER16x16= 5, // Ordered clustered dot dithering (order 8 - 16x16 matrix)
\r
470 FID_BAYER16x16 = 6 // Bayer ordered dispersed dot dithering (order 4 dithering matrix)
\r
473 /** Lossless JPEG transformations
\r
474 Constants used in FreeImage_JPEGTransform
\r
476 FI_ENUM(FREE_IMAGE_JPEG_OPERATION) {
\r
477 FIJPEG_OP_NONE = 0, // no transformation
\r
478 FIJPEG_OP_FLIP_H = 1, // horizontal flip
\r
479 FIJPEG_OP_FLIP_V = 2, // vertical flip
\r
480 FIJPEG_OP_TRANSPOSE = 3, // transpose across UL-to-LR axis
\r
481 FIJPEG_OP_TRANSVERSE = 4, // transpose across UR-to-LL axis
\r
482 FIJPEG_OP_ROTATE_90 = 5, // 90-degree clockwise rotation
\r
483 FIJPEG_OP_ROTATE_180 = 6, // 180-degree rotation
\r
484 FIJPEG_OP_ROTATE_270 = 7 // 270-degree clockwise (or 90 ccw)
\r
487 /** Tone mapping operators.
\r
488 Constants used in FreeImage_ToneMapping.
\r
490 FI_ENUM(FREE_IMAGE_TMO) {
\r
491 FITMO_DRAGO03 = 0, // Adaptive logarithmic mapping (F. Drago, 2003)
\r
492 FITMO_REINHARD05 = 1, // Dynamic range reduction inspired by photoreceptor physiology (E. Reinhard, 2005)
\r
493 FITMO_FATTAL02 = 2 // Gradient domain high dynamic range compression (R. Fattal, 2002)
\r
496 /** Upsampling / downsampling filters.
\r
497 Constants used in FreeImage_Rescale.
\r
499 FI_ENUM(FREE_IMAGE_FILTER) {
\r
500 FILTER_BOX = 0, // Box, pulse, Fourier window, 1st order (constant) b-spline
\r
501 FILTER_BICUBIC = 1, // Mitchell & Netravali's two-param cubic filter
\r
502 FILTER_BILINEAR = 2, // Bilinear filter
\r
503 FILTER_BSPLINE = 3, // 4th order (cubic) b-spline
\r
504 FILTER_CATMULLROM = 4, // Catmull-Rom spline, Overhauser spline
\r
505 FILTER_LANCZOS3 = 5 // Lanczos3 filter
\r
508 /** Color channels.
\r
509 Constants used in color manipulation routines.
\r
511 FI_ENUM(FREE_IMAGE_COLOR_CHANNEL) {
\r
512 FICC_RGB = 0, // Use red, green and blue channels
\r
513 FICC_RED = 1, // Use red channel
\r
514 FICC_GREEN = 2, // Use green channel
\r
515 FICC_BLUE = 3, // Use blue channel
\r
516 FICC_ALPHA = 4, // Use alpha channel
\r
517 FICC_BLACK = 5, // Use black channel
\r
518 FICC_REAL = 6, // Complex images: use real part
\r
519 FICC_IMAG = 7, // Complex images: use imaginary part
\r
520 FICC_MAG = 8, // Complex images: use magnitude
\r
521 FICC_PHASE = 9 // Complex images: use phase
\r
524 // Metadata support ---------------------------------------------------------
\r
527 Tag data type information (based on TIFF specifications)
\r
529 Note: RATIONALs are the ratio of two 32-bit integer values.
\r
531 FI_ENUM(FREE_IMAGE_MDTYPE) {
\r
532 FIDT_NOTYPE = 0, // placeholder
\r
533 FIDT_BYTE = 1, // 8-bit unsigned integer
\r
534 FIDT_ASCII = 2, // 8-bit bytes w/ last byte null
\r
535 FIDT_SHORT = 3, // 16-bit unsigned integer
\r
536 FIDT_LONG = 4, // 32-bit unsigned integer
\r
537 FIDT_RATIONAL = 5, // 64-bit unsigned fraction
\r
538 FIDT_SBYTE = 6, // 8-bit signed integer
\r
539 FIDT_UNDEFINED = 7, // 8-bit untyped data
\r
540 FIDT_SSHORT = 8, // 16-bit signed integer
\r
541 FIDT_SLONG = 9, // 32-bit signed integer
\r
542 FIDT_SRATIONAL = 10, // 64-bit signed fraction
\r
543 FIDT_FLOAT = 11, // 32-bit IEEE floating point
\r
544 FIDT_DOUBLE = 12, // 64-bit IEEE floating point
\r
545 FIDT_IFD = 13, // 32-bit unsigned integer (offset)
\r
546 FIDT_PALETTE = 14 // 32-bit RGBQUAD
\r
550 Metadata models supported by FreeImage
\r
552 FI_ENUM(FREE_IMAGE_MDMODEL) {
\r
554 FIMD_COMMENTS = 0, // single comment or keywords
\r
555 FIMD_EXIF_MAIN = 1, // Exif-TIFF metadata
\r
556 FIMD_EXIF_EXIF = 2, // Exif-specific metadata
\r
557 FIMD_EXIF_GPS = 3, // Exif GPS metadata
\r
558 FIMD_EXIF_MAKERNOTE = 4, // Exif maker note metadata
\r
559 FIMD_EXIF_INTEROP = 5, // Exif interoperability metadata
\r
560 FIMD_IPTC = 6, // IPTC/NAA metadata
\r
561 FIMD_XMP = 7, // Abobe XMP metadata
\r
562 FIMD_GEOTIFF = 8, // GeoTIFF metadata
\r
563 FIMD_ANIMATION = 9, // Animation metadata
\r
564 FIMD_CUSTOM = 10 // Used to attach other metadata types to a dib
\r
568 Handle to a metadata model
\r
570 FI_STRUCT (FIMETADATA) { void *data; };
\r
573 Handle to a FreeImage tag
\r
575 FI_STRUCT (FITAG) { void *data; };
\r
577 // File IO routines ---------------------------------------------------------
\r
579 #ifndef FREEIMAGE_IO
\r
580 #define FREEIMAGE_IO
\r
582 typedef void* fi_handle;
\r
583 typedef unsigned (DLL_CALLCONV *FI_ReadProc) (void *buffer, unsigned size, unsigned count, fi_handle handle);
\r
584 typedef unsigned (DLL_CALLCONV *FI_WriteProc) (void *buffer, unsigned size, unsigned count, fi_handle handle);
\r
585 typedef int (DLL_CALLCONV *FI_SeekProc) (fi_handle handle, long offset, int origin);
\r
586 typedef long (DLL_CALLCONV *FI_TellProc) (fi_handle handle);
\r
588 #if (defined(_WIN32) || defined(__WIN32__))
\r
589 #pragma pack(push, 1)
\r
594 FI_STRUCT(FreeImageIO) {
\r
595 FI_ReadProc read_proc; // pointer to the function used to read data
\r
596 FI_WriteProc write_proc; // pointer to the function used to write data
\r
597 FI_SeekProc seek_proc; // pointer to the function used to seek
\r
598 FI_TellProc tell_proc; // pointer to the function used to aquire the current position
\r
601 #if (defined(_WIN32) || defined(__WIN32__))
\r
608 Handle to a memory I/O stream
\r
610 FI_STRUCT (FIMEMORY) { void *data; };
\r
612 #endif // FREEIMAGE_IO
\r
614 // Plugin routines ----------------------------------------------------------
\r
619 typedef const char *(DLL_CALLCONV *FI_FormatProc)(void);
\r
620 typedef const char *(DLL_CALLCONV *FI_DescriptionProc)(void);
\r
621 typedef const char *(DLL_CALLCONV *FI_ExtensionListProc)(void);
\r
622 typedef const char *(DLL_CALLCONV *FI_RegExprProc)(void);
\r
623 typedef void *(DLL_CALLCONV *FI_OpenProc)(FreeImageIO *io, fi_handle handle, BOOL read);
\r
624 typedef void (DLL_CALLCONV *FI_CloseProc)(FreeImageIO *io, fi_handle handle, void *data);
\r
625 typedef int (DLL_CALLCONV *FI_PageCountProc)(FreeImageIO *io, fi_handle handle, void *data);
\r
626 typedef int (DLL_CALLCONV *FI_PageCapabilityProc)(FreeImageIO *io, fi_handle handle, void *data);
\r
627 typedef FIBITMAP *(DLL_CALLCONV *FI_LoadProc)(FreeImageIO *io, fi_handle handle, int page, int flags, void *data);
\r
628 typedef BOOL (DLL_CALLCONV *FI_SaveProc)(FreeImageIO *io, FIBITMAP *dib, fi_handle handle, int page, int flags, void *data);
\r
629 typedef BOOL (DLL_CALLCONV *FI_ValidateProc)(FreeImageIO *io, fi_handle handle);
\r
630 typedef const char *(DLL_CALLCONV *FI_MimeProc)(void);
\r
631 typedef BOOL (DLL_CALLCONV *FI_SupportsExportBPPProc)(int bpp);
\r
632 typedef BOOL (DLL_CALLCONV *FI_SupportsExportTypeProc)(FREE_IMAGE_TYPE type);
\r
633 typedef BOOL (DLL_CALLCONV *FI_SupportsICCProfilesProc)(void);
\r
635 FI_STRUCT (Plugin) {
\r
636 FI_FormatProc format_proc;
\r
637 FI_DescriptionProc description_proc;
\r
638 FI_ExtensionListProc extension_proc;
\r
639 FI_RegExprProc regexpr_proc;
\r
640 FI_OpenProc open_proc;
\r
641 FI_CloseProc close_proc;
\r
642 FI_PageCountProc pagecount_proc;
\r
643 FI_PageCapabilityProc pagecapability_proc;
\r
644 FI_LoadProc load_proc;
\r
645 FI_SaveProc save_proc;
\r
646 FI_ValidateProc validate_proc;
\r
647 FI_MimeProc mime_proc;
\r
648 FI_SupportsExportBPPProc supports_export_bpp_proc;
\r
649 FI_SupportsExportTypeProc supports_export_type_proc;
\r
650 FI_SupportsICCProfilesProc supports_icc_profiles_proc;
\r
653 typedef void (DLL_CALLCONV *FI_InitProc)(Plugin *plugin, int format_id);
\r
658 // Load / Save flag constants -----------------------------------------------
\r
660 #define BMP_DEFAULT 0
\r
661 #define BMP_SAVE_RLE 1
\r
662 #define CUT_DEFAULT 0
\r
663 #define DDS_DEFAULT 0
\r
664 #define EXR_DEFAULT 0 // save data as half with piz-based wavelet compression
\r
665 #define EXR_FLOAT 0x0001 // save data as float instead of as half (not recommended)
\r
666 #define EXR_NONE 0x0002 // save with no compression
\r
667 #define EXR_ZIP 0x0004 // save with zlib compression, in blocks of 16 scan lines
\r
668 #define EXR_PIZ 0x0008 // save with piz-based wavelet compression
\r
669 #define EXR_PXR24 0x0010 // save with lossy 24-bit float compression
\r
670 #define EXR_B44 0x0020 // save with lossy 44% float compression - goes to 22% when combined with EXR_LC
\r
671 #define EXR_LC 0x0040 // save images with one luminance and two chroma channels, rather than as RGB (lossy compression)
\r
672 #define FAXG3_DEFAULT 0
\r
673 #define GIF_DEFAULT 0
\r
674 #define GIF_LOAD256 1 // Load the image as a 256 color image with ununsed palette entries, if it's 16 or 2 color
\r
675 #define GIF_PLAYBACK 2 // 'Play' the GIF to generate each frame (as 32bpp) instead of returning raw frame data when loading
\r
676 #define HDR_DEFAULT 0
\r
677 #define ICO_DEFAULT 0
\r
678 #define ICO_MAKEALPHA 1 // convert to 32bpp and create an alpha channel from the AND-mask when loading
\r
679 #define IFF_DEFAULT 0
\r
680 #define J2K_DEFAULT 0 // save with a 16:1 rate
\r
681 #define JP2_DEFAULT 0 // save with a 16:1 rate
\r
682 #define JPEG_DEFAULT 0 // loading (see JPEG_FAST); saving (see JPEG_QUALITYGOOD|JPEG_SUBSAMPLING_420)
\r
683 #define JPEG_FAST 0x0001 // load the file as fast as possible, sacrificing some quality
\r
684 #define JPEG_ACCURATE 0x0002 // load the file with the best quality, sacrificing some speed
\r
685 #define JPEG_CMYK 0x0004 // load separated CMYK "as is" (use | to combine with other load flags)
\r
686 #define JPEG_EXIFROTATE 0x0008 // load and rotate according to Exif 'Orientation' tag if available
\r
687 #define JPEG_QUALITYSUPERB 0x80 // save with superb quality (100:1)
\r
688 #define JPEG_QUALITYGOOD 0x0100 // save with good quality (75:1)
\r
689 #define JPEG_QUALITYNORMAL 0x0200 // save with normal quality (50:1)
\r
690 #define JPEG_QUALITYAVERAGE 0x0400 // save with average quality (25:1)
\r
691 #define JPEG_QUALITYBAD 0x0800 // save with bad quality (10:1)
\r
692 #define JPEG_PROGRESSIVE 0x2000 // save as a progressive-JPEG (use | to combine with other save flags)
\r
693 #define JPEG_SUBSAMPLING_411 0x1000 // save with high 4x1 chroma subsampling (4:1:1)
\r
694 #define JPEG_SUBSAMPLING_420 0x4000 // save with medium 2x2 medium chroma subsampling (4:2:0) - default value
\r
695 #define JPEG_SUBSAMPLING_422 0x8000 // save with low 2x1 chroma subsampling (4:2:2)
\r
696 #define JPEG_SUBSAMPLING_444 0x10000 // save with no chroma subsampling (4:4:4)
\r
697 #define KOALA_DEFAULT 0
\r
698 #define LBM_DEFAULT 0
\r
699 #define MNG_DEFAULT 0
\r
700 #define PCD_DEFAULT 0
\r
701 #define PCD_BASE 1 // load the bitmap sized 768 x 512
\r
702 #define PCD_BASEDIV4 2 // load the bitmap sized 384 x 256
\r
703 #define PCD_BASEDIV16 3 // load the bitmap sized 192 x 128
\r
704 #define PCX_DEFAULT 0
\r
705 #define PFM_DEFAULT 0
\r
706 #define PICT_DEFAULT 0
\r
707 #define PNG_DEFAULT 0
\r
708 #define PNG_IGNOREGAMMA 1 // loading: avoid gamma correction
\r
709 #define PNG_Z_BEST_SPEED 0x0001 // save using ZLib level 1 compression flag (default value is 6)
\r
710 #define PNG_Z_DEFAULT_COMPRESSION 0x0006 // save using ZLib level 6 compression flag (default recommended value)
\r
711 #define PNG_Z_BEST_COMPRESSION 0x0009 // save using ZLib level 9 compression flag (default value is 6)
\r
712 #define PNG_Z_NO_COMPRESSION 0x0100 // save without ZLib compression
\r
713 #define PNG_INTERLACED 0x0200 // save using Adam7 interlacing (use | to combine with other save flags)
\r
714 #define PNM_DEFAULT 0
\r
715 #define PNM_SAVE_RAW 0 // If set the writer saves in RAW format (i.e. P4, P5 or P6)
\r
716 #define PNM_SAVE_ASCII 1 // If set the writer saves in ASCII format (i.e. P1, P2 or P3)
\r
717 #define PSD_DEFAULT 0
\r
718 #define RAS_DEFAULT 0
\r
719 #define RAW_DEFAULT 0 // load the file as linear RGB 48-bit
\r
720 #define RAW_PREVIEW 1 // try to load the embedded JPEG preview with included Exif Data or default to RGB 24-bit
\r
721 #define RAW_DISPLAY 2 // load the file as RGB 24-bit
\r
722 #define SGI_DEFAULT 0
\r
723 #define TARGA_DEFAULT 0
\r
724 #define TARGA_LOAD_RGB888 1 // If set the loader converts RGB555 and ARGB8888 -> RGB888.
\r
725 #define TIFF_DEFAULT 0
\r
726 #define TIFF_CMYK 0x0001 // reads/stores tags for separated CMYK (use | to combine with compression flags)
\r
727 #define TIFF_PACKBITS 0x0100 // save using PACKBITS compression
\r
728 #define TIFF_DEFLATE 0x0200 // save using DEFLATE compression (a.k.a. ZLIB compression)
\r
729 #define TIFF_ADOBE_DEFLATE 0x0400 // save using ADOBE DEFLATE compression
\r
730 #define TIFF_NONE 0x0800 // save without any compression
\r
731 #define TIFF_CCITTFAX3 0x1000 // save using CCITT Group 3 fax encoding
\r
732 #define TIFF_CCITTFAX4 0x2000 // save using CCITT Group 4 fax encoding
\r
733 #define TIFF_LZW 0x4000 // save using LZW compression
\r
734 #define TIFF_JPEG 0x8000 // save using JPEG compression
\r
735 #define WBMP_DEFAULT 0
\r
736 #define XBM_DEFAULT 0
\r
737 #define XPM_DEFAULT 0
\r
739 // Background filling options ---------------------------------------------------------
\r
740 // Constants used in FreeImage_FillBackground and FreeImage_EnlargeCanvas
\r
742 #define FI_COLOR_IS_RGB_COLOR 0x00 // RGBQUAD color is a RGB color (contains no valid alpha channel)
\r
743 #define FI_COLOR_IS_RGBA_COLOR 0x01 // RGBQUAD color is a RGBA color (contains a valid alpha channel)
\r
744 #define FI_COLOR_FIND_EQUAL_COLOR 0x02 // For palettized images: lookup equal RGB color from palette
\r
745 #define FI_COLOR_ALPHA_IS_INDEX 0x04 // The color's rgbReserved member (alpha) contains the palette index to be used
\r
746 #define FI_COLOR_PALETTE_SEARCH_MASK (FI_COLOR_FIND_EQUAL_COLOR | FI_COLOR_ALPHA_IS_INDEX) // No color lookup is performed
\r
753 // Init / Error routines ----------------------------------------------------
\r
755 DLL_API void DLL_CALLCONV FreeImage_Initialise(BOOL load_local_plugins_only FI_DEFAULT(FALSE));
\r
756 DLL_API void DLL_CALLCONV FreeImage_DeInitialise(void);
\r
758 // Version routines ---------------------------------------------------------
\r
760 DLL_API const char *DLL_CALLCONV FreeImage_GetVersion(void);
\r
761 DLL_API const char *DLL_CALLCONV FreeImage_GetCopyrightMessage(void);
\r
763 // Message output functions -------------------------------------------------
\r
765 typedef void (*FreeImage_OutputMessageFunction)(FREE_IMAGE_FORMAT fif, const char *msg);
\r
766 typedef void (DLL_CALLCONV *FreeImage_OutputMessageFunctionStdCall)(FREE_IMAGE_FORMAT fif, const char *msg);
\r
768 DLL_API void DLL_CALLCONV FreeImage_SetOutputMessageStdCall(FreeImage_OutputMessageFunctionStdCall omf);
\r
769 DLL_API void DLL_CALLCONV FreeImage_SetOutputMessage(FreeImage_OutputMessageFunction omf);
\r
770 DLL_API void DLL_CALLCONV FreeImage_OutputMessageProc(int fif, const char *fmt, ...);
\r
772 // Allocate / Clone / Unload routines ---------------------------------------
\r
774 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Allocate(int width, int height, int bpp, unsigned red_mask FI_DEFAULT(0), unsigned green_mask FI_DEFAULT(0), unsigned blue_mask FI_DEFAULT(0));
\r
775 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_AllocateT(FREE_IMAGE_TYPE type, int width, int height, int bpp FI_DEFAULT(8), unsigned red_mask FI_DEFAULT(0), unsigned green_mask FI_DEFAULT(0), unsigned blue_mask FI_DEFAULT(0));
\r
776 DLL_API FIBITMAP * DLL_CALLCONV FreeImage_Clone(FIBITMAP *dib);
\r
777 DLL_API void DLL_CALLCONV FreeImage_Unload(FIBITMAP *dib);
\r
779 // Load / Save routines -----------------------------------------------------
\r
781 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Load(FREE_IMAGE_FORMAT fif, const char *filename, int flags FI_DEFAULT(0));
\r
782 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_LoadU(FREE_IMAGE_FORMAT fif, const wchar_t *filename, int flags FI_DEFAULT(0));
\r
783 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_LoadFromHandle(FREE_IMAGE_FORMAT fif, FreeImageIO *io, fi_handle handle, int flags FI_DEFAULT(0));
\r
784 DLL_API BOOL DLL_CALLCONV FreeImage_Save(FREE_IMAGE_FORMAT fif, FIBITMAP *dib, const char *filename, int flags FI_DEFAULT(0));
\r
785 DLL_API BOOL DLL_CALLCONV FreeImage_SaveU(FREE_IMAGE_FORMAT fif, FIBITMAP *dib, const wchar_t *filename, int flags FI_DEFAULT(0));
\r
786 DLL_API BOOL DLL_CALLCONV FreeImage_SaveToHandle(FREE_IMAGE_FORMAT fif, FIBITMAP *dib, FreeImageIO *io, fi_handle handle, int flags FI_DEFAULT(0));
\r
788 // Memory I/O stream routines -----------------------------------------------
\r
790 DLL_API FIMEMORY *DLL_CALLCONV FreeImage_OpenMemory(BYTE *data FI_DEFAULT(0), DWORD size_in_bytes FI_DEFAULT(0));
\r
791 DLL_API void DLL_CALLCONV FreeImage_CloseMemory(FIMEMORY *stream);
\r
792 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_LoadFromMemory(FREE_IMAGE_FORMAT fif, FIMEMORY *stream, int flags FI_DEFAULT(0));
\r
793 DLL_API BOOL DLL_CALLCONV FreeImage_SaveToMemory(FREE_IMAGE_FORMAT fif, FIBITMAP *dib, FIMEMORY *stream, int flags FI_DEFAULT(0));
\r
794 DLL_API long DLL_CALLCONV FreeImage_TellMemory(FIMEMORY *stream);
\r
795 DLL_API BOOL DLL_CALLCONV FreeImage_SeekMemory(FIMEMORY *stream, long offset, int origin);
\r
796 DLL_API BOOL DLL_CALLCONV FreeImage_AcquireMemory(FIMEMORY *stream, BYTE **data, DWORD *size_in_bytes);
\r
797 DLL_API unsigned DLL_CALLCONV FreeImage_ReadMemory(void *buffer, unsigned size, unsigned count, FIMEMORY *stream);
\r
798 DLL_API unsigned DLL_CALLCONV FreeImage_WriteMemory(const void *buffer, unsigned size, unsigned count, FIMEMORY *stream);
\r
799 DLL_API FIMULTIBITMAP *DLL_CALLCONV FreeImage_LoadMultiBitmapFromMemory(FREE_IMAGE_FORMAT fif, FIMEMORY *stream, int flags FI_DEFAULT(0));
\r
801 // Plugin Interface ---------------------------------------------------------
\r
803 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_RegisterLocalPlugin(FI_InitProc proc_address, const char *format FI_DEFAULT(0), const char *description FI_DEFAULT(0), const char *extension FI_DEFAULT(0), const char *regexpr FI_DEFAULT(0));
\r
804 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_RegisterExternalPlugin(const char *path, const char *format FI_DEFAULT(0), const char *description FI_DEFAULT(0), const char *extension FI_DEFAULT(0), const char *regexpr FI_DEFAULT(0));
\r
805 DLL_API int DLL_CALLCONV FreeImage_GetFIFCount(void);
\r
806 DLL_API int DLL_CALLCONV FreeImage_SetPluginEnabled(FREE_IMAGE_FORMAT fif, BOOL enable);
\r
807 DLL_API int DLL_CALLCONV FreeImage_IsPluginEnabled(FREE_IMAGE_FORMAT fif);
\r
808 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFIFFromFormat(const char *format);
\r
809 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFIFFromMime(const char *mime);
\r
810 DLL_API const char *DLL_CALLCONV FreeImage_GetFormatFromFIF(FREE_IMAGE_FORMAT fif);
\r
811 DLL_API const char *DLL_CALLCONV FreeImage_GetFIFExtensionList(FREE_IMAGE_FORMAT fif);
\r
812 DLL_API const char *DLL_CALLCONV FreeImage_GetFIFDescription(FREE_IMAGE_FORMAT fif);
\r
813 DLL_API const char *DLL_CALLCONV FreeImage_GetFIFRegExpr(FREE_IMAGE_FORMAT fif);
\r
814 DLL_API const char *DLL_CALLCONV FreeImage_GetFIFMimeType(FREE_IMAGE_FORMAT fif);
\r
815 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFIFFromFilename(const char *filename);
\r
816 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFIFFromFilenameU(const wchar_t *filename);
\r
817 DLL_API BOOL DLL_CALLCONV FreeImage_FIFSupportsReading(FREE_IMAGE_FORMAT fif);
\r
818 DLL_API BOOL DLL_CALLCONV FreeImage_FIFSupportsWriting(FREE_IMAGE_FORMAT fif);
\r
819 DLL_API BOOL DLL_CALLCONV FreeImage_FIFSupportsExportBPP(FREE_IMAGE_FORMAT fif, int bpp);
\r
820 DLL_API BOOL DLL_CALLCONV FreeImage_FIFSupportsExportType(FREE_IMAGE_FORMAT fif, FREE_IMAGE_TYPE type);
\r
821 DLL_API BOOL DLL_CALLCONV FreeImage_FIFSupportsICCProfiles(FREE_IMAGE_FORMAT fif);
\r
823 // Multipaging interface ----------------------------------------------------
\r
825 DLL_API FIMULTIBITMAP * DLL_CALLCONV FreeImage_OpenMultiBitmap(FREE_IMAGE_FORMAT fif, const char *filename, BOOL create_new, BOOL read_only, BOOL keep_cache_in_memory FI_DEFAULT(FALSE), int flags FI_DEFAULT(0));
\r
826 DLL_API FIMULTIBITMAP * DLL_CALLCONV FreeImage_OpenMultiBitmapFromHandle(FREE_IMAGE_FORMAT fif, FreeImageIO *io, fi_handle handle, int flags FI_DEFAULT(0));
\r
827 DLL_API BOOL DLL_CALLCONV FreeImage_CloseMultiBitmap(FIMULTIBITMAP *bitmap, int flags FI_DEFAULT(0));
\r
828 DLL_API int DLL_CALLCONV FreeImage_GetPageCount(FIMULTIBITMAP *bitmap);
\r
829 DLL_API void DLL_CALLCONV FreeImage_AppendPage(FIMULTIBITMAP *bitmap, FIBITMAP *data);
\r
830 DLL_API void DLL_CALLCONV FreeImage_InsertPage(FIMULTIBITMAP *bitmap, int page, FIBITMAP *data);
\r
831 DLL_API void DLL_CALLCONV FreeImage_DeletePage(FIMULTIBITMAP *bitmap, int page);
\r
832 DLL_API FIBITMAP * DLL_CALLCONV FreeImage_LockPage(FIMULTIBITMAP *bitmap, int page);
\r
833 DLL_API void DLL_CALLCONV FreeImage_UnlockPage(FIMULTIBITMAP *bitmap, FIBITMAP *data, BOOL changed);
\r
834 DLL_API BOOL DLL_CALLCONV FreeImage_MovePage(FIMULTIBITMAP *bitmap, int target, int source);
\r
835 DLL_API BOOL DLL_CALLCONV FreeImage_GetLockedPageNumbers(FIMULTIBITMAP *bitmap, int *pages, int *count);
\r
837 // Filetype request routines ------------------------------------------------
\r
839 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFileType(const char *filename, int size FI_DEFAULT(0));
\r
840 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFileTypeU(const wchar_t *filename, int size FI_DEFAULT(0));
\r
841 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFileTypeFromHandle(FreeImageIO *io, fi_handle handle, int size FI_DEFAULT(0));
\r
842 DLL_API FREE_IMAGE_FORMAT DLL_CALLCONV FreeImage_GetFileTypeFromMemory(FIMEMORY *stream, int size FI_DEFAULT(0));
\r
844 // Image type request routine -----------------------------------------------
\r
846 DLL_API FREE_IMAGE_TYPE DLL_CALLCONV FreeImage_GetImageType(FIBITMAP *dib);
\r
848 // FreeImage helper routines ------------------------------------------------
\r
850 DLL_API BOOL DLL_CALLCONV FreeImage_IsLittleEndian(void);
\r
851 DLL_API BOOL DLL_CALLCONV FreeImage_LookupX11Color(const char *szColor, BYTE *nRed, BYTE *nGreen, BYTE *nBlue);
\r
852 DLL_API BOOL DLL_CALLCONV FreeImage_LookupSVGColor(const char *szColor, BYTE *nRed, BYTE *nGreen, BYTE *nBlue);
\r
854 // Pixel access routines ----------------------------------------------------
\r
856 DLL_API BYTE *DLL_CALLCONV FreeImage_GetBits(FIBITMAP *dib);
\r
857 DLL_API BYTE *DLL_CALLCONV FreeImage_GetScanLine(FIBITMAP *dib, int scanline);
\r
859 DLL_API BOOL DLL_CALLCONV FreeImage_GetPixelIndex(FIBITMAP *dib, unsigned x, unsigned y, BYTE *value);
\r
860 DLL_API BOOL DLL_CALLCONV FreeImage_GetPixelColor(FIBITMAP *dib, unsigned x, unsigned y, RGBQUAD *value);
\r
861 DLL_API BOOL DLL_CALLCONV FreeImage_SetPixelIndex(FIBITMAP *dib, unsigned x, unsigned y, BYTE *value);
\r
862 DLL_API BOOL DLL_CALLCONV FreeImage_SetPixelColor(FIBITMAP *dib, unsigned x, unsigned y, RGBQUAD *value);
\r
864 // DIB info routines --------------------------------------------------------
\r
866 DLL_API unsigned DLL_CALLCONV FreeImage_GetColorsUsed(FIBITMAP *dib);
\r
867 DLL_API unsigned DLL_CALLCONV FreeImage_GetBPP(FIBITMAP *dib);
\r
868 DLL_API unsigned DLL_CALLCONV FreeImage_GetWidth(FIBITMAP *dib);
\r
869 DLL_API unsigned DLL_CALLCONV FreeImage_GetHeight(FIBITMAP *dib);
\r
870 DLL_API unsigned DLL_CALLCONV FreeImage_GetLine(FIBITMAP *dib);
\r
871 DLL_API unsigned DLL_CALLCONV FreeImage_GetPitch(FIBITMAP *dib);
\r
872 DLL_API unsigned DLL_CALLCONV FreeImage_GetDIBSize(FIBITMAP *dib);
\r
873 DLL_API RGBQUAD *DLL_CALLCONV FreeImage_GetPalette(FIBITMAP *dib);
\r
875 DLL_API unsigned DLL_CALLCONV FreeImage_GetDotsPerMeterX(FIBITMAP *dib);
\r
876 DLL_API unsigned DLL_CALLCONV FreeImage_GetDotsPerMeterY(FIBITMAP *dib);
\r
877 DLL_API void DLL_CALLCONV FreeImage_SetDotsPerMeterX(FIBITMAP *dib, unsigned res);
\r
878 DLL_API void DLL_CALLCONV FreeImage_SetDotsPerMeterY(FIBITMAP *dib, unsigned res);
\r
880 DLL_API BITMAPINFOHEADER *DLL_CALLCONV FreeImage_GetInfoHeader(FIBITMAP *dib);
\r
881 DLL_API BITMAPINFO *DLL_CALLCONV FreeImage_GetInfo(FIBITMAP *dib);
\r
882 DLL_API FREE_IMAGE_COLOR_TYPE DLL_CALLCONV FreeImage_GetColorType(FIBITMAP *dib);
\r
884 DLL_API unsigned DLL_CALLCONV FreeImage_GetRedMask(FIBITMAP *dib);
\r
885 DLL_API unsigned DLL_CALLCONV FreeImage_GetGreenMask(FIBITMAP *dib);
\r
886 DLL_API unsigned DLL_CALLCONV FreeImage_GetBlueMask(FIBITMAP *dib);
\r
888 DLL_API unsigned DLL_CALLCONV FreeImage_GetTransparencyCount(FIBITMAP *dib);
\r
889 DLL_API BYTE * DLL_CALLCONV FreeImage_GetTransparencyTable(FIBITMAP *dib);
\r
890 DLL_API void DLL_CALLCONV FreeImage_SetTransparent(FIBITMAP *dib, BOOL enabled);
\r
891 DLL_API void DLL_CALLCONV FreeImage_SetTransparencyTable(FIBITMAP *dib, BYTE *table, int count);
\r
892 DLL_API BOOL DLL_CALLCONV FreeImage_IsTransparent(FIBITMAP *dib);
\r
893 DLL_API void DLL_CALLCONV FreeImage_SetTransparentIndex(FIBITMAP *dib, int index);
\r
894 DLL_API int DLL_CALLCONV FreeImage_GetTransparentIndex(FIBITMAP *dib);
\r
896 DLL_API BOOL DLL_CALLCONV FreeImage_HasBackgroundColor(FIBITMAP *dib);
\r
897 DLL_API BOOL DLL_CALLCONV FreeImage_GetBackgroundColor(FIBITMAP *dib, RGBQUAD *bkcolor);
\r
898 DLL_API BOOL DLL_CALLCONV FreeImage_SetBackgroundColor(FIBITMAP *dib, RGBQUAD *bkcolor);
\r
901 // ICC profile routines -----------------------------------------------------
\r
903 DLL_API FIICCPROFILE *DLL_CALLCONV FreeImage_GetICCProfile(FIBITMAP *dib);
\r
904 DLL_API FIICCPROFILE *DLL_CALLCONV FreeImage_CreateICCProfile(FIBITMAP *dib, void *data, long size);
\r
905 DLL_API void DLL_CALLCONV FreeImage_DestroyICCProfile(FIBITMAP *dib);
\r
907 // Line conversion routines -------------------------------------------------
\r
909 DLL_API void DLL_CALLCONV FreeImage_ConvertLine1To4(BYTE *target, BYTE *source, int width_in_pixels);
\r
910 DLL_API void DLL_CALLCONV FreeImage_ConvertLine8To4(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
911 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To4_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
912 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To4_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
913 DLL_API void DLL_CALLCONV FreeImage_ConvertLine24To4(BYTE *target, BYTE *source, int width_in_pixels);
\r
914 DLL_API void DLL_CALLCONV FreeImage_ConvertLine32To4(BYTE *target, BYTE *source, int width_in_pixels);
\r
915 DLL_API void DLL_CALLCONV FreeImage_ConvertLine1To8(BYTE *target, BYTE *source, int width_in_pixels);
\r
916 DLL_API void DLL_CALLCONV FreeImage_ConvertLine4To8(BYTE *target, BYTE *source, int width_in_pixels);
\r
917 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To8_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
918 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To8_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
919 DLL_API void DLL_CALLCONV FreeImage_ConvertLine24To8(BYTE *target, BYTE *source, int width_in_pixels);
\r
920 DLL_API void DLL_CALLCONV FreeImage_ConvertLine32To8(BYTE *target, BYTE *source, int width_in_pixels);
\r
921 DLL_API void DLL_CALLCONV FreeImage_ConvertLine1To16_555(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
922 DLL_API void DLL_CALLCONV FreeImage_ConvertLine4To16_555(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
923 DLL_API void DLL_CALLCONV FreeImage_ConvertLine8To16_555(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
924 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16_565_To16_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
925 DLL_API void DLL_CALLCONV FreeImage_ConvertLine24To16_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
926 DLL_API void DLL_CALLCONV FreeImage_ConvertLine32To16_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
927 DLL_API void DLL_CALLCONV FreeImage_ConvertLine1To16_565(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
928 DLL_API void DLL_CALLCONV FreeImage_ConvertLine4To16_565(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
929 DLL_API void DLL_CALLCONV FreeImage_ConvertLine8To16_565(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
930 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16_555_To16_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
931 DLL_API void DLL_CALLCONV FreeImage_ConvertLine24To16_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
932 DLL_API void DLL_CALLCONV FreeImage_ConvertLine32To16_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
933 DLL_API void DLL_CALLCONV FreeImage_ConvertLine1To24(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
934 DLL_API void DLL_CALLCONV FreeImage_ConvertLine4To24(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
935 DLL_API void DLL_CALLCONV FreeImage_ConvertLine8To24(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
936 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To24_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
937 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To24_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
938 DLL_API void DLL_CALLCONV FreeImage_ConvertLine32To24(BYTE *target, BYTE *source, int width_in_pixels);
\r
939 DLL_API void DLL_CALLCONV FreeImage_ConvertLine1To32(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
940 DLL_API void DLL_CALLCONV FreeImage_ConvertLine4To32(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
941 DLL_API void DLL_CALLCONV FreeImage_ConvertLine8To32(BYTE *target, BYTE *source, int width_in_pixels, RGBQUAD *palette);
\r
942 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To32_555(BYTE *target, BYTE *source, int width_in_pixels);
\r
943 DLL_API void DLL_CALLCONV FreeImage_ConvertLine16To32_565(BYTE *target, BYTE *source, int width_in_pixels);
\r
944 DLL_API void DLL_CALLCONV FreeImage_ConvertLine24To32(BYTE *target, BYTE *source, int width_in_pixels);
\r
946 // Smart conversion routines ------------------------------------------------
\r
948 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertTo4Bits(FIBITMAP *dib);
\r
949 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertTo8Bits(FIBITMAP *dib);
\r
950 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertToGreyscale(FIBITMAP *dib);
\r
951 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertTo16Bits555(FIBITMAP *dib);
\r
952 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertTo16Bits565(FIBITMAP *dib);
\r
953 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertTo24Bits(FIBITMAP *dib);
\r
954 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertTo32Bits(FIBITMAP *dib);
\r
955 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ColorQuantize(FIBITMAP *dib, FREE_IMAGE_QUANTIZE quantize);
\r
956 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ColorQuantizeEx(FIBITMAP *dib, FREE_IMAGE_QUANTIZE quantize FI_DEFAULT(FIQ_WUQUANT), int PaletteSize FI_DEFAULT(256), int ReserveSize FI_DEFAULT(0), RGBQUAD *ReservePalette FI_DEFAULT(NULL));
\r
957 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Threshold(FIBITMAP *dib, BYTE T);
\r
958 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Dither(FIBITMAP *dib, FREE_IMAGE_DITHER algorithm);
\r
960 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertFromRawBits(BYTE *bits, int width, int height, int pitch, unsigned bpp, unsigned red_mask, unsigned green_mask, unsigned blue_mask, BOOL topdown FI_DEFAULT(FALSE));
\r
961 DLL_API void DLL_CALLCONV FreeImage_ConvertToRawBits(BYTE *bits, FIBITMAP *dib, int pitch, unsigned bpp, unsigned red_mask, unsigned green_mask, unsigned blue_mask, BOOL topdown FI_DEFAULT(FALSE));
\r
963 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertToRGBF(FIBITMAP *dib);
\r
965 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertToStandardType(FIBITMAP *src, BOOL scale_linear FI_DEFAULT(TRUE));
\r
966 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ConvertToType(FIBITMAP *src, FREE_IMAGE_TYPE dst_type, BOOL scale_linear FI_DEFAULT(TRUE));
\r
968 // tone mapping operators
\r
969 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_ToneMapping(FIBITMAP *dib, FREE_IMAGE_TMO tmo, double first_param FI_DEFAULT(0), double second_param FI_DEFAULT(0));
\r
970 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_TmoDrago03(FIBITMAP *src, double gamma FI_DEFAULT(2.2), double exposure FI_DEFAULT(0));
\r
971 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_TmoReinhard05(FIBITMAP *src, double intensity FI_DEFAULT(0), double contrast FI_DEFAULT(0));
\r
972 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_TmoReinhard05Ex(FIBITMAP *src, double intensity FI_DEFAULT(0), double contrast FI_DEFAULT(0), double adaptation FI_DEFAULT(1), double color_correction FI_DEFAULT(0));
\r
974 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_TmoFattal02(FIBITMAP *src, double color_saturation FI_DEFAULT(0.5), double attenuation FI_DEFAULT(0.85));
\r
976 // ZLib interface -----------------------------------------------------------
\r
978 DLL_API DWORD DLL_CALLCONV FreeImage_ZLibCompress(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size);
\r
979 DLL_API DWORD DLL_CALLCONV FreeImage_ZLibUncompress(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size);
\r
980 DLL_API DWORD DLL_CALLCONV FreeImage_ZLibGZip(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size);
\r
981 DLL_API DWORD DLL_CALLCONV FreeImage_ZLibGUnzip(BYTE *target, DWORD target_size, BYTE *source, DWORD source_size);
\r
982 DLL_API DWORD DLL_CALLCONV FreeImage_ZLibCRC32(DWORD crc, BYTE *source, DWORD source_size);
\r
984 // --------------------------------------------------------------------------
\r
985 // Metadata routines --------------------------------------------------------
\r
986 // --------------------------------------------------------------------------
\r
988 // tag creation / destruction
\r
989 DLL_API FITAG *DLL_CALLCONV FreeImage_CreateTag(void);
\r
990 DLL_API void DLL_CALLCONV FreeImage_DeleteTag(FITAG *tag);
\r
991 DLL_API FITAG *DLL_CALLCONV FreeImage_CloneTag(FITAG *tag);
\r
993 // tag getters and setters
\r
994 DLL_API const char *DLL_CALLCONV FreeImage_GetTagKey(FITAG *tag);
\r
995 DLL_API const char *DLL_CALLCONV FreeImage_GetTagDescription(FITAG *tag);
\r
996 DLL_API WORD DLL_CALLCONV FreeImage_GetTagID(FITAG *tag);
\r
997 DLL_API FREE_IMAGE_MDTYPE DLL_CALLCONV FreeImage_GetTagType(FITAG *tag);
\r
998 DLL_API DWORD DLL_CALLCONV FreeImage_GetTagCount(FITAG *tag);
\r
999 DLL_API DWORD DLL_CALLCONV FreeImage_GetTagLength(FITAG *tag);
\r
1000 DLL_API const void *DLL_CALLCONV FreeImage_GetTagValue(FITAG *tag);
\r
1002 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagKey(FITAG *tag, const char *key);
\r
1003 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagDescription(FITAG *tag, const char *description);
\r
1004 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagID(FITAG *tag, WORD id);
\r
1005 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagType(FITAG *tag, FREE_IMAGE_MDTYPE type);
\r
1006 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagCount(FITAG *tag, DWORD count);
\r
1007 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagLength(FITAG *tag, DWORD length);
\r
1008 DLL_API BOOL DLL_CALLCONV FreeImage_SetTagValue(FITAG *tag, const void *value);
\r
1011 DLL_API FIMETADATA *DLL_CALLCONV FreeImage_FindFirstMetadata(FREE_IMAGE_MDMODEL model, FIBITMAP *dib, FITAG **tag);
\r
1012 DLL_API BOOL DLL_CALLCONV FreeImage_FindNextMetadata(FIMETADATA *mdhandle, FITAG **tag);
\r
1013 DLL_API void DLL_CALLCONV FreeImage_FindCloseMetadata(FIMETADATA *mdhandle);
\r
1015 // metadata setter and getter
\r
1016 DLL_API BOOL DLL_CALLCONV FreeImage_SetMetadata(FREE_IMAGE_MDMODEL model, FIBITMAP *dib, const char *key, FITAG *tag);
\r
1017 DLL_API BOOL DLL_CALLCONV FreeImage_GetMetadata(FREE_IMAGE_MDMODEL model, FIBITMAP *dib, const char *key, FITAG **tag);
\r
1020 DLL_API unsigned DLL_CALLCONV FreeImage_GetMetadataCount(FREE_IMAGE_MDMODEL model, FIBITMAP *dib);
\r
1021 DLL_API BOOL DLL_CALLCONV FreeImage_CloneMetadata(FIBITMAP *dst, FIBITMAP *src);
\r
1023 // tag to C string conversion
\r
1024 DLL_API const char* DLL_CALLCONV FreeImage_TagToString(FREE_IMAGE_MDMODEL model, FITAG *tag, char *Make FI_DEFAULT(NULL));
\r
1026 // --------------------------------------------------------------------------
\r
1027 // Image manipulation toolkit -----------------------------------------------
\r
1028 // --------------------------------------------------------------------------
\r
1030 // rotation and flipping
\r
1031 /// @deprecated see FreeImage_Rotate
\r
1032 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_RotateClassic(FIBITMAP *dib, double angle);
\r
1033 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Rotate(FIBITMAP *dib, double angle, const void *bkcolor FI_DEFAULT(NULL));
\r
1034 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_RotateEx(FIBITMAP *dib, double angle, double x_shift, double y_shift, double x_origin, double y_origin, BOOL use_mask);
\r
1035 DLL_API BOOL DLL_CALLCONV FreeImage_FlipHorizontal(FIBITMAP *dib);
\r
1036 DLL_API BOOL DLL_CALLCONV FreeImage_FlipVertical(FIBITMAP *dib);
\r
1037 DLL_API BOOL DLL_CALLCONV FreeImage_JPEGTransform(const char *src_file, const char *dst_file, FREE_IMAGE_JPEG_OPERATION operation, BOOL perfect FI_DEFAULT(FALSE));
\r
1038 DLL_API BOOL DLL_CALLCONV FreeImage_JPEGTransformU(const wchar_t *src_file, const wchar_t *dst_file, FREE_IMAGE_JPEG_OPERATION operation, BOOL perfect FI_DEFAULT(FALSE));
\r
1040 // upsampling / downsampling
\r
1041 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Rescale(FIBITMAP *dib, int dst_width, int dst_height, FREE_IMAGE_FILTER filter);
\r
1042 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_MakeThumbnail(FIBITMAP *dib, int max_pixel_size, BOOL convert FI_DEFAULT(TRUE));
\r
1044 // color manipulation routines (point operations)
\r
1045 DLL_API BOOL DLL_CALLCONV FreeImage_AdjustCurve(FIBITMAP *dib, BYTE *LUT, FREE_IMAGE_COLOR_CHANNEL channel);
\r
1046 DLL_API BOOL DLL_CALLCONV FreeImage_AdjustGamma(FIBITMAP *dib, double gamma);
\r
1047 DLL_API BOOL DLL_CALLCONV FreeImage_AdjustBrightness(FIBITMAP *dib, double percentage);
\r
1048 DLL_API BOOL DLL_CALLCONV FreeImage_AdjustContrast(FIBITMAP *dib, double percentage);
\r
1049 DLL_API BOOL DLL_CALLCONV FreeImage_Invert(FIBITMAP *dib);
\r
1050 DLL_API BOOL DLL_CALLCONV FreeImage_GetHistogram(FIBITMAP *dib, DWORD *histo, FREE_IMAGE_COLOR_CHANNEL channel FI_DEFAULT(FICC_BLACK));
\r
1051 DLL_API int DLL_CALLCONV FreeImage_GetAdjustColorsLookupTable(BYTE *LUT, double brightness, double contrast, double gamma, BOOL invert);
\r
1052 DLL_API BOOL DLL_CALLCONV FreeImage_AdjustColors(FIBITMAP *dib, double brightness, double contrast, double gamma, BOOL invert FI_DEFAULT(FALSE));
\r
1053 DLL_API unsigned DLL_CALLCONV FreeImage_ApplyColorMapping(FIBITMAP *dib, RGBQUAD *srccolors, RGBQUAD *dstcolors, unsigned count, BOOL ignore_alpha, BOOL swap);
\r
1054 DLL_API unsigned DLL_CALLCONV FreeImage_SwapColors(FIBITMAP *dib, RGBQUAD *color_a, RGBQUAD *color_b, BOOL ignore_alpha);
\r
1055 DLL_API unsigned DLL_CALLCONV FreeImage_ApplyPaletteIndexMapping(FIBITMAP *dib, BYTE *srcindices, BYTE *dstindices, unsigned count, BOOL swap);
\r
1056 DLL_API unsigned DLL_CALLCONV FreeImage_SwapPaletteIndices(FIBITMAP *dib, BYTE *index_a, BYTE *index_b);
\r
1058 // channel processing routines
\r
1059 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_GetChannel(FIBITMAP *dib, FREE_IMAGE_COLOR_CHANNEL channel);
\r
1060 DLL_API BOOL DLL_CALLCONV FreeImage_SetChannel(FIBITMAP *dib, FIBITMAP *dib8, FREE_IMAGE_COLOR_CHANNEL channel);
\r
1061 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_GetComplexChannel(FIBITMAP *src, FREE_IMAGE_COLOR_CHANNEL channel);
\r
1062 DLL_API BOOL DLL_CALLCONV FreeImage_SetComplexChannel(FIBITMAP *dst, FIBITMAP *src, FREE_IMAGE_COLOR_CHANNEL channel);
\r
1064 // copy / paste / composite routines
\r
1065 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Copy(FIBITMAP *dib, int left, int top, int right, int bottom);
\r
1066 DLL_API BOOL DLL_CALLCONV FreeImage_Paste(FIBITMAP *dst, FIBITMAP *src, int left, int top, int alpha);
\r
1067 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_Composite(FIBITMAP *fg, BOOL useFileBkg FI_DEFAULT(FALSE), RGBQUAD *appBkColor FI_DEFAULT(NULL), FIBITMAP *bg FI_DEFAULT(NULL));
\r
1068 DLL_API BOOL DLL_CALLCONV FreeImage_JPEGCrop(const char *src_file, const char *dst_file, int left, int top, int right, int bottom);
\r
1069 DLL_API BOOL DLL_CALLCONV FreeImage_JPEGCropU(const wchar_t *src_file, const wchar_t *dst_file, int left, int top, int right, int bottom);
\r
1070 DLL_API BOOL DLL_CALLCONV FreeImage_PreMultiplyWithAlpha(FIBITMAP *dib);
\r
1072 // background filling routines
\r
1073 DLL_API BOOL DLL_CALLCONV FreeImage_FillBackground(FIBITMAP *dib, const void *color, int options FI_DEFAULT(0));
\r
1074 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_EnlargeCanvas(FIBITMAP *src, int left, int top, int right, int bottom, const void *color, int options FI_DEFAULT(0));
\r
1075 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_AllocateEx(int width, int height, int bpp, const RGBQUAD *color, int options FI_DEFAULT(0), const RGBQUAD *palette FI_DEFAULT(NULL), unsigned red_mask FI_DEFAULT(0), unsigned green_mask FI_DEFAULT(0), unsigned blue_mask FI_DEFAULT(0));
\r
1076 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_AllocateExT(FREE_IMAGE_TYPE type, int width, int height, int bpp, const void *color, int options FI_DEFAULT(0), const RGBQUAD *palette FI_DEFAULT(NULL), unsigned red_mask FI_DEFAULT(0), unsigned green_mask FI_DEFAULT(0), unsigned blue_mask FI_DEFAULT(0));
\r
1078 // miscellaneous algorithms
\r
1079 DLL_API FIBITMAP *DLL_CALLCONV FreeImage_MultigridPoissonSolver(FIBITMAP *Laplacian, int ncycle FI_DEFAULT(3));
\r
1081 // restore the borland-specific enum size option
\r
1082 #if defined(__BORLANDC__)
\r
1083 #pragma option pop
\r
1086 #ifdef __cplusplus
\r
1090 #endif // FREEIMAGE_H
\r