4 * This video output module writes TARGA uncompressed files in 15, 24 and 32
7 * to select the output format use the format filter:
8 * mplayer -vo tga -vf format=bgr15 ...
9 * mplayer -vo tga -vf format=bgr24 ...
10 * mplayer -vo tga -vf format=bgr32 ...
12 * The 16 bit files are loaded without problem from Gimp and ImageMagick but
13 * give an error with entice (a visualizer from the enlightenment package
14 * that uses the imlib2 package).
16 * In 32-bit mode the alpha channel is set to 255 (0xff). For big-endian
17 * machines, TGA_ALPHA32 changes from 0xff000000 to 0x000000ff, and
18 * TGA_SHIFT32 from 0 to 8.
20 * I need to fill the alpha channel because entice considers that alpha
21 * channel (and displays nothing, only the background!), but ImageMagick
22 * (the program display) or gimp doesn't care.
24 * Maybe it is possible (with a compilation switch) to avoid the fill of
25 * the alpha channel and work outside MPlayer (if needed).
27 * Daniele Forghieri ( guru@digitalfantasy.it )
29 * This file is part of MPlayer.
31 * MPlayer is free software; you can redistribute it and/or modify
32 * it under the terms of the GNU General Public License as published by
33 * the Free Software Foundation; either version 2 of the License, or
34 * (at your option) any later version.
36 * MPlayer is distributed in the hope that it will be useful,
37 * but WITHOUT ANY WARRANTY; without even the implied warranty of
38 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
39 * GNU General Public License for more details.
41 * You should have received a copy of the GNU General Public License along
42 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
43 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
55 #include "video_out.h"
56 #include "video_out_internal.h"
58 static const vo_info_t info
=
62 "Daniele Forghieri - guru@digitalfantasy.it",
67 const LIBVO_EXTERN (tga
)
70 static int frame_num
= 0;
71 static void *line_buff
;
73 static void tga_make_header(uint8_t *h
, int dx
, int dy
, int bpp
)
78 for(i
= 0; i
< 18; i
++) {
89 *h
= (dx
>> 8) & 0xff;
97 *h
= (dy
>> 8) & 0xff;
116 static int write_tga( char *file
, int bpp
, int dx
, int dy
, uint8_t *buf
, int stride
)
121 fo
= fopen(file
, "wb");
126 tga_make_header(hdr
, dx
, dy
, bpp
);
127 if (fwrite(hdr
, sizeof(hdr
), 1, fo
) == 1) {
130 wb
= ((bpp
+ 7) / 8) * dx
;
132 /* Setup the alpha channel for every pixel */
140 for(x
= 0; x
< dx
; x
++) {
155 if (fwrite(line_buff
, wb
, 1, fo
) != 1) {
165 if (fwrite(buf
, wb
, 1, fo
) != 1) {
184 fprintf(stderr
, "Error writing file [%s]\n", file
);
189 static uint32_t draw_image(mp_image_t
* mpi
)
193 snprintf (file
, 20, "%08d.tga", ++frame_num
);
205 static int config(uint32_t width
, uint32_t height
, uint32_t d_width
, uint32_t d_height
, uint32_t flags
, char *title
, uint32_t format
)
207 /* buffer for alpha */
208 if(line_buff
){ free(line_buff
); line_buff
=NULL
; }
209 if (format
== (IMGFMT_BGR
| 32)) {
210 line_buff
= malloc(width
* 4);
215 static void draw_osd(void)
219 static void flip_page (void)
224 static int draw_slice(uint8_t *srcimg
[], int stride
[], int w
,int h
,int x
,int y
)
229 static int draw_frame(uint8_t * src
[])
234 static int query_format(uint32_t format
)
240 return VFCAP_CSP_SUPPORTED
| VFCAP_CSP_SUPPORTED_BY_HW
;
245 static void uninit(void)
247 if(line_buff
){ free(line_buff
); line_buff
=NULL
; }
250 static void check_events(void)
254 static int preinit(const char *arg
)
257 mp_tmsg(MSGT_VO
,MSGL_WARN
, "[VO_TGA] Unknown subdevice: %s.\n",arg
);
263 static int control(uint32_t request
, void *data
)
266 case VOCTRL_DRAW_IMAGE
:
267 return draw_image(data
);
269 case VOCTRL_QUERY_FORMAT
:
270 return query_format(*((uint32_t*)data
));