svn merge -r 12937:13095 https://svn.blender.org/svnroot/bf-blender/trunk/blender
[blender.git] / source / blender / imbuf / intern / cineon / logImageLib.h
1 /*
2  *       Common library definitions for Cineon and DPX image files.
3  *
4  *       Copyright 1999,2000,2001 David Hodson <hodsond@acm.org>
5  *
6  *       This program is free software; you can redistribute it and/or modify it
7  *       under the terms of the GNU General Public License as published by the Free
8  *       Software Foundation; either version 2 of the License, or (at your option)
9  *       any later version.
10  *
11  *       This program is distributed in the hope that it will be useful, but
12  *       WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13  *       or FITNESS FOR A PARTICULAR PURPOSE.    See the GNU General Public License
14  *       for more details.
15  *
16  *       You should have received a copy of the GNU General Public License
17  *       along with this program; if not, write to the Free Software
18  *       Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19  *
20  */
21
22 #ifndef _LOG_IMAGE_LIB_H_
23 #define _LOG_IMAGE_LIB_H_
24
25 #ifdef __cplusplus
26 extern "C" {
27 #endif
28
29 /*
30  * Image structure. You don't care what this is.
31  */
32
33 typedef struct _Log_Image_File_t_ LogImageFile;
34
35 /*
36  * Magic numbers for normal and byte-swapped Cineon and Dpx files
37  */
38
39 #define CINEON_FILE_MAGIC 0x802A5FD7
40 #define DPX_FILE_MAGIC 0x53445058
41
42 /*
43  * Image 8 bit <-> 10 bit conversion parameters.
44  */
45
46 typedef struct {
47         float gamma;
48         int blackPoint;
49         int whitePoint;
50 } LogImageByteConversionParameters;
51
52 /* int functions return 0 for OK */
53
54 void logImageSetVerbose(int);
55
56 LogImageFile* logImageOpenFromMem(unsigned char *buffer, unsigned int size, int cineon);
57 LogImageFile* logImageOpen(const char* filename, int cineon);
58 int logImageGetSize(const LogImageFile* logImage, int* xsize, int* ysize, int* channels);
59 LogImageFile* logImageCreate(const char* filename, int cineon, int xsize, int ysize, int channels);
60
61 /* get / set header block NYI */
62 int logImageGetHeader(LogImageFile*, int*, void**);
63 int logImageSetHeader(LogImageFile*, int, void*);
64
65 /* byte conversion routines for mapping logImage (usually) 10 bit values to 8 bit */
66 /* see Kodak docs for details... */
67
68 int logImageGetByteConversionDefaults(LogImageByteConversionParameters* params);
69 int logImageGetByteConversion(const LogImageFile* logImage, LogImageByteConversionParameters* params);
70 int logImageSetByteConversion(LogImageFile* logImage, const LogImageByteConversionParameters* params);
71
72 /* get/set scanline of converted bytes */
73 int logImageGetRowBytes(LogImageFile* logImage, unsigned short* row, int y);
74 int logImageSetRowBytes(LogImageFile* logImage, const unsigned short* row, int y);
75
76 /* closes file and deletes data */
77 void logImageClose(LogImageFile* logImage);
78
79 /* read file and dump header info */
80 void logImageDump(const char* filename);
81
82 #ifdef __cplusplus
83 }
84 #endif
85
86 #endif /* _LOG_IMAGE_LIB_H_ */