1 |
< |
/* $Header$ */ |
2 |
< |
|
1 |
> |
/* RCSid $Id$ */ |
2 |
|
/* |
3 |
|
* Copyright (c) 1988-1997 Sam Leffler |
4 |
|
* Copyright (c) 1991-1997 Silicon Graphics, Inc. |
85 |
|
#endif |
86 |
|
|
87 |
|
#if defined(USE_WIN32_FILEIO) |
88 |
< |
#include <windows.h> |
89 |
< |
#ifdef __WIN32__ |
88 |
> |
# include <windows.h> |
89 |
> |
# ifdef __WIN32__ |
90 |
|
DECLARE_HANDLE(thandle_t); /* Win32 file handle */ |
91 |
< |
#else |
91 |
> |
# else |
92 |
|
typedef HFILE thandle_t; /* client data handle */ |
93 |
< |
#endif |
93 |
> |
# endif /* __WIN32__ */ |
94 |
|
#else |
95 |
|
typedef void* thandle_t; /* client data handle */ |
96 |
< |
#endif |
96 |
> |
#endif /* USE_WIN32_FILEIO */ |
97 |
|
|
98 |
|
#ifndef NULL |
99 |
< |
#define NULL 0 |
99 |
> |
# define NULL (void *)0 |
100 |
|
#endif |
101 |
|
|
102 |
|
/* |
113 |
|
#define TIFFPRINT_JPEGACTABLES 0x200 /* JPEG AC tables */ |
114 |
|
#define TIFFPRINT_JPEGDCTABLES 0x200 /* JPEG DC tables */ |
115 |
|
|
116 |
+ |
/* |
117 |
+ |
* Colour conversion stuff |
118 |
+ |
*/ |
119 |
+ |
|
120 |
+ |
/* reference white */ |
121 |
+ |
#define D65_X0 (95.0470F) |
122 |
+ |
#define D65_Y0 (100.0F) |
123 |
+ |
#define D65_Z0 (108.8827F) |
124 |
+ |
|
125 |
+ |
#define D50_X0 (96.4250F) |
126 |
+ |
#define D50_Y0 (100.0F) |
127 |
+ |
#define D50_Z0 (82.4680F) |
128 |
+ |
|
129 |
+ |
/* Structure for holding information about a display device. */ |
130 |
+ |
|
131 |
+ |
typedef unsigned char TIFFRGBValue; /* 8-bit samples */ |
132 |
+ |
|
133 |
+ |
typedef struct { |
134 |
+ |
float d_mat[3][3]; /* XYZ -> luminance matrix */ |
135 |
+ |
float d_YCR; /* Light o/p for reference white */ |
136 |
+ |
float d_YCG; |
137 |
+ |
float d_YCB; |
138 |
+ |
uint32 d_Vrwr; /* Pixel values for ref. white */ |
139 |
+ |
uint32 d_Vrwg; |
140 |
+ |
uint32 d_Vrwb; |
141 |
+ |
float d_Y0R; /* Residual light for black pixel */ |
142 |
+ |
float d_Y0G; |
143 |
+ |
float d_Y0B; |
144 |
+ |
float d_gammaR; /* Gamma values for the three guns */ |
145 |
+ |
float d_gammaG; |
146 |
+ |
float d_gammaB; |
147 |
+ |
} TIFFDisplay; |
148 |
+ |
|
149 |
+ |
typedef struct { /* YCbCr->RGB support */ |
150 |
+ |
TIFFRGBValue* clamptab; /* range clamping table */ |
151 |
+ |
int* Cr_r_tab; |
152 |
+ |
int* Cb_b_tab; |
153 |
+ |
int32* Cr_g_tab; |
154 |
+ |
int32* Cb_g_tab; |
155 |
+ |
int32* Y_tab; |
156 |
+ |
} TIFFYCbCrToRGB; |
157 |
+ |
|
158 |
+ |
typedef struct { /* CIE Lab 1976->RGB support */ |
159 |
+ |
int range; /* Size of conversion table */ |
160 |
+ |
#define CIELABTORGB_TABLE_RANGE 1500 |
161 |
+ |
float rstep, gstep, bstep; |
162 |
+ |
float X0, Y0, Z0; /* Reference white point */ |
163 |
+ |
TIFFDisplay display; |
164 |
+ |
float Yr2r[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yr to r */ |
165 |
+ |
float Yg2g[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yg to g */ |
166 |
+ |
float Yb2b[CIELABTORGB_TABLE_RANGE + 1]; /* Conversion of Yb to b */ |
167 |
+ |
} TIFFCIELabToRGB; |
168 |
+ |
|
169 |
|
/* |
170 |
|
* RGBA-style image support. |
171 |
|
*/ |
120 |
– |
typedef unsigned char TIFFRGBValue; /* 8-bit samples */ |
172 |
|
typedef struct _TIFFRGBAImage TIFFRGBAImage; |
173 |
|
/* |
174 |
|
* The image reading and conversion routines invoke |
189 |
|
/* |
190 |
|
* RGBA-reader state. |
191 |
|
*/ |
141 |
– |
typedef struct { /* YCbCr->RGB support */ |
142 |
– |
TIFFRGBValue* clamptab; /* range clamping table */ |
143 |
– |
int* Cr_r_tab; |
144 |
– |
int* Cb_b_tab; |
145 |
– |
int32* Cr_g_tab; |
146 |
– |
int32* Cb_g_tab; |
147 |
– |
float coeffs[3]; /* cached for repeated use */ |
148 |
– |
} TIFFYCbCrToRGB; |
149 |
– |
|
192 |
|
struct _TIFFRGBAImage { |
193 |
|
TIFF* tif; /* image handle */ |
194 |
|
int stoponerr; /* stop on read error */ |
199 |
|
uint16 bitspersample; /* image bits/sample */ |
200 |
|
uint16 samplesperpixel; /* image samples/pixel */ |
201 |
|
uint16 orientation; /* image orientation */ |
202 |
+ |
uint16 req_orientation; /* requested orientation */ |
203 |
|
uint16 photometric; /* image photometric interp */ |
204 |
|
uint16* redcmap; /* colormap pallete */ |
205 |
|
uint16* greencmap; |
215 |
|
uint32** BWmap; /* black&white map */ |
216 |
|
uint32** PALmap; /* palette image map */ |
217 |
|
TIFFYCbCrToRGB* ycbcr; /* YCbCr conversion state */ |
218 |
+ |
TIFFCIELabToRGB* cielab; /* CIE L*a*b conversion state */ |
219 |
|
|
220 |
|
int row_offset; |
221 |
|
int col_offset; |
247 |
|
#include <stdio.h> |
248 |
|
#include <stdarg.h> |
249 |
|
|
250 |
< |
/* share internal LogLuv conversion routines */ |
250 |
> |
/* share internal LogLuv conversion routines? */ |
251 |
|
#ifndef LOGLUV_PUBLIC |
252 |
< |
#define LOGLUV_PUBLIC 1 |
252 |
> |
#define LOGLUV_PUBLIC 1 |
253 |
|
#endif |
254 |
|
|
255 |
< |
#if defined(__cplusplus) |
255 |
> |
#if defined(c_plusplus) || defined(__cplusplus) |
256 |
|
extern "C" { |
257 |
|
#endif |
258 |
|
typedef void (*TIFFErrorHandler)(const char*, const char*, va_list); |
269 |
|
extern const TIFFCodec* TIFFFindCODEC(uint16); |
270 |
|
extern TIFFCodec* TIFFRegisterCODEC(uint16, const char*, TIFFInitMethod); |
271 |
|
extern void TIFFUnRegisterCODEC(TIFFCodec*); |
272 |
+ |
extern int TIFFIsCODECConfigured(uint16); |
273 |
+ |
extern TIFFCodec* TIFFGetConfiguredCODECs(); |
274 |
|
|
275 |
|
extern tdata_t _TIFFmalloc(tsize_t); |
276 |
|
extern tdata_t _TIFFrealloc(tdata_t, tsize_t); |
279 |
|
extern int _TIFFmemcmp(const tdata_t, const tdata_t, tsize_t); |
280 |
|
extern void _TIFFfree(tdata_t); |
281 |
|
|
282 |
+ |
extern void TIFFCleanup(TIFF*); |
283 |
|
extern void TIFFClose(TIFF*); |
284 |
|
extern int TIFFFlush(TIFF*); |
285 |
|
extern int TIFFFlushData(TIFF*); |
291 |
|
extern tsize_t TIFFScanlineSize(TIFF*); |
292 |
|
extern tsize_t TIFFRasterScanlineSize(TIFF*); |
293 |
|
extern tsize_t TIFFStripSize(TIFF*); |
294 |
+ |
extern tsize_t TIFFRawStripSize(TIFF*, tstrip_t); |
295 |
|
extern tsize_t TIFFVStripSize(TIFF*, uint32); |
296 |
|
extern tsize_t TIFFTileRowSize(TIFF*); |
297 |
|
extern tsize_t TIFFTileSize(TIFF*); |
299 |
|
extern uint32 TIFFDefaultStripSize(TIFF*, uint32); |
300 |
|
extern void TIFFDefaultTileSize(TIFF*, uint32*, uint32*); |
301 |
|
extern int TIFFFileno(TIFF*); |
302 |
+ |
extern int TIFFSetFileno(TIFF*, int); |
303 |
+ |
extern thandle_t TIFFClientdata(TIFF*); |
304 |
+ |
extern thandle_t TIFFSetClientdata(TIFF*, thandle_t); |
305 |
|
extern int TIFFGetMode(TIFF*); |
306 |
+ |
extern int TIFFSetMode(TIFF*, int); |
307 |
|
extern int TIFFIsTiled(TIFF*); |
308 |
|
extern int TIFFIsByteSwapped(TIFF*); |
309 |
|
extern int TIFFIsUpSampled(TIFF*); |
310 |
|
extern int TIFFIsMSB2LSB(TIFF*); |
311 |
+ |
extern int TIFFIsBigEndian(TIFF*); |
312 |
+ |
extern TIFFReadWriteProc TIFFGetReadProc(TIFF*); |
313 |
+ |
extern TIFFReadWriteProc TIFFGetWriteProc(TIFF*); |
314 |
+ |
extern TIFFSeekProc TIFFGetSeekProc(TIFF*); |
315 |
+ |
extern TIFFCloseProc TIFFGetCloseProc(TIFF*); |
316 |
+ |
extern TIFFSizeProc TIFFGetSizeProc(TIFF*); |
317 |
+ |
extern TIFFMapFileProc TIFFGetMapFileProc(TIFF*); |
318 |
+ |
extern TIFFUnmapFileProc TIFFGetUnmapFileProc(TIFF*); |
319 |
|
extern uint32 TIFFCurrentRow(TIFF*); |
320 |
|
extern tdir_t TIFFCurrentDirectory(TIFF*); |
321 |
|
extern tdir_t TIFFNumberOfDirectories(TIFF*); |
324 |
|
extern ttile_t TIFFCurrentTile(TIFF*); |
325 |
|
extern int TIFFReadBufferSetup(TIFF*, tdata_t, tsize_t); |
326 |
|
extern int TIFFWriteBufferSetup(TIFF*, tdata_t, tsize_t); |
327 |
+ |
extern int TIFFSetupStrips(TIFF *); |
328 |
|
extern int TIFFWriteCheck(TIFF*, int, const char *); |
329 |
|
extern int TIFFCreateDirectory(TIFF*); |
330 |
|
extern int TIFFLastDirectory(TIFF*); |
334 |
|
extern int TIFFSetField(TIFF*, ttag_t, ...); |
335 |
|
extern int TIFFVSetField(TIFF*, ttag_t, va_list); |
336 |
|
extern int TIFFWriteDirectory(TIFF *); |
337 |
+ |
extern int TIFFCheckpointDirectory(TIFF *); |
338 |
+ |
extern int TIFFRewriteDirectory(TIFF *); |
339 |
|
extern int TIFFReassignTagToIgnore(enum TIFFIgnoreSense, int); |
340 |
|
|
341 |
|
#if defined(c_plusplus) || defined(__cplusplus) |
343 |
|
extern int TIFFReadScanline(TIFF*, tdata_t, uint32, tsample_t = 0); |
344 |
|
extern int TIFFWriteScanline(TIFF*, tdata_t, uint32, tsample_t = 0); |
345 |
|
extern int TIFFReadRGBAImage(TIFF*, uint32, uint32, uint32*, int = 0); |
346 |
+ |
extern int TIFFReadRGBAImageOriented(TIFF*, uint32, uint32, uint32*, |
347 |
+ |
int = ORIENTATION_BOTLEFT, int = 0); |
348 |
|
#else |
349 |
|
extern void TIFFPrintDirectory(TIFF*, FILE*, long); |
350 |
|
extern int TIFFReadScanline(TIFF*, tdata_t, uint32, tsample_t); |
351 |
|
extern int TIFFWriteScanline(TIFF*, tdata_t, uint32, tsample_t); |
352 |
|
extern int TIFFReadRGBAImage(TIFF*, uint32, uint32, uint32*, int); |
353 |
+ |
extern int TIFFReadRGBAImageOriented(TIFF*, uint32, uint32, uint32*, int, int); |
354 |
|
#endif |
355 |
|
|
356 |
|
extern int TIFFReadRGBAStrip(TIFF*, tstrip_t, uint32 * ); |
360 |
|
extern int TIFFRGBAImageGet(TIFFRGBAImage*, uint32*, uint32, uint32); |
361 |
|
extern void TIFFRGBAImageEnd(TIFFRGBAImage*); |
362 |
|
extern TIFF* TIFFOpen(const char*, const char*); |
363 |
+ |
# ifdef __WIN32__ |
364 |
+ |
extern TIFF* TIFFOpenW(const wchar_t*, const char*); |
365 |
+ |
# endif /* __WIN32__ */ |
366 |
|
extern TIFF* TIFFFdOpen(int, const char*, const char*); |
367 |
|
extern TIFF* TIFFClientOpen(const char*, const char*, |
368 |
|
thandle_t, |
371 |
|
TIFFSizeProc, |
372 |
|
TIFFMapFileProc, TIFFUnmapFileProc); |
373 |
|
extern const char* TIFFFileName(TIFF*); |
374 |
+ |
extern const char* TIFFSetFileName(TIFF*, const char *); |
375 |
|
extern void TIFFError(const char*, const char*, ...); |
376 |
|
extern void TIFFWarning(const char*, const char*, ...); |
377 |
|
extern TIFFErrorHandler TIFFSetErrorHandler(TIFFErrorHandler); |
394 |
|
extern tsize_t TIFFWriteRawStrip(TIFF*, tstrip_t, tdata_t, tsize_t); |
395 |
|
extern tsize_t TIFFWriteEncodedTile(TIFF*, ttile_t, tdata_t, tsize_t); |
396 |
|
extern tsize_t TIFFWriteRawTile(TIFF*, ttile_t, tdata_t, tsize_t); |
397 |
+ |
extern int TIFFDataWidth(TIFFDataType); /* table of tag datatype widths */ |
398 |
|
extern void TIFFSetWriteOffset(TIFF*, toff_t); |
399 |
|
extern void TIFFSwabShort(uint16*); |
400 |
|
extern void TIFFSwabLong(uint32*); |
401 |
|
extern void TIFFSwabDouble(double*); |
402 |
|
extern void TIFFSwabArrayOfShort(uint16*, unsigned long); |
403 |
+ |
extern void TIFFSwabArrayOfTriples(uint8*, unsigned long); |
404 |
|
extern void TIFFSwabArrayOfLong(uint32*, unsigned long); |
405 |
|
extern void TIFFSwabArrayOfDouble(double*, unsigned long); |
406 |
|
extern void TIFFReverseBits(unsigned char *, unsigned long); |
407 |
|
extern const unsigned char* TIFFGetBitRevTable(int); |
408 |
|
|
409 |
< |
#if LOGLUV_PUBLIC |
409 |
> |
#ifdef LOGLUV_PUBLIC |
410 |
|
#define U_NEU 0.210526316 |
411 |
|
#define V_NEU 0.473684211 |
412 |
|
#define UVSCALE 410. |
430 |
|
extern uint32 LogLuv32fromXYZ(float*, int); |
431 |
|
#endif |
432 |
|
#endif /* LOGLUV_PUBLIC */ |
433 |
< |
#if defined(__cplusplus) |
433 |
> |
|
434 |
> |
/* |
435 |
> |
** Stuff, related to tag handling and creating custom tags. |
436 |
> |
*/ |
437 |
> |
extern int TIFFGetTagListCount( TIFF * ); |
438 |
> |
extern ttag_t TIFFGetTagListEntry( TIFF *, int tag_index ); |
439 |
> |
|
440 |
> |
#define TIFF_ANY TIFF_NOTYPE /* for field descriptor searching */ |
441 |
> |
#define TIFF_VARIABLE -1 /* marker for variable length tags */ |
442 |
> |
#define TIFF_SPP -2 /* marker for SamplesPerPixel tags */ |
443 |
> |
#define TIFF_VARIABLE2 -3 /* marker for uint32 var-length tags */ |
444 |
> |
|
445 |
> |
#define FIELD_CUSTOM 65 |
446 |
> |
|
447 |
> |
typedef struct { |
448 |
> |
ttag_t field_tag; /* field's tag */ |
449 |
> |
short field_readcount; /* read count/TIFF_VARIABLE/TIFF_SPP */ |
450 |
> |
short field_writecount; /* write count/TIFF_VARIABLE */ |
451 |
> |
TIFFDataType field_type; /* type of associated data */ |
452 |
> |
unsigned short field_bit; /* bit in fieldsset bit vector */ |
453 |
> |
unsigned char field_oktochange; /* if true, can change while writing */ |
454 |
> |
unsigned char field_passcount; /* if true, pass dir count on set */ |
455 |
> |
char *field_name; /* ASCII name */ |
456 |
> |
} TIFFFieldInfo; |
457 |
> |
|
458 |
> |
typedef struct _TIFFTagValue { |
459 |
> |
const TIFFFieldInfo *info; |
460 |
> |
int count; |
461 |
> |
void *value; |
462 |
> |
} TIFFTagValue; |
463 |
> |
|
464 |
> |
extern void TIFFMergeFieldInfo(TIFF*, const TIFFFieldInfo[], int); |
465 |
> |
extern const TIFFFieldInfo* TIFFFindFieldInfo(TIFF*, ttag_t, TIFFDataType); |
466 |
> |
extern const TIFFFieldInfo* TIFFFindFieldInfoByName(TIFF* , const char *, |
467 |
> |
TIFFDataType); |
468 |
> |
extern const TIFFFieldInfo* TIFFFieldWithTag(TIFF*, ttag_t); |
469 |
> |
extern const TIFFFieldInfo* TIFFFieldWithName(TIFF*, const char *); |
470 |
> |
|
471 |
> |
typedef int (*TIFFVSetMethod)(TIFF*, ttag_t, va_list); |
472 |
> |
typedef int (*TIFFVGetMethod)(TIFF*, ttag_t, va_list); |
473 |
> |
typedef void (*TIFFPrintMethod)(TIFF*, FILE*, long); |
474 |
> |
|
475 |
> |
typedef struct { |
476 |
> |
TIFFVSetMethod vsetfield; /* tag set routine */ |
477 |
> |
TIFFVGetMethod vgetfield; /* tag get routine */ |
478 |
> |
TIFFPrintMethod printdir; /* directory print routine */ |
479 |
> |
} TIFFTagMethods; |
480 |
> |
|
481 |
> |
extern TIFFTagMethods *TIFFAccessTagMethods( TIFF * ); |
482 |
> |
extern void *TIFFGetClientInfo( TIFF *, const char * ); |
483 |
> |
extern void TIFFSetClientInfo( TIFF *, void *, const char * ); |
484 |
> |
|
485 |
> |
extern int TIFFCIELabToRGBInit(TIFFCIELabToRGB*, TIFFDisplay *, float*); |
486 |
> |
extern void TIFFCIELabToXYZ(TIFFCIELabToRGB *, uint32, int32, int32, |
487 |
> |
float *, float *, float *); |
488 |
> |
extern void TIFFXYZToRGB(TIFFCIELabToRGB *, float, float, float, |
489 |
> |
uint32 *, uint32 *, uint32 *); |
490 |
> |
|
491 |
> |
extern int TIFFYCbCrToRGBInit(TIFFYCbCrToRGB*, float*, float*); |
492 |
> |
extern void TIFFYCbCrtoRGB(TIFFYCbCrToRGB *, uint32, int32, int32, |
493 |
> |
uint32 *, uint32 *, uint32 *); |
494 |
> |
|
495 |
> |
#if defined(c_plusplus) || defined(__cplusplus) |
496 |
|
} |
497 |
|
#endif |
498 |
+ |
|
499 |
|
#endif /* _TIFFIO_ */ |
500 |
+ |
|
501 |
+ |
/* vim: set ts=8 sts=8 sw=8 noet: */ |