DOCS/man/hu/mplayer.1 synced with r18969
[mplayer/glamo.git] / libvo / vo_tga.c
blobfc5531db6a1e126e7723ea74205d5919f894652d
1 /*
2 * vo_tga.c: targa output
4 * this video output module write targa uncompressed file in 15, 24 and 32 bit bgr format.
6 * to select the output format use the format filter:
7 * mplayer -vo tga -vf format=bgr15 ...
8 * mplayer -vo tga -vf format=bgr24 ...
9 * mplayer -vo tga -vf format=bgr32 ...
11 * The 16 bit file are loaded without problem from Gimp and ImageMagick but give an error
12 * with entice (a visualizer from the enlightenment package that use the imlib2 package).
14 * In 32 bit mode the alpha channel is set to 255 (0xff). For big endian
15 * machines, TGA_ALPHA32 changes from 0xff000000 to 0x000000ff, and TGA_SHIFT32 from 0 to 8.
17 * I need to fill the alpha channel because entice consider that alpha channel (and displays
18 * nothing, only the background!), but ImageMacick (the program display) or gimp doesn't
19 * care.
21 * maybe is possible (with a compilation switch) to avoid the fill of the alpha channel
22 * and work outside mplayer (if needed)
24 * Daniele Forghieri ( guru@digitalfantasy.it )
28 #include <stdio.h>
29 #include <stdlib.h>
30 #include <string.h>
31 #include <errno.h>
32 #include <math.h>
34 #include "config.h"
35 #include "mp_msg.h"
36 #include "help_mp.h"
37 #include "video_out.h"
38 #include "video_out_internal.h"
40 #ifdef WORDS_BIGENDIAN
41 #define TGA_ALPHA32 0x000000ff
42 #define TGA_SHIFT32 8
43 #else
44 #define TGA_ALPHA32 0xff000000
45 #define TGA_SHIFT32 0
46 #endif
48 static vo_info_t info =
50 "Targa output",
51 "tga",
52 "Daniele Forghieri - guru@digitalfantasy.it",
57 LIBVO_EXTERN (tga)
59 /* locals vars */
60 static int frame_num = 0;
61 static void *line_buff;
63 static void tga_make_header(uint8_t *h, int dx, int dy, int bpp)
66 int i;
68 for(i = 0; i < 18; i++) {
69 switch (i) {
70 case 2:
71 *h = 0x02;
72 break;
74 case 12:
75 *h = dx & 0xff;
76 break;
78 case 13:
79 *h = (dx >> 8) & 0xff;
80 break;
82 case 14:
83 *h = dy & 0xff;
84 break;
86 case 15:
87 *h = (dy >> 8) & 0xff;
88 break;
90 case 16:
91 *h = bpp;
92 break;
94 case 17:
95 *h = 0x20;
96 break;
98 default:
99 *h = 0;
101 ++h;
106 static int write_tga( char *file, int bpp, int dx, int dy, uint8_t *buf, int stride)
108 int er;
109 FILE *fo;
111 fo = fopen(file, "wb");
112 if (fo != NULL) {
113 uint8_t hdr[18];
115 er = 0;
116 tga_make_header(hdr, dx, dy, bpp);
117 if (fwrite(hdr, sizeof(hdr), 1, fo) == 1) {
118 int wb;
120 wb = ((bpp + 7) / 8) * dx;
121 if (bpp == 32) {
122 /* Setup the alpha channel for every pixel */
123 while (dy-- > 0) {
124 uint32_t *d;
125 uint32_t *s;
126 int x;
128 s = (uint32_t *)buf;
129 d = line_buff;
130 for(x = 0; x < dx; x++) {
131 *d++ = ((*s++) << TGA_SHIFT32) | TGA_ALPHA32;
133 if (fwrite(line_buff, wb, 1, fo) != 1) {
134 er = 4;
135 break;
137 buf += stride;
141 else {
142 while (dy-- > 0) {
143 if (fwrite(buf, wb, 1, fo) != 1) {
144 er = 4;
145 break;
147 buf += stride;
151 else {
152 er = 2;
155 fclose(fo);
157 else {
158 er = 1;
161 if (er) {
162 fprintf(stderr, "Error writing file [%s]\n", file);
164 return(er);
167 static uint32_t draw_image(mp_image_t* mpi)
169 char file[20 + 1];
171 snprintf (file, 20, "%08d.tga", ++frame_num);
173 write_tga( file,
174 mpi->bpp,
175 mpi->w,
176 mpi->h,
177 mpi->planes[0],
178 mpi->stride[0]);
180 return VO_TRUE;
183 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)
185 /* buffer for alpha */
186 if(line_buff){ free(line_buff); line_buff=NULL; }
187 if (format == (IMGFMT_BGR | 32)) {
188 line_buff = malloc(width * 4);
190 return 0;
193 static void draw_osd(void)
197 static void flip_page (void)
199 return;
202 static int draw_slice(uint8_t *srcimg[], int stride[], int w,int h,int x,int y)
204 return -1;
207 static int draw_frame(uint8_t * src[])
209 return -1;
212 static int query_format(uint32_t format)
214 switch(format){
215 case IMGFMT_BGR|15:
216 case IMGFMT_BGR|24:
217 case IMGFMT_BGR|32:
218 return VFCAP_CSP_SUPPORTED | VFCAP_CSP_SUPPORTED_BY_HW;
220 return 0;
223 static void uninit(void)
225 if(line_buff){ free(line_buff); line_buff=NULL; }
228 static void check_events(void)
232 static int preinit(const char *arg)
234 if(arg) {
235 mp_msg(MSGT_VO,MSGL_WARN, MSGTR_LIBVO_TGA_UnknownSubdevice,arg);
236 return ENOSYS;
238 return 0;
241 static int control(uint32_t request, void *data, ...)
243 switch (request) {
244 case VOCTRL_DRAW_IMAGE:
245 return draw_image(data);
247 case VOCTRL_QUERY_FORMAT:
248 return query_format(*((uint32_t*)data));
250 return VO_NOTIMPL;