annotate targa.c @ 5306:abc5c130b448 libavcodec

AC-3 decoder, soc revision 32, Jul 17 09:37:32 2006 UTC by cloud9 Latest commit. There is no error in parsing and or recovering transform coefficients. Double checked with ac3dec. Getting consistent results with the bit allocation routine and transform coefficients. The code is able to parse valid ac3 bitstreams without error from start to end. I have also implemented the imdct when block switching is not enabled. However, can anybody provide an insight into how to convert float samples to int16_t ? lrint is of no help cuz it produces output -1, 0 or 1 whereas the output should be between -32768 to 32767.
author jbr
date Sat, 14 Jul 2007 15:48:28 +0000
parents 2b72f9bc4f06
children 56d2853cd7c3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
1 /*
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
2 * Targa (.tga) image decoder
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
3 * Copyright (c) 2006 Konstantin Shishkov
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
4 *
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
5 * This file is part of FFmpeg.
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
6 *
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
7 * FFmpeg is free software; you can redistribute it and/or
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
8 * modify it under the terms of the GNU Lesser General Public
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
9 * License as published by the Free Software Foundation; either
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
10 * version 2.1 of the License, or (at your option) any later version.
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
11 *
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
12 * FFmpeg is distributed in the hope that it will be useful,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
15 * Lesser General Public License for more details.
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
16 *
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
17 * You should have received a copy of the GNU Lesser General Public
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
18 * License along with FFmpeg; if not, write to the Free Software
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
20 */
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
21 #include "avcodec.h"
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
22
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
23 enum TargaCompr{
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
24 TGA_NODATA = 0, // no image data
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
25 TGA_PAL = 1, // palettized
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
26 TGA_RGB = 2, // true-color
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
27 TGA_BW = 3, // black & white or grayscale
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
28 TGA_RLE = 8, // flag pointing that data is RLE-coded
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
29 };
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
30
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
31 typedef struct TargaContext {
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
32 AVFrame picture;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
33
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
34 int width, height;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
35 int bpp;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
36 int color_type;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
37 int compression_type;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
38 } TargaContext;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
39
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
40 static void targa_decode_rle(AVCodecContext *avctx, TargaContext *s, uint8_t *src, uint8_t *dst, int w, int h, int stride, int bpp)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
41 {
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
42 int i, x, y;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
43 int depth = (bpp + 1) >> 3;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
44 int type, count;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
45 int diff;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
46
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
47 diff = stride - w * depth;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
48 x = y = 0;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
49 while(y < h){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
50 type = *src++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
51 count = (type & 0x7F) + 1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
52 type &= 0x80;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
53 if((x + count > w) && (x + count + 1 > (h - y) * w)){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
54 av_log(avctx, AV_LOG_ERROR, "Packet went out of bounds: position (%i,%i) size %i\n", x, y, count);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
55 return;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
56 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
57 for(i = 0; i < count; i++){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
58 switch(depth){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
59 case 1:
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
60 *dst = *src;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
61 break;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
62 case 2:
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
63 *((uint16_t*)dst) = AV_RL16(src);
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
64 break;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
65 case 3:
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
66 dst[0] = src[0];
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
67 dst[1] = src[1];
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
68 dst[2] = src[2];
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
69 break;
4132
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
70 case 4:
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
71 *((uint32_t*)dst) = AV_RL32(src);
4132
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
72 break;
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
73 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
74 dst += depth;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
75 if(!type)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
76 src += depth;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
77
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
78 x++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
79 if(x == w){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
80 x = 0;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
81 y++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
82 dst += diff;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
83 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
84 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
85 if(type)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
86 src += depth;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
87 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
88 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
89
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
90 static int decode_frame(AVCodecContext *avctx,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
91 void *data, int *data_size,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
92 uint8_t *buf, int buf_size)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
93 {
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
94 TargaContext * const s = avctx->priv_data;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
95 AVFrame *picture = data;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
96 AVFrame * const p= (AVFrame*)&s->picture;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
97 uint8_t *dst;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
98 int stride;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
99 int idlen, pal, compr, x, y, w, h, bpp, flags;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
100 int first_clr, colors, csize;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
101
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
102 /* parse image header */
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
103 idlen = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
104 pal = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
105 compr = *buf++;
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
106 first_clr = AV_RL16(buf); buf += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
107 colors = AV_RL16(buf); buf += 2;
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
108 csize = *buf++;
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
109 x = AV_RL16(buf); buf += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
110 y = AV_RL16(buf); buf += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
111 w = AV_RL16(buf); buf += 2;
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
112 h = AV_RL16(buf); buf += 2;
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
113 bpp = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
114 flags = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
115 //skip identifier if any
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
116 buf += idlen;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
117 s->bpp = bpp;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
118 s->width = w;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
119 s->height = h;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
120 switch(s->bpp){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
121 case 8:
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
122 avctx->pix_fmt = ((compr & (~TGA_RLE)) == TGA_BW) ? PIX_FMT_GRAY8 : PIX_FMT_PAL8;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
123 break;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
124 case 15:
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
125 avctx->pix_fmt = PIX_FMT_RGB555;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
126 break;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
127 case 16:
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
128 avctx->pix_fmt = PIX_FMT_RGB555;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
129 break;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
130 case 24:
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
131 avctx->pix_fmt = PIX_FMT_BGR24;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
132 break;
4132
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
133 case 32:
4494
ce643a22f049 Replace deprecated PIX_FMT names by the newer variants.
diego
parents: 4364
diff changeset
134 avctx->pix_fmt = PIX_FMT_RGB32;
4132
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
135 break;
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
136 default:
4128
2e93c877d264 Use bpp from header in error message
kostya
parents: 3986
diff changeset
137 av_log(avctx, AV_LOG_ERROR, "Bit depth %i is not supported\n", s->bpp);
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
138 return -1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
139 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
140
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
141 if(s->picture.data[0])
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
142 avctx->release_buffer(avctx, &s->picture);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
143
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
144 if(avcodec_check_dimensions(avctx, w, h))
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
145 return -1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
146 if(w != avctx->width || h != avctx->height)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
147 avcodec_set_dimensions(avctx, w, h);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
148 if(avctx->get_buffer(avctx, p) < 0){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
149 av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
150 return -1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
151 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
152 if(flags & 0x20){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
153 dst = p->data[0];
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
154 stride = p->linesize[0];
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
155 }else{ //image is upside-down
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
156 dst = p->data[0] + p->linesize[0] * (h - 1);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
157 stride = -p->linesize[0];
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
158 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
159
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
160 if(avctx->pix_fmt == PIX_FMT_PAL8 && avctx->palctrl){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
161 memcpy(p->data[1], avctx->palctrl->palette, AVPALETTE_SIZE);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
162 if(avctx->palctrl->palette_changed){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
163 p->palette_has_changed = 1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
164 avctx->palctrl->palette_changed = 0;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
165 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
166 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
167 if(colors){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
168 if((colors + first_clr) > 256){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
169 av_log(avctx, AV_LOG_ERROR, "Incorrect palette: %i colors with offset %i\n", colors, first_clr);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
170 return -1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
171 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
172 if(csize != 24){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
173 av_log(avctx, AV_LOG_ERROR, "Palette entry size %i bits is not supported\n", csize);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
174 return -1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
175 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
176 if(avctx->pix_fmt != PIX_FMT_PAL8)//should not occur but skip palette anyway
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
177 buf += colors * ((csize + 1) >> 3);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
178 else{
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
179 int r, g, b, t;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
180 int32_t *pal = ((int32_t*)p->data[1]) + first_clr;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
181 for(t = 0; t < colors; t++){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
182 r = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
183 g = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
184 b = *buf++;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
185 *pal++ = (b << 16) | (g << 8) | r;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
186 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
187 p->palette_has_changed = 1;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
188 avctx->palctrl->palette_changed = 0;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
189 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
190 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
191 if((compr & (~TGA_RLE)) == TGA_NODATA)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
192 memset(p->data[0], 0, p->linesize[0] * s->height);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
193 else{
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
194 if(compr & TGA_RLE)
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
195 targa_decode_rle(avctx, s, buf, dst, avctx->width, avctx->height, stride, bpp);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
196 else{
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
197 for(y = 0; y < s->height; y++){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
198 #ifdef WORDS_BIGENDIAN
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
199 if((s->bpp + 1) >> 3 == 2){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
200 uint16_t *dst16 = (uint16_t*)dst;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
201 for(x = 0; x < s->width; x++)
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
202 dst16[x] = AV_RL16(buf + x * 2);
4132
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
203 }else if((s->bpp + 1) >> 3 == 4){
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
204 uint32_t *dst32 = (uint32_t*)dst;
c9e0315f9954 RGB32 support in Targa
kostya
parents: 4128
diff changeset
205 for(x = 0; x < s->width; x++)
4364
05e932ddaaa9 rename BE/LE_8/16/32 to AV_RL/B_8/16/32
alex
parents: 4132
diff changeset
206 dst32[x] = AV_RL32(buf + x * 4);
3986
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
207 }else
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
208 #endif
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
209 memcpy(dst, buf, s->width * ((s->bpp + 1) >> 3));
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
210
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
211 dst += stride;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
212 buf += s->width * ((s->bpp + 1) >> 3);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
213 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
214 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
215 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
216
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
217 *picture= *(AVFrame*)&s->picture;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
218 *data_size = sizeof(AVPicture);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
219
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
220 return buf_size;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
221 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
222
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
223 static int targa_init(AVCodecContext *avctx){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
224 TargaContext *s = avctx->priv_data;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
225
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
226 avcodec_get_frame_defaults((AVFrame*)&s->picture);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
227 avctx->coded_frame= (AVFrame*)&s->picture;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
228 s->picture.data[0] = NULL;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
229
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
230 return 0;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
231 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
232
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
233 static int targa_end(AVCodecContext *avctx){
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
234 TargaContext *s = avctx->priv_data;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
235
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
236 if(s->picture.data[0])
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
237 avctx->release_buffer(avctx, &s->picture);
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
238
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
239 return 0;
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
240 }
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
241
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
242 AVCodec targa_decoder = {
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
243 "targa",
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
244 CODEC_TYPE_VIDEO,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
245 CODEC_ID_TARGA,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
246 sizeof(TargaContext),
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
247 targa_init,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
248 NULL,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
249 targa_end,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
250 decode_frame,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
251 0,
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
252 NULL
54c7481b381e Targa image decoder
kostya
parents:
diff changeset
253 };