annotate img.c @ 47:45308962220f libavformat

added jpeg image encoder and decoder (new YUV handling routines and mjpeg codec fixes are necessary to go further)
author bellard
date Sun, 02 Feb 2003 19:18:09 +0000
parents 65433f1b2549
children b0e0eb595e29
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
1 /*
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
2 * Image format
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
3 * Copyright (c) 2000, 2001, 2002 Fabrice Bellard.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
4 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
5 * This library is free software; you can redistribute it and/or
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
8 * version 2 of the License, or (at your option) any later version.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
9 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
10 * This library is distributed in the hope that it will be useful,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
13 * Lesser General Public License for more details.
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
14 *
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
16 * License along with this library; if not, write to the Free Software
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
18 */
8
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
19 #include <unistd.h>
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
20 #include "avformat.h"
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
21
11
932b59c66c60 mingw patch by (Bill Eldridge <bill at rfa dot org>)
michaelni
parents: 10
diff changeset
22 #ifdef __MINGW32__
932b59c66c60 mingw patch by (Bill Eldridge <bill at rfa dot org>)
michaelni
parents: 10
diff changeset
23 # include <windows.h>
12
d58c983a19a7 redid usleep() fix for BeOS, more consistant with the MINGW32 one. removed a TAB :P
mmu_man
parents: 11
diff changeset
24 # define usleep(t) Sleep((t) / 1000)
d58c983a19a7 redid usleep() fix for BeOS, more consistant with the MINGW32 one. removed a TAB :P
mmu_man
parents: 11
diff changeset
25 #endif
d58c983a19a7 redid usleep() fix for BeOS, more consistant with the MINGW32 one. removed a TAB :P
mmu_man
parents: 11
diff changeset
26 #ifdef __BEOS__
d58c983a19a7 redid usleep() fix for BeOS, more consistant with the MINGW32 one. removed a TAB :P
mmu_man
parents: 11
diff changeset
27 # ifndef usleep
d58c983a19a7 redid usleep() fix for BeOS, more consistant with the MINGW32 one. removed a TAB :P
mmu_man
parents: 11
diff changeset
28 # include <OS.h>
22
65433f1b2549 os2 support patch by ("Slavik Gnatenko" <miracle9 at newmail dot ru>)
michaelni
parents: 21
diff changeset
29 # define usleep(t) snooze((bigtime_t)(t))
12
d58c983a19a7 redid usleep() fix for BeOS, more consistant with the MINGW32 one. removed a TAB :P
mmu_man
parents: 11
diff changeset
30 # endif
11
932b59c66c60 mingw patch by (Bill Eldridge <bill at rfa dot org>)
michaelni
parents: 10
diff changeset
31 #endif
22
65433f1b2549 os2 support patch by ("Slavik Gnatenko" <miracle9 at newmail dot ru>)
michaelni
parents: 21
diff changeset
32 #if defined(CONFIG_OS2)
65433f1b2549 os2 support patch by ("Slavik Gnatenko" <miracle9 at newmail dot ru>)
michaelni
parents: 21
diff changeset
33 # include <stdlib.h>
65433f1b2549 os2 support patch by ("Slavik Gnatenko" <miracle9 at newmail dot ru>)
michaelni
parents: 21
diff changeset
34 # define usleep(t) _sleep2((t) / 1000)
65433f1b2549 os2 support patch by ("Slavik Gnatenko" <miracle9 at newmail dot ru>)
michaelni
parents: 21
diff changeset
35 #endif
11
932b59c66c60 mingw patch by (Bill Eldridge <bill at rfa dot org>)
michaelni
parents: 10
diff changeset
36
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
37 typedef struct {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
38 int width;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
39 int height;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
40 int img_number;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
41 int img_size;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
42 AVImageFormat *img_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
43 int pix_fmt;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
44 int is_pipe;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
45 char path[1024];
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
46 /* temporary usage */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
47 void *ptr;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
48 } VideoData;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
49
8
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
50 int emulate_frame_rate;
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
51
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
52 static int image_probe(AVProbeData *p)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
53 {
21
3d2d2f8725f9 jpeg detection fix - fixed imagepipe output
bellard
parents: 20
diff changeset
54 if (filename_number_test(p->filename) >= 0 && guess_image_format(p->filename))
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
55 return AVPROBE_SCORE_MAX;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
56 else
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
57 return 0;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
58 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
59
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
60 static int read_header_alloc_cb(void *opaque, AVImageInfo *info)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
61 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
62 VideoData *s = opaque;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
63
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
64 s->width = info->width;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
65 s->height = info->height;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
66 s->pix_fmt = info->pix_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
67 /* stop image reading but no error */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
68 return 1;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
69 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
70
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
71 static int img_read_header(AVFormatContext *s1, AVFormatParameters *ap)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
72 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
73 VideoData *s = s1->priv_data;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
74 int i, ret;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
75 char buf[1024];
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
76 ByteIOContext pb1, *f = &pb1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
77 AVStream *st;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
78
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
79 st = av_new_stream(s1, 0);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
80 if (!st) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
81 av_free(s);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
82 return -ENOMEM;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
83 }
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
84
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
85 if (ap && ap->image_format)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
86 s->img_fmt = ap->image_format;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
87
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
88 strcpy(s->path, s1->filename);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
89 s->img_number = 0;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
90
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
91 /* find format */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
92 if (s1->iformat->flags & AVFMT_NOFILE)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
93 s->is_pipe = 0;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
94 else
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
95 s->is_pipe = 1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
96
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
97 if (!s->is_pipe) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
98 /* try to find the first image */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
99 for(i=0;i<5;i++) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
100 if (get_frame_filename(buf, sizeof(buf), s->path, s->img_number) < 0)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
101 goto fail;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
102 if (url_fopen(f, buf, URL_RDONLY) >= 0)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
103 break;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
104 s->img_number++;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
105 }
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
106 if (i == 5)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
107 goto fail;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
108 } else {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
109 f = &s1->pb;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
110 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
111
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
112 ret = av_read_image(f, s1->filename, s->img_fmt, read_header_alloc_cb, s);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
113 if (ret < 0)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
114 goto fail1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
115
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
116 if (!s->is_pipe) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
117 url_fclose(f);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
118 } else {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
119 url_fseek(f, 0, SEEK_SET);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
120 }
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
121
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
122 st->codec.codec_type = CODEC_TYPE_VIDEO;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
123 st->codec.codec_id = CODEC_ID_RAWVIDEO;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
124 st->codec.width = s->width;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
125 st->codec.height = s->height;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
126 st->codec.pix_fmt = s->pix_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
127 s->img_size = avpicture_get_size(s->pix_fmt, s->width, s->height);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
128
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
129 if (!ap || !ap->frame_rate)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
130 st->codec.frame_rate = 25 * FRAME_RATE_BASE;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
131 else
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
132 st->codec.frame_rate = ap->frame_rate;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
133
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
134 return 0;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
135 fail1:
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
136 if (!s->is_pipe)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
137 url_fclose(f);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
138 fail:
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
139 av_free(s);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
140 return -EIO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
141 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
142
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
143 static int read_packet_alloc_cb(void *opaque, AVImageInfo *info)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
144 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
145 VideoData *s = opaque;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
146
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
147 if (info->width != s->width ||
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
148 info->height != s->height)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
149 return -1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
150 avpicture_fill(&info->pict, s->ptr, info->pix_fmt, info->width, info->height);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
151 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
152 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
153
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
154 static int img_read_packet(AVFormatContext *s1, AVPacket *pkt)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
155 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
156 VideoData *s = s1->priv_data;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
157 char filename[1024];
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
158 int ret;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
159 ByteIOContext f1, *f;
8
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
160 static INT64 first_frame;
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
161
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
162 if (emulate_frame_rate) {
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
163 if (!first_frame) {
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
164 first_frame = av_gettime();
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
165 } else {
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
166 INT64 pts;
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
167 INT64 nowus;
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
168
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
169 nowus = av_gettime() - first_frame;
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
170
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
171 pts = ((INT64)s->img_number * FRAME_RATE_BASE * 1000000) / (s1->streams[0]->codec.frame_rate);
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
172
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
173 if (pts > nowus)
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
174 usleep(pts - nowus);
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
175 }
995bb04e02f1 * Add code to allow the img reader to read files at the nominal frame rate.
philipjsg
parents: 0
diff changeset
176 }
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
177
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
178 if (!s->is_pipe) {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
179 if (get_frame_filename(filename, sizeof(filename),
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
180 s->path, s->img_number) < 0)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
181 return -EIO;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
182 f = &f1;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
183 if (url_fopen(f, filename, URL_RDONLY) < 0)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
184 return -EIO;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
185 } else {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
186 f = &s1->pb;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
187 if (url_feof(f))
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
188 return -EIO;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
189 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
190
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
191 av_new_packet(pkt, s->img_size);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
192 pkt->stream_index = 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
193
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
194 s->ptr = pkt->data;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
195 ret = av_read_image(f, filename, s->img_fmt, read_packet_alloc_cb, s);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
196 if (!s->is_pipe) {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
197 url_fclose(f);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
198 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
199
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
200 if (ret < 0) {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
201 av_free_packet(pkt);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
202 return -EIO; /* signal EOF */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
203 } else {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
204 pkt->pts = ((INT64)s->img_number * s1->pts_den * FRAME_RATE_BASE) / (s1->streams[0]->codec.frame_rate * s1->pts_num);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
205 s->img_number++;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
206 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
207 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
208 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
209
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
210 static int img_read_close(AVFormatContext *s1)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
211 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
212 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
213 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
214
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
215 /******************************************************/
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
216 /* image output */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
217
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
218 static int img_set_parameters(AVFormatContext *s, AVFormatParameters *ap)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
219 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
220 VideoData *img = s->priv_data;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
221 AVStream *st;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
222 AVImageFormat *img_fmt;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
223 int i;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
224
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
225 /* find output image format */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
226 if (ap && ap->image_format) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
227 img_fmt = ap->image_format;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
228 } else {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
229 img_fmt = guess_image_format(s->filename);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
230 }
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
231 if (!img_fmt)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
232 return -1;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
233
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
234 if (s->nb_streams != 1)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
235 return -1;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
236
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
237 st = s->streams[0];
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
238 /* we select the first matching format */
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
239 for(i=0;i<PIX_FMT_NB;i++) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
240 if (img_fmt->supported_pixel_formats & (1 << i))
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
241 break;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
242 }
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
243 if (i >= PIX_FMT_NB)
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
244 return -1;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
245 img->img_fmt = img_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
246 img->pix_fmt = i;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
247 st->codec.pix_fmt = img->pix_fmt;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
248 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
249 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
250
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
251 static int img_write_header(AVFormatContext *s)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
252 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
253 VideoData *img = s->priv_data;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
254
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
255 img->img_number = 1;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
256 strcpy(img->path, s->filename);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
257
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
258 /* find format */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
259 if (s->oformat->flags & AVFMT_NOFILE)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
260 img->is_pipe = 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
261 else
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
262 img->is_pipe = 1;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
263
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
264 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
265 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
266
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
267 static int img_write_packet(AVFormatContext *s, int stream_index,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
268 UINT8 *buf, int size, int force_pts)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
269 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
270 VideoData *img = s->priv_data;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
271 AVStream *st = s->streams[stream_index];
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
272 ByteIOContext pb1, *pb;
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
273 AVPicture *picture;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
274 int width, height, ret;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
275 char filename[1024];
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
276 AVImageInfo info;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
277
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
278 width = st->codec.width;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
279 height = st->codec.height;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
280
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
281 picture = (AVPicture *)buf;
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
282
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
283 if (!img->is_pipe) {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
284 if (get_frame_filename(filename, sizeof(filename),
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
285 img->path, img->img_number) < 0)
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
286 return -EIO;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
287 pb = &pb1;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
288 if (url_fopen(pb, filename, URL_WRONLY) < 0)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
289 return -EIO;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
290 } else {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
291 pb = &s->pb;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
292 }
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
293 info.width = width;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
294 info.height = height;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
295 info.pix_fmt = st->codec.pix_fmt;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
296 info.pict = *picture;
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
297 ret = av_write_image(pb, img->img_fmt, &info);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
298 if (!img->is_pipe) {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
299 url_fclose(pb);
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
300 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
301
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
302 img->img_number++;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
303 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
304 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
305
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
306 static int img_write_trailer(AVFormatContext *s)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
307 {
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
308 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
309 }
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
310
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
311 /* input */
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
312
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
313 static AVInputFormat image_iformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
314 "image",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
315 "image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
316 sizeof(VideoData),
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
317 image_probe,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
318 img_read_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
319 img_read_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
320 img_read_close,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
321 NULL,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
322 AVFMT_NOFILE | AVFMT_NEEDNUMBER,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
323 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
324
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
325 static AVInputFormat imagepipe_iformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
326 "imagepipe",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
327 "piped image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
328 sizeof(VideoData),
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
329 NULL, /* no probe */
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
330 img_read_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
331 img_read_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
332 img_read_close,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
333 NULL,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
334 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
335
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
336
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
337 /* output */
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
338
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
339 static AVOutputFormat image_oformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
340 "image",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
341 "image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
342 "",
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
343 "",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
344 sizeof(VideoData),
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
345 CODEC_ID_NONE,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
346 CODEC_ID_RAWVIDEO,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
347 img_write_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
348 img_write_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
349 img_write_trailer,
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
350 AVFMT_NOFILE | AVFMT_NEEDNUMBER | AVFMT_RAWPICTURE,
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
351 img_set_parameters,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
352 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
353
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
354 static AVOutputFormat imagepipe_oformat = {
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
355 "imagepipe",
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
356 "piped image sequence",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
357 "",
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
358 "",
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
359 sizeof(VideoData),
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
360 CODEC_ID_NONE,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
361 CODEC_ID_RAWVIDEO,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
362 img_write_header,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
363 img_write_packet,
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
364 img_write_trailer,
21
3d2d2f8725f9 jpeg detection fix - fixed imagepipe output
bellard
parents: 20
diff changeset
365 AVFMT_RAWPICTURE,
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
366 img_set_parameters,
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
367 };
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
368
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
369 int img_init(void)
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
370 {
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
371 av_register_input_format(&image_iformat);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
372 av_register_output_format(&image_oformat);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
373
20
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
374 av_register_input_format(&imagepipe_iformat);
3d52de18ecc3 added still image support
bellard
parents: 12
diff changeset
375 av_register_output_format(&imagepipe_oformat);
0
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
376
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
377 return 0;
05318cf2e886 renamed libav to libavformat
bellard
parents:
diff changeset
378 }