diff options
author | Ton Roosendaal <ton@blender.org> | 2006-03-12 17:11:23 +0300 |
---|---|---|
committer | Ton Roosendaal <ton@blender.org> | 2006-03-12 17:11:23 +0300 |
commit | de0262e4c81c7d7f036cc574f636a248f2cc9f27 (patch) | |
tree | eb9548b7588eb22de2c409bc0ee127716827e94d /source/blender/imbuf/intern/cineon/logImageLib.h | |
parent | bd151b30ab70433c27027864db777a3955d0fc76 (diff) |
New: Import/Export of Cineon and DPX image files. The first is Kodak's
standard for film scanning, 10 bits/channel and logarithmic. DPX is
derived from Cineon as the ANSI/SMPTE industry standard.
DPX supports 16 bits color/channel, linear as well as logarithmic.
Code has been gratefully copied from CinePaint and was integrated in
Blender by Joe Eagar.
According to CinePaint's dev Robin Rowe the DPX code defaults to log
colorspace. Can't find in the code clues yet how to enable/disable that.
However, tests with write/read of DPX seems to show no visible loss by
log conversion code. Might be because it uses the entire 16 bit range...
CinePaint dpx files have been succesfully imported in a Quantel IQ HD/2K
finishing/grading set without problem, so for now I guess we can
use it! :)
Changes in code: added tests for image magic numbers before entering
the actual reading code. Prevents error prints, and makes it faster too.
(Note; this because Blender doesn't check for extensions, but calls
reading functions on every file until one accepts it. :)
Diffstat (limited to 'source/blender/imbuf/intern/cineon/logImageLib.h')
-rw-r--r-- | source/blender/imbuf/intern/cineon/logImageLib.h | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/source/blender/imbuf/intern/cineon/logImageLib.h b/source/blender/imbuf/intern/cineon/logImageLib.h new file mode 100644 index 00000000000..ea45c675fe2 --- /dev/null +++ b/source/blender/imbuf/intern/cineon/logImageLib.h @@ -0,0 +1,86 @@ +/* + * Common library definitions for Cineon and DPX image files. + * + * Copyright 1999,2000,2001 David Hodson <hodsond@acm.org> + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the Free + * Software Foundation; either version 2 of the License, or (at your option) + * any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + */ + +#ifndef _LOG_IMAGE_LIB_H_ +#define _LOG_IMAGE_LIB_H_ + +#ifdef __cplusplus +extern "C" { +#endif + +/* + * Image structure. You don't care what this is. + */ + +typedef struct _Log_Image_File_t_ LogImageFile; + +/* + * Magic numbers for normal and byte-swapped Cineon and Dpx files + */ + +#define CINEON_FILE_MAGIC 0x802A5FD7 +#define DPX_FILE_MAGIC 0x53445058 + +/* + * Image 8 bit <-> 10 bit conversion parameters. + */ + +typedef struct { + float gamma; + int blackPoint; + int whitePoint; +} LogImageByteConversionParameters; + +/* int functions return 0 for OK */ + +void logImageSetVerbose(int); + +LogImageFile* logImageOpenFromMem(unsigned char *buffer, unsigned int size, int cineon); +LogImageFile* logImageOpen(const char* filename, int cineon); +int logImageGetSize(const LogImageFile* logImage, int* xsize, int* ysize, int* channels); +LogImageFile* logImageCreate(const char* filename, int cineon, int xsize, int ysize, int channels); + +/* get / set header block NYI */ +int logImageGetHeader(LogImageFile*, int*, void**); +int logImageSetHeader(LogImageFile*, int, void*); + +/* byte conversion routines for mapping logImage (usually) 10 bit values to 8 bit */ +/* see Kodak docs for details... */ + +int logImageGetByteConversionDefaults(LogImageByteConversionParameters* params); +int logImageGetByteConversion(const LogImageFile* logImage, LogImageByteConversionParameters* params); +int logImageSetByteConversion(LogImageFile* logImage, const LogImageByteConversionParameters* params); + +/* get/set scanline of converted bytes */ +int logImageGetRowBytes(LogImageFile* logImage, unsigned short* row, int y); +int logImageSetRowBytes(LogImageFile* logImage, const unsigned short* row, int y); + +/* closes file and deletes data */ +void logImageClose(LogImageFile* logImage); + +/* read file and dump header info */ +void logImageDump(const char* filename); + +#ifdef __cplusplus +} +#endif + +#endif /* _LOG_IMAGE_LIB_H_ */ |