5eb52158a1a71df323bed19ed5b5eb63b165e612
[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 #define RAWTGA  (TGA | 1)
60
61 #define JPG_STD (JPG | (0 << 8))
62 #define JPG_VID (JPG | (1 << 8))
63 #define JPG_JST (JPG | (2 << 8))
64 #define JPG_MAX (JPG | (3 << 8))
65 #define JPG_MSK (0xffffff00)
66
67 #define AM_ham      (0x0800 | AMI)
68 #define AM_hbrite   (0x0080 | AMI)
69 #define AM_lace     (0x0004 | AMI)
70 #define AM_hires    (0x8000 | AMI)
71 #define AM_hblace   (AM_hbrite | AM_lace)
72 #define AM_hilace   (AM_hires | AM_lace)
73 #define AM_hamlace  (AM_ham | AM_lace)
74
75 #define RGB888  1
76 #define RGB555  2
77 #define DYUV    3
78 #define CLUT8   4
79 #define CLUT7   5
80 #define CLUT4   6
81 #define CLUT3   7
82 #define RL7     8
83 #define RL3     9
84 #define MPLTE   10
85
86 #define DYUV1   0
87 #define C233    1
88 #define YUVX    2
89 #define HAMX    3
90 #define TANX    4
91
92 #define AN_c233                 (Anim | C233)
93 #define AN_yuvx                 (Anim | YUVX)
94 #define AN_hamx                 (Anim | HAMX)
95 #define AN_tanx                 (Anim | TANX)
96
97 #define IS_amiga(x)             (x->ftype & AMI)
98 #define IS_ham(x)               ((x->ftype & AM_ham) == AM_ham)
99 #define IS_hbrite(x)    ((x->ftype & AM_hbrite) == AM_hbrite)
100
101 #define IS_lace(x)              ((x->ftype & AM_lace) == AM_lace)
102 #define IS_hires(x)             ((x->ftype & AM_hires) == AM_hires)
103 #define IS_hblace(x)    ((x->ftype & AM_hblace) == AM_hblace)
104 #define IS_hilace(x)    ((x->ftype & AM_hilace) == AM_hilace)
105 #define IS_hamlace(x)   ((x->ftype & AM_hamlace) == AM_hamlace)
106
107 #define IS_anim(x)              (x->ftype & Anim)
108 #define IS_hamx(x)              (x->ftype == AN_hamx)
109 #define IS_tga(x)               (x->ftype & TGA)
110 #define IS_png(x)               (x->ftype & PNG)
111 #define IS_bmp(x)               (x->ftype & BMP)
112 #define IS_radhdr(x)            (x->ftype & RADHDR)
113 #define IS_tim(x)               (x->ftype & TIM)
114 #define IS_tiff(x)              (x->ftype & TIFF)
115 #define IS_openexr(x)           (x->ftype & OPENEXR)
116
117
118 #define IMAGIC  0732
119 #define IS_iris(x)              (x->ftype == IMAGIC)
120
121 #define IS_jpg(x)               (x->ftype & JPG)
122 #define IS_stdjpg(x)    ((x->ftype & JPG_MSK) == JPG_STD)
123 #define IS_vidjpg(x)    ((x->ftype & JPG_MSK) == JPG_VID)
124 #define IS_jstjpg(x)    ((x->ftype & JPG_MSK) == JPG_JST)
125 #define IS_maxjpg(x)    ((x->ftype & JPG_MSK) == JPG_MAX)
126
127 #define AN_INIT an_stringdec = stringdec; an_stringenc = stringenc;
128
129 #define IB_MIPMAP_LEVELS        10
130
131 struct MEM_CacheLimiterHandle_s;
132
133 typedef struct ImBuf {
134         struct ImBuf *next, *prev;      /**< allow lists of ImBufs, for caches or flipbooks */
135         short   x, y;                           /**< width and Height of our image buffer */
136         short   skipx;                          /**< Width in ints to get to the next scanline */
137         unsigned char   depth;          /**< Active amount of bits/bitplanes */
138         unsigned char   cbits;          /**< Amount of active bits in cmap */
139         unsigned short  mincol;         /**< smallest color in colormap */
140         unsigned short  maxcol;         /**< Largest color in colormap */
141         int     type;                                   /**< 0=abgr, 1=bitplanes */
142         int     ftype;                                  /**< File type we are going to save as */
143         unsigned int    *cmap;          /**< Color map data. */
144         unsigned int    *rect;          /**< pixel values stored here */
145         unsigned int    **planes;       /**< bitplanes */
146         int     flags;                          /**< Controls which components should exist. */
147         int     mall;                           /**< what is malloced internal, and can be freed */
148         short   xorig, yorig;           /**< Cordinates of first pixel of an image used in some formats (example: targa) */
149         char    name[1023];             /**< The file name assocated with this image */
150         char    namenull;               /**< Unused don't want to remove it thought messes things up */
151         int     userflags;                      /**< Used to set imbuf to Dirty and other stuff */
152         int     *zbuf;                          /**< z buffer data, original zbuffer */
153         float *zbuf_float;              /**< z buffer data, camera coordinates */
154         void *userdata; 
155         unsigned char *encodedbuffer;     /**< Compressed image only used with png currently */
156         unsigned int   encodedsize;       /**< Size of data written to encodedbuffer */
157         unsigned int   encodedbuffersize; /**< Size of encodedbuffer */
158
159         float *rect_float;              /**< floating point Rect equivilant */
160         int channels;                   /**< amount of channels in rect_float (0 = 4 channel default) */
161         float dither;                   /**< random dither value, for conversion from float -> byte rect */
162         
163         struct MEM_CacheLimiterHandle_s * c_handle; /**< handle for cache limiter */
164         int refcounter;                 /**< Refcounter for multiple users */
165         int index;                              /**< reference index for ImBuf lists */
166         
167         struct ImBuf *mipmap[IB_MIPMAP_LEVELS]; /**< MipMap levels, a series of halved images */
168 } ImBuf;
169
170 LIBEXPORT struct ImBuf *allocImBuf(short,short,uchar,uint,uchar);
171 LIBEXPORT struct ImBuf *dupImBuf(struct ImBuf *);
172 LIBEXPORT void freeImBuf(struct ImBuf*);
173
174 LIBEXPORT short converttocmap(struct ImBuf* ibuf);
175
176 LIBEXPORT short saveiff(struct ImBuf *,char *,int);
177
178 LIBEXPORT struct ImBuf *loadiffmem(int *,int);
179 LIBEXPORT struct ImBuf *loadifffile(int,int);
180 LIBEXPORT struct ImBuf *loadiffname(char *,int);
181 LIBEXPORT struct ImBuf *testiffname(char *,int);
182
183 LIBEXPORT struct ImBuf *onehalf(struct ImBuf *);
184 LIBEXPORT struct ImBuf *onethird(struct ImBuf *);
185 LIBEXPORT struct ImBuf *halflace(struct ImBuf *);
186 LIBEXPORT struct ImBuf *half_x(struct ImBuf *);
187 LIBEXPORT struct ImBuf *half_y(struct ImBuf *);
188 LIBEXPORT struct ImBuf *double_x(struct ImBuf *);
189 LIBEXPORT struct ImBuf *double_y(struct ImBuf *);
190 LIBEXPORT struct ImBuf *double_fast_x(struct ImBuf *);
191 LIBEXPORT struct ImBuf *double_fast_y(struct ImBuf *);
192
193 LIBEXPORT int ispic(char *);
194
195 LIBEXPORT void dit2(struct ImBuf *, short, short);
196 LIBEXPORT void dit0(struct ImBuf *, short, short);
197
198 LIBEXPORT struct ImBuf *scaleImBuf(struct ImBuf *, short, short);
199 LIBEXPORT struct ImBuf *scalefastImBuf(struct ImBuf *, short, short);
200 LIBEXPORT struct ImBuf *scalefieldImBuf(struct ImBuf *, short, short);
201 LIBEXPORT struct ImBuf *scalefastfieldImBuf(struct ImBuf *, short, short);
202
203 LIBEXPORT void de_interlace(struct ImBuf *ib);
204 LIBEXPORT void interlace(struct ImBuf *ib);
205 LIBEXPORT void gamwarp(struct ImBuf *ibuf, double gamma);
206
207 LIBEXPORT void IMB_rectcpy(struct ImBuf *dbuf, struct ImBuf *sbuf, 
208         int destx, int desty, int srcx, int srcy, int width, int height);
209
210 LIBEXPORT void IMB_rectfill(struct ImBuf *drect, float col[4]);
211 LIBEXPORT void IMB_rectfill_area(struct ImBuf *ibuf, float *col, int x1, int y1, int x2, int y2);
212 LIBEXPORT void buf_rectfill_area(unsigned char *rect, float *rectf, int width, int height, float *col, int x1, int y1, int x2, int y2);
213
214 #endif /* IFF_H */
215