Added support for outputting bmp's
[blender.git] / source / blender / imbuf / intern / writeimage.c
1 /**
2  *
3  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version. The Blender
9  * Foundation also sells licenses for use in proprietary software under
10  * the Blender License.  See http://www.blender.org/BL/ for information
11  * about this.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software Foundation,
20  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
21  *
22  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
23  * All rights reserved.
24  *
25  * The Original Code is: all of this file.
26  *
27  * Contributor(s): none yet.
28  *
29  * ***** END GPL/BL DUAL LICENSE BLOCK *****
30  * writeimage.c
31  *
32  * $Id$
33  */
34
35 #include "BLI_blenlib.h"
36
37 #include "imbuf.h"
38 #include "imbuf_patch.h"
39
40 #include "IMB_imbuf_types.h"
41 #include "IMB_imbuf.h"
42
43 #include "IMB_allocimbuf.h"
44
45 #include "IMB_targa.h"
46 #include "IMB_jpeg.h"
47 #include "IMB_iris.h"
48 #include "IMB_ham.h"
49 #include "IMB_hamx.h"
50 #include "IMB_amiga.h"
51 #include "IMB_png.h"
52
53 #include "IMB_iff.h"
54 #include "IMB_bitplanes.h"
55 #include "IMB_divers.h"
56
57 #ifdef HAVE_CONFIG_H
58 #include <config.h>
59 #endif
60
61
62 short IMB_saveiff(struct ImBuf *ibuf,char *naam,int flags)
63 {
64         short ok=TRUE,delpl=FALSE;
65         int file = -1;
66
67         if (ibuf==0) return (FALSE);
68         ibuf->flags = flags;
69
70         /* Put formats that take a filename here */
71         if (IS_jpg(ibuf)) {
72                 if(imb_savejpeg(ibuf, naam, flags)) return (0);
73                 else return (TRUE);
74         }
75
76         file = open(naam, O_BINARY | O_RDWR | O_CREAT | O_TRUNC, 0666);
77         if (file < 0) return (FALSE);
78
79         if (flags & IB_rect){
80                 if (ibuf->cmap){
81                         imb_checkncols(ibuf);
82                 }
83         }
84
85         /* Put formats that take a filehandle here */
86         if (IS_png(ibuf)) {
87                 ok = imb_savepng(ibuf,file,flags);
88                 if (ok) {
89                         close (file);
90                         return (ok);
91                 }
92         }
93
94         if (IS_bmp(ibuf)) {
95                 ok = imb_savebmp(ibuf,file,flags);
96                 if (ok) {
97                         close (file);
98                         return (ok);
99                 }
100         }
101
102         if (IS_tga(ibuf)) {
103                 ok = imb_savetarga(ibuf,file,flags);
104                 if (ok) {
105                         close (file);
106                         return (ok);
107                 }
108         }
109         
110         if (IS_iris(ibuf)) {
111                 ok = imb_saveiris(ibuf,file,flags);
112                 if (ok) {
113                         close (file);
114                         return (ok);
115                 }
116         }
117         
118         if (ok) ok = imb_start_iff(ibuf,file);
119
120         if (IS_amiga(ibuf)){
121                 IMB_flipy(ibuf);
122                 if (flags & IB_rect){
123                         if ((flags & IB_cmap) == 0) {
124                                 if (IS_ham(ibuf)){
125                                         if (ok) ok = imb_converttoham(ibuf);
126                                 }else if (ibuf->cmap){
127                                         if (ok) ok = IMB_converttocmap(ibuf);
128                                 }
129                         }
130                         if (ok){
131                                 if (ibuf->planes==0){
132                                         delpl=TRUE;
133                                         ok=imb_addplanesImBuf(ibuf);
134                                 }
135                                 imb_longtobp(ibuf);
136                         }
137                 }
138
139                 if (flags & IB_vert){
140                         if (ok) ok = imb_encodebodyv(ibuf,file);
141                 }
142                 else{
143                         if (ok) ok = imb_encodebodyh(ibuf,file);
144                 }
145                 if (ok) ok = imb_update_iff(file,BODY);
146         }else if (IS_anim(ibuf)) {
147                 if (ok) ok = imb_enc_anim(ibuf, file);
148                 if (ok) ok = imb_update_iff(file, BODY);
149         }
150         close(file);
151
152         if (ok==FALSE) {
153                 fprintf(stderr,"Couldn't save picture.\n");
154         }       
155         if (delpl) imb_freeplanesImBuf(ibuf);
156
157         return (ok);
158 }
159