[#18164] jpeg2000 patch, with some fixes from Peter too.
[blender.git] / source / blender / blenpluginapi / iff.h
1 /* Copyright (c) 1999, Not a Number / NeoGeo b.v. 
2  * $Id$
3  * 
4  * All rights reserved.
5  * 
6  * Contact:      info@blender.org   
7  * Information:  http://www.blender.org
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  * 2. Redistributions in binary form must reproduce the above copyright
15  *    notice, this list of conditions and the following disclaimer in the
16  *    documentation and/or other materials provided with the distribution.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
19  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
22  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28  * SUCH DAMAGE.
29  */
30
31 #ifndef IFF_H
32 #define IFF_H
33
34 #include <sys/types.h>
35 #include "util.h"
36 #include "externdef.h"
37
38 #define IB_rect                 (1 << 0)
39 #define IB_planes               (1 << 1)
40 #define IB_cmap                 (1 << 2)
41 #define IB_test                 (1 << 7)
42
43 #define IB_fields               (1 << 11)
44 #define IB_yuv                  (1 << 12)
45 #define IB_zbuf                 (1 << 13)
46 #define IB_rgba                 (1 << 14)
47
48 #define AMI             (1 << 31)
49 #define PNG             (1 << 30)
50 #define Anim            (1 << 29)
51 #define TGA             (1 << 28)
52 #define JPG             (1 << 27)
53 #define BMP             (1 << 26)
54 #ifdef WITH_QUICKTIME
55 #define QUICKTIME       (1 << 25)
56 #endif
57 #define RADHDR  (1<<24)
58
59 #ifdef WITH_OPENJPEG
60 #define JP2                            (1 << 18)
61 #endif
62
63 #define RAWTGA  (TGA | 1)
64
65 #define JPG_STD (JPG | (0 << 8))
66 #define JPG_VID (JPG | (1 << 8))
67 #define JPG_JST (JPG | (2 << 8))
68 #define JPG_MAX (JPG | (3 << 8))
69 #define JPG_MSK (0xffffff00)
70
71 #define AM_ham      (0x0800 | AMI)
72 #define AM_hbrite   (0x0080 | AMI)
73 #define AM_lace     (0x0004 | AMI)
74 #define AM_hires    (0x8000 | AMI)
75 #define AM_hblace   (AM_hbrite | AM_lace)
76 #define AM_hilace   (AM_hires | AM_lace)
77 #define AM_hamlace  (AM_ham | AM_lace)
78
79 #define RGB888  1
80 #define RGB555  2
81 #define DYUV    3
82 #define CLUT8   4
83 #define CLUT7   5
84 #define CLUT4   6
85 #define CLUT3   7
86 #define RL7     8
87 #define RL3     9
88 #define MPLTE   10
89
90 #define DYUV1   0
91 #define C233    1
92 #define YUVX    2
93 #define HAMX    3
94 #define TANX    4
95
96 #define AN_c233                 (Anim | C233)
97 #define AN_yuvx                 (Anim | YUVX)
98 #define AN_hamx                 (Anim | HAMX)
99 #define AN_tanx                 (Anim | TANX)
100
101 #define IS_amiga(x)             (x->ftype & AMI)
102 #define IS_ham(x)               ((x->ftype & AM_ham) == AM_ham)
103 #define IS_hbrite(x)    ((x->ftype & AM_hbrite) == AM_hbrite)
104
105 #define IS_lace(x)              ((x->ftype & AM_lace) == AM_lace)
106 #define IS_hires(x)             ((x->ftype & AM_hires) == AM_hires)
107 #define IS_hblace(x)    ((x->ftype & AM_hblace) == AM_hblace)
108 #define IS_hilace(x)    ((x->ftype & AM_hilace) == AM_hilace)
109 #define IS_hamlace(x)   ((x->ftype & AM_hamlace) == AM_hamlace)
110
111 #define IS_anim(x)              (x->ftype & Anim)
112 #define IS_hamx(x)              (x->ftype == AN_hamx)
113 #define IS_tga(x)               (x->ftype & TGA)
114 #define IS_png(x)               (x->ftype & PNG)
115 #define IS_bmp(x)               (x->ftype & BMP)
116 #define IS_radhdr(x)            (x->ftype & RADHDR)
117 #define IS_tim(x)               (x->ftype & TIM)
118 #define IS_tiff(x)              (x->ftype & TIFF)
119 #define IS_openexr(x)           (x->ftype & OPENEXR)
120 #define IS_jp2(x)           (x->ftype & JP2)
121
122
123 #define IMAGIC  0732
124 #define IS_iris(x)              (x->ftype == IMAGIC)
125
126 #define IS_jpg(x)               (x->ftype & JPG)
127 #define IS_stdjpg(x)    ((x->ftype & JPG_MSK) == JPG_STD)
128 #define IS_vidjpg(x)    ((x->ftype & JPG_MSK) == JPG_VID)
129 #define IS_jstjpg(x)    ((x->ftype & JPG_MSK) == JPG_JST)
130 #define IS_maxjpg(x)    ((x->ftype & JPG_MSK) == JPG_MAX)
131
132 #define AN_INIT an_stringdec = stringdec; an_stringenc = stringenc;
133
134 #define IB_MIPMAP_LEVELS        10
135
136 struct MEM_CacheLimiterHandle_s;
137
138 typedef struct ImBuf {
139         struct ImBuf *next, *prev;      /**< allow lists of ImBufs, for caches or flipbooks */
140         short   x, y;                           /**< width and Height of our image buffer */
141         short   skipx;                          /**< Width in ints to get to the next scanline */
142         unsigned char   depth;          /**< Active amount of bits/bitplanes */
143         unsigned char   cbits;          /**< Amount of active bits in cmap */
144         unsigned short  mincol;         /**< smallest color in colormap */
145         unsigned short  maxcol;         /**< Largest color in colormap */
146         int     type;                                   /**< 0=abgr, 1=bitplanes */
147         int     ftype;                                  /**< File type we are going to save as */
148         unsigned int    *cmap;          /**< Color map data. */
149         unsigned int    *rect;          /**< pixel values stored here */
150         unsigned int    **planes;       /**< bitplanes */
151         int     flags;                          /**< Controls which components should exist. */
152         int     mall;                           /**< what is malloced internal, and can be freed */
153         short   xorig, yorig;           /**< Cordinates of first pixel of an image used in some formats (example: targa) */
154         char    name[1023];             /**< The file name assocated with this image */
155         char    namenull;               /**< Unused don't want to remove it thought messes things up */
156         int     userflags;                      /**< Used to set imbuf to Dirty and other stuff */
157         int     *zbuf;                          /**< z buffer data, original zbuffer */
158         float *zbuf_float;              /**< z buffer data, camera coordinates */
159         void *userdata;                 /**< temporary storage, only used by baking at the moment */
160         unsigned char *encodedbuffer;     /**< Compressed image only used with png currently */
161         unsigned int   encodedsize;       /**< Size of data written to encodedbuffer */
162         unsigned int   encodedbuffersize; /**< Size of encodedbuffer */
163
164         float *rect_float;              /**< floating point Rect equivilant */
165         int channels;                   /**< amount of channels in rect_float (0 = 4 channel default) */
166         float dither;                   /**< random dither value, for conversion from float -> byte rect */
167         
168         struct MEM_CacheLimiterHandle_s * c_handle; /**< handle for cache limiter */
169         struct ImgInfo * img_info;
170         int refcounter;                 /**< Refcounter for multiple users */
171         int index;                              /**< reference index for ImBuf lists */
172         
173         struct ImBuf *mipmap[IB_MIPMAP_LEVELS]; /**< MipMap levels, a series of halved images */
174 } ImBuf;
175
176 LIBIMPORT struct ImBuf *allocImBuf(short,short,uchar,uint,uchar);
177 LIBIMPORT struct ImBuf *dupImBuf(struct ImBuf *);
178 LIBIMPORT void freeImBuf(struct ImBuf*);
179
180 LIBIMPORT short converttocmap(struct ImBuf* ibuf);
181
182 LIBIMPORT short saveiff(struct ImBuf *,char *,int);
183
184 LIBIMPORT struct ImBuf *loadiffmem(int *,int);
185 LIBIMPORT struct ImBuf *loadifffile(int,int);
186 LIBIMPORT struct ImBuf *loadiffname(char *,int);
187 LIBIMPORT struct ImBuf *testiffname(char *,int);
188
189 LIBIMPORT struct ImBuf *onehalf(struct ImBuf *);
190 LIBIMPORT struct ImBuf *onethird(struct ImBuf *);
191 LIBIMPORT struct ImBuf *halflace(struct ImBuf *);
192 LIBIMPORT struct ImBuf *half_x(struct ImBuf *);
193 LIBIMPORT struct ImBuf *half_y(struct ImBuf *);
194 LIBIMPORT struct ImBuf *double_x(struct ImBuf *);
195 LIBIMPORT struct ImBuf *double_y(struct ImBuf *);
196 LIBIMPORT struct ImBuf *double_fast_x(struct ImBuf *);
197 LIBIMPORT struct ImBuf *double_fast_y(struct ImBuf *);
198
199 LIBIMPORT int ispic(char *);
200
201 LIBIMPORT void dit2(struct ImBuf *, short, short);
202 LIBIMPORT void dit0(struct ImBuf *, short, short);
203
204 LIBIMPORT struct ImBuf *scaleImBuf(struct ImBuf *, short, short);
205 LIBIMPORT struct ImBuf *scalefastImBuf(struct ImBuf *, short, short);
206 LIBIMPORT struct ImBuf *scalefieldImBuf(struct ImBuf *, short, short);
207 LIBIMPORT struct ImBuf *scalefastfieldImBuf(struct ImBuf *, short, short);
208
209 LIBIMPORT void de_interlace(struct ImBuf *ib);
210 LIBIMPORT void interlace(struct ImBuf *ib);
211 LIBIMPORT void gamwarp(struct ImBuf *ibuf, double gamma);
212
213 LIBIMPORT void IMB_rectcpy(struct ImBuf *dbuf, struct ImBuf *sbuf, 
214         int destx, int desty, int srcx, int srcy, int width, int height);
215
216 LIBIMPORT void IMB_rectfill(struct ImBuf *drect, float col[4]);
217 LIBIMPORT void IMB_rectfill_area(struct ImBuf *ibuf, float *col, int x1, int y1, int x2, int y2);
218 LIBIMPORT void buf_rectfill_area(unsigned char *rect, float *rectf, int width, int height, float *col, int x1, int y1, int x2, int y2);
219
220 #endif /* IFF_H */
221