Mercurial > libavformat.hg
annotate raw.c @ 128:45633cd5518a libavformat
* introducing new public interface in imgconvert.c
+ avcodec_get_pix_fmt
converts textual representation of pixel format into
the actual id. Complements avcodec_get_pix_fmt_name.
+ avpicture_layout
serializes given picture into a flat array.
Complements avpicture_fill.
* adding a new option -pix_fmt to the ffmpeg, in order to control
pixel format for the codecs that do support it, like rawvideo,
for example.
* reducing complexity of the rawvideo codec by splitting it in two
and making it more reliable via hooking up to the avpicture_layout.
Plus adding new FourCC as described here: http://www.fourcc.org
* A tiny fix for avienc.c that makes avih and video strf consistent
regarding codec FourCC.
author | romansh |
---|---|
date | Wed, 07 May 2003 19:01:45 +0000 |
parents | 23f62139c013 |
children | 56590088f801 |
rev | line source |
---|---|
0 | 1 /* |
2 * RAW encoder and decoder | |
3 * Copyright (c) 2001 Fabrice Bellard. | |
4 * | |
5 * This library is free software; you can redistribute it and/or | |
6 * modify it under the terms of the GNU Lesser General Public | |
7 * License as published by the Free Software Foundation; either | |
8 * version 2 of the License, or (at your option) any later version. | |
9 * | |
10 * This library is distributed in the hope that it will be useful, | |
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 * Lesser General Public License for more details. | |
14 * | |
15 * You should have received a copy of the GNU Lesser General Public | |
16 * License along with this library; if not, write to the Free Software | |
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
18 */ | |
19 #include "avformat.h" | |
20 | |
21 /* simple formats */ | |
64 | 22 static int raw_write_header(struct AVFormatContext *s) |
0 | 23 { |
24 return 0; | |
25 } | |
26 | |
64 | 27 static int raw_write_packet(struct AVFormatContext *s, int stream_index, |
28 unsigned char *buf, int size, int force_pts) | |
0 | 29 { |
30 put_buffer(&s->pb, buf, size); | |
31 put_flush_packet(&s->pb); | |
32 return 0; | |
33 } | |
34 | |
64 | 35 static int raw_write_trailer(struct AVFormatContext *s) |
0 | 36 { |
37 return 0; | |
38 } | |
39 | |
40 /* raw input */ | |
65 | 41 static int raw_read_header(AVFormatContext *s, AVFormatParameters *ap) |
0 | 42 { |
43 AVStream *st; | |
44 int id; | |
45 | |
46 st = av_new_stream(s, 0); | |
47 if (!st) | |
48 return AVERROR_NOMEM; | |
49 if (ap) { | |
50 id = s->iformat->value; | |
51 if (id == CODEC_ID_RAWVIDEO) { | |
52 st->codec.codec_type = CODEC_TYPE_VIDEO; | |
53 } else { | |
54 st->codec.codec_type = CODEC_TYPE_AUDIO; | |
55 } | |
56 st->codec.codec_id = id; | |
57 | |
58 switch(st->codec.codec_type) { | |
59 case CODEC_TYPE_AUDIO: | |
60 st->codec.sample_rate = ap->sample_rate; | |
61 st->codec.channels = ap->channels; | |
62 break; | |
63 case CODEC_TYPE_VIDEO: | |
85
25062c9b1f86
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
65
diff
changeset
|
64 st->codec.frame_rate = ap->frame_rate; |
25062c9b1f86
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
65
diff
changeset
|
65 st->codec.frame_rate_base = ap->frame_rate_base; |
0 | 66 st->codec.width = ap->width; |
67 st->codec.height = ap->height; | |
128 | 68 st->codec.pix_fmt = ap->pix_fmt; |
0 | 69 break; |
70 default: | |
71 return -1; | |
72 } | |
73 } else { | |
74 return -1; | |
75 } | |
76 return 0; | |
77 } | |
78 | |
79 #define RAW_PACKET_SIZE 1024 | |
80 | |
64 | 81 static int raw_read_packet(AVFormatContext *s, AVPacket *pkt) |
0 | 82 { |
83 int ret, size; | |
28 | 84 // AVStream *st = s->streams[0]; |
0 | 85 |
86 size= RAW_PACKET_SIZE; | |
87 | |
88 if (av_new_packet(pkt, size) < 0) | |
89 return -EIO; | |
90 | |
91 pkt->stream_index = 0; | |
92 ret = get_buffer(&s->pb, pkt->data, size); | |
93 if (ret <= 0) { | |
94 av_free_packet(pkt); | |
95 return -EIO; | |
96 } | |
97 /* note: we need to modify the packet size here to handle the last | |
98 packet */ | |
99 pkt->size = ret; | |
100 return ret; | |
101 } | |
102 | |
64 | 103 static int raw_read_close(AVFormatContext *s) |
0 | 104 { |
105 return 0; | |
106 } | |
107 | |
108 /* mp3 read */ | |
109 static int mp3_read_header(AVFormatContext *s, | |
110 AVFormatParameters *ap) | |
111 { | |
112 AVStream *st; | |
125
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
113 int pos; |
0 | 114 |
115 st = av_new_stream(s, 0); | |
116 if (!st) | |
117 return AVERROR_NOMEM; | |
118 | |
119 st->codec.codec_type = CODEC_TYPE_AUDIO; | |
120 st->codec.codec_id = CODEC_ID_MP2; | |
125
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
121 |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
122 /* looking for 11111111 111MMLLC - MPEG synchronization tag |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
123 MM: 00 - MPEG-2.5, 10 - MPEG-2, 11 - MPEG-1 |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
124 LL: 11 - Layer I, 10 - Layer II, 01 - Layer III |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
125 XXX: this code does not read more bytes from file |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
126 so if ID3 (or other stuff) length > IO_BUFFER_SIZE it fails back to CODEC_ID_MP2 */ |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
127 for(pos=0; pos < s->pb.buffer_size-1; pos++) |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
128 if( s->pb.buffer[pos] == 0xFF && (s->pb.buffer[pos] & 0xE0) == 0xE0 ) |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
129 break; |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
130 |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
131 if( pos < s->pb.buffer_size-1 && (s->pb.buffer[pos+1] & 6) == 2 ) |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
132 st->codec.codec_id = CODEC_ID_MP3LAME; |
7500e14259a6
mp3 codec autodetection patch by (Andriy Rysin <arysin at bcsii dot net>)
michaelni
parents:
100
diff
changeset
|
133 |
0 | 134 /* the parameters will be extracted from the compressed bitstream */ |
135 return 0; | |
136 } | |
137 | |
63 | 138 /* ac3 read */ |
139 static int ac3_read_header(AVFormatContext *s, | |
140 AVFormatParameters *ap) | |
141 { | |
142 AVStream *st; | |
143 | |
144 st = av_new_stream(s, 0); | |
145 if (!st) | |
146 return AVERROR_NOMEM; | |
147 | |
148 st->codec.codec_type = CODEC_TYPE_AUDIO; | |
149 st->codec.codec_id = CODEC_ID_AC3; | |
150 /* the parameters will be extracted from the compressed bitstream */ | |
151 return 0; | |
152 } | |
153 | |
0 | 154 /* mpeg1/h263 input */ |
155 static int video_read_header(AVFormatContext *s, | |
156 AVFormatParameters *ap) | |
157 { | |
158 AVStream *st; | |
159 | |
160 st = av_new_stream(s, 0); | |
161 if (!st) | |
162 return AVERROR_NOMEM; | |
163 | |
164 st->codec.codec_type = CODEC_TYPE_VIDEO; | |
165 st->codec.codec_id = s->iformat->value; | |
166 /* for mjpeg, specify frame rate */ | |
167 /* for mpeg4 specify it too (most mpeg4 streams dont have the fixed_vop_rate set ...)*/ | |
168 if (st->codec.codec_id == CODEC_ID_MJPEG || st->codec.codec_id == CODEC_ID_MPEG4) { | |
169 if (ap) { | |
85
25062c9b1f86
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
65
diff
changeset
|
170 st->codec.frame_rate = ap->frame_rate; |
25062c9b1f86
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
65
diff
changeset
|
171 st->codec.frame_rate_base = ap->frame_rate_base; |
0 | 172 } else { |
85
25062c9b1f86
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
65
diff
changeset
|
173 st->codec.frame_rate = 25; |
25062c9b1f86
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
65
diff
changeset
|
174 st->codec.frame_rate_base = 1; |
0 | 175 } |
176 } | |
177 return 0; | |
178 } | |
179 | |
180 #define SEQ_START_CODE 0x000001b3 | |
181 #define GOP_START_CODE 0x000001b8 | |
182 #define PICTURE_START_CODE 0x00000100 | |
183 | |
184 /* XXX: improve that by looking at several start codes */ | |
185 static int mpegvideo_probe(AVProbeData *p) | |
186 { | |
49 | 187 int code; |
188 const uint8_t *d; | |
0 | 189 |
190 /* we search the first start code. If it is a sequence, gop or | |
191 picture start code then we decide it is an mpeg video | |
192 stream. We do not send highest value to give a chance to mpegts */ | |
49 | 193 /* NOTE: the search range was restricted to avoid too many false |
194 detections */ | |
195 | |
196 if (p->buf_size < 6) | |
197 return 0; | |
198 d = p->buf; | |
199 code = (d[0] << 24) | (d[1] << 16) | (d[2] << 8) | (d[3]); | |
200 if ((code & 0xffffff00) == 0x100) { | |
201 if (code == SEQ_START_CODE || | |
202 code == GOP_START_CODE || | |
203 code == PICTURE_START_CODE) | |
204 return 50 - 1; | |
205 else | |
206 return 0; | |
0 | 207 } |
208 return 0; | |
209 } | |
210 | |
211 AVInputFormat mp3_iformat = { | |
212 "mp3", | |
213 "MPEG audio", | |
214 0, | |
215 NULL, | |
216 mp3_read_header, | |
217 raw_read_packet, | |
218 raw_read_close, | |
219 .extensions = "mp2,mp3", /* XXX: use probe */ | |
220 }; | |
221 | |
222 AVOutputFormat mp2_oformat = { | |
223 "mp2", | |
224 "MPEG audio layer 2", | |
225 "audio/x-mpeg", | |
126
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
226 #ifdef CONFIG_MP3LAME |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
227 "mp2", |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
228 #else |
0 | 229 "mp2,mp3", |
126
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
230 #endif |
0 | 231 0, |
232 CODEC_ID_MP2, | |
233 0, | |
234 raw_write_header, | |
235 raw_write_packet, | |
236 raw_write_trailer, | |
237 }; | |
238 | |
126
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
239 #ifdef CONFIG_MP3LAME |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
240 AVOutputFormat mp3_oformat = { |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
241 "mp3", |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
242 "MPEG audio layer 3", |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
243 "audio/x-mpeg", |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
244 "mp3", |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
245 0, |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
246 CODEC_ID_MP3LAME, |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
247 0, |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
248 raw_write_header, |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
249 raw_write_packet, |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
250 raw_write_trailer, |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
251 }; |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
252 #endif |
0 | 253 |
254 AVInputFormat ac3_iformat = { | |
255 "ac3", | |
256 "raw ac3", | |
257 0, | |
258 NULL, | |
63 | 259 ac3_read_header, |
0 | 260 raw_read_packet, |
261 raw_read_close, | |
262 .extensions = "ac3", | |
263 }; | |
264 | |
265 AVOutputFormat ac3_oformat = { | |
266 "ac3", | |
267 "raw ac3", | |
268 "audio/x-ac3", | |
269 "ac3", | |
270 0, | |
271 CODEC_ID_AC3, | |
272 0, | |
273 raw_write_header, | |
274 raw_write_packet, | |
275 raw_write_trailer, | |
276 }; | |
277 | |
278 AVOutputFormat h263_oformat = { | |
279 "h263", | |
280 "raw h263", | |
281 "video/x-h263", | |
282 "h263", | |
283 0, | |
284 0, | |
285 CODEC_ID_H263, | |
286 raw_write_header, | |
287 raw_write_packet, | |
288 raw_write_trailer, | |
289 }; | |
290 | |
291 AVInputFormat m4v_iformat = { | |
292 "m4v", | |
293 "raw MPEG4 video format", | |
294 0, | |
295 NULL /*mpegvideo_probe*/, | |
296 video_read_header, | |
297 raw_read_packet, | |
298 raw_read_close, | |
299 .extensions = "m4v", //FIXME remove after writing mpeg4_probe | |
300 .value = CODEC_ID_MPEG4, | |
301 }; | |
302 | |
303 AVOutputFormat m4v_oformat = { | |
304 "m4v", | |
305 "raw MPEG4 video format", | |
306 NULL, | |
307 "m4v", | |
308 0, | |
309 CODEC_ID_NONE, | |
310 CODEC_ID_MPEG4, | |
311 raw_write_header, | |
312 raw_write_packet, | |
313 raw_write_trailer, | |
314 }; | |
315 | |
100 | 316 AVInputFormat h264_iformat = { |
317 "h264", | |
318 "raw H264 video format", | |
319 0, | |
320 NULL /*mpegvideo_probe*/, | |
321 video_read_header, | |
322 raw_read_packet, | |
323 raw_read_close, | |
324 .extensions = "h26l,h264", //FIXME remove after writing mpeg4_probe | |
325 .value = CODEC_ID_H264, | |
326 }; | |
327 | |
328 AVOutputFormat h264_oformat = { | |
329 "h264", | |
330 "raw H264 video format", | |
331 NULL, | |
332 "h264", | |
333 0, | |
334 CODEC_ID_NONE, | |
335 CODEC_ID_H264, | |
336 raw_write_header, | |
337 raw_write_packet, | |
338 raw_write_trailer, | |
339 }; | |
340 | |
0 | 341 AVInputFormat mpegvideo_iformat = { |
342 "mpegvideo", | |
343 "MPEG video", | |
344 0, | |
345 mpegvideo_probe, | |
346 video_read_header, | |
347 raw_read_packet, | |
348 raw_read_close, | |
349 .value = CODEC_ID_MPEG1VIDEO, | |
350 }; | |
351 | |
352 AVOutputFormat mpeg1video_oformat = { | |
353 "mpeg1video", | |
354 "MPEG video", | |
355 "video/x-mpeg", | |
356 "mpg,mpeg", | |
357 0, | |
358 0, | |
359 CODEC_ID_MPEG1VIDEO, | |
360 raw_write_header, | |
361 raw_write_packet, | |
362 raw_write_trailer, | |
363 }; | |
364 | |
365 AVInputFormat mjpeg_iformat = { | |
366 "mjpeg", | |
367 "MJPEG video", | |
368 0, | |
369 NULL, | |
370 video_read_header, | |
371 raw_read_packet, | |
372 raw_read_close, | |
373 .extensions = "mjpg,mjpeg", | |
374 .value = CODEC_ID_MJPEG, | |
375 }; | |
376 | |
377 AVOutputFormat mjpeg_oformat = { | |
378 "mjpeg", | |
379 "MJPEG video", | |
380 "video/x-mjpeg", | |
381 "mjpg,mjpeg", | |
382 0, | |
383 0, | |
384 CODEC_ID_MJPEG, | |
385 raw_write_header, | |
386 raw_write_packet, | |
387 raw_write_trailer, | |
388 }; | |
389 | |
390 /* pcm formats */ | |
391 | |
392 #define PCMDEF(name, long_name, ext, codec) \ | |
393 AVInputFormat pcm_ ## name ## _iformat = {\ | |
394 #name,\ | |
395 long_name,\ | |
396 0,\ | |
397 NULL,\ | |
398 raw_read_header,\ | |
399 raw_read_packet,\ | |
400 raw_read_close,\ | |
401 .extensions = ext,\ | |
402 .value = codec,\ | |
403 };\ | |
404 \ | |
405 AVOutputFormat pcm_ ## name ## _oformat = {\ | |
406 #name,\ | |
407 long_name,\ | |
408 NULL,\ | |
409 ext,\ | |
410 0,\ | |
411 codec,\ | |
412 0,\ | |
413 raw_write_header,\ | |
414 raw_write_packet,\ | |
415 raw_write_trailer,\ | |
416 }; | |
417 | |
418 #ifdef WORDS_BIGENDIAN | |
419 #define BE_DEF(s) s | |
420 #define LE_DEF(s) NULL | |
421 #else | |
422 #define BE_DEF(s) NULL | |
423 #define LE_DEF(s) s | |
424 #endif | |
425 | |
426 | |
427 PCMDEF(s16le, "pcm signed 16 bit little endian format", | |
428 LE_DEF("sw"), CODEC_ID_PCM_S16LE) | |
429 | |
430 PCMDEF(s16be, "pcm signed 16 bit big endian format", | |
431 BE_DEF("sw"), CODEC_ID_PCM_S16BE) | |
432 | |
433 PCMDEF(u16le, "pcm unsigned 16 bit little endian format", | |
434 LE_DEF("uw"), CODEC_ID_PCM_U16LE) | |
435 | |
436 PCMDEF(u16be, "pcm unsigned 16 bit big endian format", | |
437 BE_DEF("uw"), CODEC_ID_PCM_U16BE) | |
438 | |
439 PCMDEF(s8, "pcm signed 8 bit format", | |
440 "sb", CODEC_ID_PCM_S8) | |
441 | |
442 PCMDEF(u8, "pcm unsigned 8 bit format", | |
443 "ub", CODEC_ID_PCM_U8) | |
444 | |
445 PCMDEF(mulaw, "pcm mu law format", | |
446 "ul", CODEC_ID_PCM_MULAW) | |
447 | |
448 PCMDEF(alaw, "pcm A law format", | |
449 "al", CODEC_ID_PCM_ALAW) | |
450 | |
64 | 451 static int rawvideo_read_packet(AVFormatContext *s, AVPacket *pkt) |
0 | 452 { |
453 int packet_size, ret, width, height; | |
454 AVStream *st = s->streams[0]; | |
455 | |
456 width = st->codec.width; | |
457 height = st->codec.height; | |
458 | |
128 | 459 packet_size = avpicture_get_size(st->codec.pix_fmt, width, height); |
460 if (packet_size < 0) | |
0 | 461 av_abort(); |
462 | |
463 if (av_new_packet(pkt, packet_size) < 0) | |
464 return -EIO; | |
465 | |
466 pkt->stream_index = 0; | |
467 #if 0 | |
468 /* bypass buffered I/O */ | |
469 ret = url_read(url_fileno(&s->pb), pkt->data, pkt->size); | |
470 #else | |
471 ret = get_buffer(&s->pb, pkt->data, pkt->size); | |
472 #endif | |
473 if (ret != pkt->size) { | |
474 av_free_packet(pkt); | |
475 return -EIO; | |
476 } else { | |
477 return 0; | |
478 } | |
479 } | |
480 | |
481 AVInputFormat rawvideo_iformat = { | |
482 "rawvideo", | |
483 "raw video format", | |
484 0, | |
485 NULL, | |
486 raw_read_header, | |
487 rawvideo_read_packet, | |
488 raw_read_close, | |
489 .extensions = "yuv", | |
490 .value = CODEC_ID_RAWVIDEO, | |
491 }; | |
492 | |
493 AVOutputFormat rawvideo_oformat = { | |
494 "rawvideo", | |
495 "raw video format", | |
496 NULL, | |
497 "yuv", | |
498 0, | |
499 CODEC_ID_NONE, | |
500 CODEC_ID_RAWVIDEO, | |
501 raw_write_header, | |
502 raw_write_packet, | |
503 raw_write_trailer, | |
504 }; | |
505 | |
506 static int null_write_packet(struct AVFormatContext *s, | |
507 int stream_index, | |
508 unsigned char *buf, int size, int force_pts) | |
509 { | |
510 return 0; | |
511 } | |
512 | |
513 AVOutputFormat null_oformat = { | |
514 "null", | |
515 "null video format", | |
516 NULL, | |
517 NULL, | |
518 0, | |
519 #ifdef WORDS_BIGENDIAN | |
520 CODEC_ID_PCM_S16BE, | |
521 #else | |
522 CODEC_ID_PCM_S16LE, | |
523 #endif | |
524 CODEC_ID_RAWVIDEO, | |
525 raw_write_header, | |
526 null_write_packet, | |
527 raw_write_trailer, | |
528 .flags = AVFMT_NOFILE | AVFMT_RAWPICTURE, | |
529 }; | |
530 | |
531 int raw_init(void) | |
532 { | |
533 av_register_input_format(&mp3_iformat); | |
534 av_register_output_format(&mp2_oformat); | |
126
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
535 #ifdef CONFIG_MP3LAME |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
536 av_register_output_format(&mp3_oformat); |
23f62139c013
prefers MP3 codec (rather than MP2) for output if
michaelni
parents:
125
diff
changeset
|
537 #endif |
0 | 538 av_register_input_format(&ac3_iformat); |
539 av_register_output_format(&ac3_oformat); | |
540 | |
541 av_register_output_format(&h263_oformat); | |
542 | |
543 av_register_input_format(&m4v_iformat); | |
544 av_register_output_format(&m4v_oformat); | |
100 | 545 |
546 av_register_input_format(&h264_iformat); | |
547 av_register_output_format(&h264_oformat); | |
0 | 548 |
549 av_register_input_format(&mpegvideo_iformat); | |
550 av_register_output_format(&mpeg1video_oformat); | |
551 | |
552 av_register_input_format(&mjpeg_iformat); | |
553 av_register_output_format(&mjpeg_oformat); | |
554 | |
555 av_register_input_format(&pcm_s16le_iformat); | |
556 av_register_output_format(&pcm_s16le_oformat); | |
557 av_register_input_format(&pcm_s16be_iformat); | |
558 av_register_output_format(&pcm_s16be_oformat); | |
559 av_register_input_format(&pcm_u16le_iformat); | |
560 av_register_output_format(&pcm_u16le_oformat); | |
561 av_register_input_format(&pcm_u16be_iformat); | |
562 av_register_output_format(&pcm_u16be_oformat); | |
563 av_register_input_format(&pcm_s8_iformat); | |
564 av_register_output_format(&pcm_s8_oformat); | |
565 av_register_input_format(&pcm_u8_iformat); | |
566 av_register_output_format(&pcm_u8_oformat); | |
567 av_register_input_format(&pcm_mulaw_iformat); | |
568 av_register_output_format(&pcm_mulaw_oformat); | |
569 av_register_input_format(&pcm_alaw_iformat); | |
570 av_register_output_format(&pcm_alaw_oformat); | |
571 | |
572 av_register_input_format(&rawvideo_iformat); | |
573 av_register_output_format(&rawvideo_oformat); | |
574 | |
575 av_register_output_format(&null_oformat); | |
576 return 0; | |
577 } |