annotate libmpcodecs/ve_lavc.c @ 5551:73978162b6a1

soem fixes
author arpi
date Thu, 11 Apr 2002 02:50:47 +0000
parents 7d1dfb59c6c0
children 4016b44a1230
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
1 #include <stdio.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
2 #include <stdlib.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
3 #include <string.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
4
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
5 #include "../config.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
6
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
7 #ifdef USE_LIBAVCODEC
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
8
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
9 #include "../mp_msg.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
10 #include "../help_mp.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
11
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
12 #include "codec-cfg.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
13 #include "stream.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
14 #include "demuxer.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
15 #include "stheader.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
16
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
17 #include "aviwrite.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
18
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
19 #include "../libvo/img_format.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
20 #include "../mp_image.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
21 #include "vf.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
22
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
23 #include "divx4_vbr.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
24
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
25 extern int pass;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
26 extern char* passtmpfile;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
27
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
28 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
29
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
30 #ifdef USE_LIBAVCODEC_SO
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
31 #include <libffmpeg/avcodec.h>
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
32 #else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
33 #include "libavcodec/avcodec.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
34 #endif
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
35
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
36 extern int avcodec_inited;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
37
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
38 /* video options */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
39 static char *lavc_param_vcodec = NULL;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
40 static int lavc_param_vbitrate = -1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
41 static int lavc_param_vrate_tolerance = 1024*8;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
42 static int lavc_param_vhq = 0; /* default is realtime encoding */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
43 static int lavc_param_v4mv = 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
44 static int lavc_param_vme = 3;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
45 static int lavc_param_vqscale = 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
46 static int lavc_param_vqmin = 3;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
47 static int lavc_param_vqmax = 15;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
48 static int lavc_param_vqdiff = 3;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
49 static float lavc_param_vqcompress = 0.5;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
50 static float lavc_param_vqblur = 0.5;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
51 static int lavc_param_keyint = -1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
52
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
53 #include "cfgparser.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
54
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
55 #ifdef USE_LIBAVCODEC
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
56 struct config lavcopts_conf[]={
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
57 {"vcodec", &lavc_param_vcodec, CONF_TYPE_STRING, 0, 0, 0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
58 {"vbitrate", &lavc_param_vbitrate, CONF_TYPE_INT, CONF_RANGE, 4, 24000000, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
59 {"vratetol", &lavc_param_vrate_tolerance, CONF_TYPE_INT, CONF_RANGE, 4, 24000000, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
60 {"vhq", &lavc_param_vhq, CONF_TYPE_FLAG, 0, 0, 1, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
61 {"v4mv", &lavc_param_v4mv, CONF_TYPE_FLAG, 0, 0, 1, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
62 {"vme", &lavc_param_vme, CONF_TYPE_INT, CONF_RANGE, 0, 5, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
63 {"vqscale", &lavc_param_vqscale, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
64 {"vqmin", &lavc_param_vqmin, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
65 {"vqmax", &lavc_param_vqmax, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
66 {"vqdiff", &lavc_param_vqdiff, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
67 {"vqcomp", &lavc_param_vqcompress, CONF_TYPE_FLOAT, CONF_RANGE, 0.0, 1.0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
68 {"vqblur", &lavc_param_vqblur, CONF_TYPE_FLOAT, CONF_RANGE, 0.0, 1.0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
69 {"keyint", &lavc_param_keyint, CONF_TYPE_INT, 0, 0, 0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
70 {NULL, NULL, 0, 0, 0, 0, NULL}
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
71 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
72 #endif
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
73
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
74 struct vf_priv_s {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
75 aviwrite_stream_t* mux;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
76 AVCodecContext context;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
77 AVCodec *codec;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
78 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
79
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
80 #define mux_v (vf->priv->mux)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
81 #define lavc_venc_context (vf->priv->context)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
82
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
83 static int config(struct vf_instance_s* vf,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
84 int width, int height, int d_width, int d_height,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
85 unsigned int flags, unsigned int outfmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
86
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
87 mux_v->bih->biWidth=width;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
88 mux_v->bih->biHeight=height;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
89 mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
90
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
91 memset(&lavc_venc_context, 0, sizeof(lavc_venc_context));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
92
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
93 printf("videocodec: libavcodec (%dx%d fourcc=%x [%.4s])\n",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
94 mux_v->bih->biWidth, mux_v->bih->biHeight, mux_v->bih->biCompression,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
95 (char *)&mux_v->bih->biCompression);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
96
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
97 lavc_venc_context.width = width;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
98 lavc_venc_context.height = height;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
99 if (lavc_param_vbitrate >= 0) /* != -1 */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
100 lavc_venc_context.bit_rate = lavc_param_vbitrate*1000;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
101 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
102 lavc_venc_context.bit_rate = 800000; /* default */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
103 lavc_venc_context.bit_rate_tolerance= lavc_param_vrate_tolerance*1000;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
104 lavc_venc_context.frame_rate = (float)mux_v->h.dwRate/mux_v->h.dwScale * FRAME_RATE_BASE;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
105 lavc_venc_context.qmin= lavc_param_vqmin;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
106 lavc_venc_context.qmax= lavc_param_vqmax;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
107 lavc_venc_context.max_qdiff= lavc_param_vqdiff;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
108 lavc_venc_context.qcompress= lavc_param_vqcompress;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
109 lavc_venc_context.qblur= lavc_param_vqblur;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
110 /* keyframe interval */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
111 if (lavc_param_keyint >= 0) /* != -1 */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
112 lavc_venc_context.gop_size = lavc_param_keyint;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
113 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
114 lavc_venc_context.gop_size = 250; /* default */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
115
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
116 if (lavc_param_vhq)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
117 {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
118 printf("High quality encoding selected (non real time)!\n");
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
119 lavc_venc_context.flags = CODEC_FLAG_HQ;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
120 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
121 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
122 lavc_venc_context.flags = 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
123
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
124 lavc_venc_context.flags|= lavc_param_v4mv ? CODEC_FLAG_4MV : 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
125
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
126 /* motion estimation (0 = none ... 3 = high quality but slow) */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
127 /* this is just an extern from libavcodec but it should be in the
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
128 encoder context - FIXME */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
129 motion_estimation_method = lavc_param_vme;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
130
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
131 /* fixed qscale :p */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
132 if (lavc_param_vqscale)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
133 {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
134 printf("Using constant qscale = %d (VBR)\n", lavc_param_vqscale);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
135 lavc_venc_context.flags |= CODEC_FLAG_QSCALE;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
136 lavc_venc_context.quality = lavc_param_vqscale;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
137 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
138
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
139 switch(pass){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
140 case 1:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
141 if (VbrControl_init_2pass_vbr_analysis(passtmpfile, 5) == -1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
142 mp_msg(MSGT_MENCODER,MSGL_ERR,"2pass failed: filename=%s\n", passtmpfile);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
143 pass=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
144 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
145 break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
146 case 2:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
147 if (VbrControl_init_2pass_vbr_encoding(passtmpfile,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
148 lavc_venc_context.bit_rate,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
149 (float)mux_v->h.dwRate/mux_v->h.dwScale,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
150 100, /* crispness */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
151 5) == -1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
152 mp_msg(MSGT_MENCODER,MSGL_ERR,"2pass failed: filename=%s\n", passtmpfile);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
153 pass=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
154 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
155 break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
156 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
157
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
158 if (avcodec_open(&lavc_venc_context, vf->priv->codec) != 0) {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
159 mp_msg(MSGT_MENCODER,MSGL_ERR,MSGTR_CantOpenCodec);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
160 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
161 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
162
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
163 if (lavc_venc_context.codec->encode == NULL) {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
164 mp_msg(MSGT_MENCODER,MSGL_ERR,"avcodec init failed (ctx->codec->encode == NULL)!\n");
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
165 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
166 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
167
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
168 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
169 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
170
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
171 static int control(struct vf_instance_s* vf, int request, void* data){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
172
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
173 return CONTROL_UNKNOWN;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
174 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
175
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
176 static int query_format(struct vf_instance_s* vf, unsigned int fmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
177 switch(fmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
178 case IMGFMT_YV12:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
179 case IMGFMT_IYUV:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
180 case IMGFMT_I420:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
181 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
182 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
183 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
184 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
185
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
186 static void put_image(struct vf_instance_s* vf, mp_image_t *mpi){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
187 int out_size;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
188 AVPicture lavc_venc_picture;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
189
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
190 lavc_venc_picture.data[0]=mpi->planes[0];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
191 lavc_venc_picture.data[1]=mpi->planes[1];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
192 lavc_venc_picture.data[2]=mpi->planes[2];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
193 lavc_venc_picture.linesize[0]=mpi->stride[0];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
194 lavc_venc_picture.linesize[1]=mpi->stride[1];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
195 lavc_venc_picture.linesize[2]=mpi->stride[2];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
196
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
197 if(pass==2){ // handle 2-pass:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
198 lavc_venc_context.flags|=CODEC_FLAG_QSCALE; // enable VBR
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
199 lavc_venc_context.quality=VbrControl_get_quant();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
200 #ifdef CODEC_FLAG_TYPE
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
201 lavc_venc_context.flags|=CODEC_FLAG_TYPE; // force keyframes
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
202 lavc_venc_context.key_frame=VbrControl_get_intra();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
203 lavc_venc_context.gop_size=0x3fffffff;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
204 #else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
205 #error you should upgrade libavcodec... get latest CVS
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
206 #endif
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
207 out_size = avcodec_encode_video(&lavc_venc_context, mux_v->buffer, mux_v->buffer_size,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
208 &lavc_venc_picture);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
209 VbrControl_update_2pass_vbr_encoding(lavc_venc_context.mv_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
210 lavc_venc_context.i_tex_bits+lavc_venc_context.p_tex_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
211 8*out_size);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
212 } else {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
213 out_size = avcodec_encode_video(&lavc_venc_context, mux_v->buffer, mux_v->buffer_size,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
214 &lavc_venc_picture);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
215
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
216 if(pass==1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
217 VbrControl_update_2pass_vbr_analysis(lavc_venc_context.key_frame,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
218 lavc_venc_context.mv_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
219 lavc_venc_context.i_tex_bits+lavc_venc_context.p_tex_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
220 8*out_size, lavc_venc_context.quality);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
221 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
222
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
223 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
224
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
225 mencoder_write_chunk(mux_v,out_size,lavc_venc_context.key_frame?0x10:0);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
226 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
227
5551
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
228 static void uninit(struct vf_instance_s* vf){
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
229 avcodec_close(&lavc_venc_context);
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
230 }
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
231
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
232 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
233
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
234 static int vf_open(vf_instance_t *vf, char* args){
5551
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
235 vf->uninit=uninit;
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
236 vf->config=config;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
237 vf->control=control;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
238 vf->query_format=query_format;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
239 vf->put_image=put_image;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
240 vf->priv=malloc(sizeof(struct vf_priv_s));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
241 memset(vf->priv,0,sizeof(struct vf_priv_s));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
242 vf->priv->mux=args;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
243
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
244 mux_v->bih=malloc(sizeof(BITMAPINFOHEADER));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
245 mux_v->bih->biSize=sizeof(BITMAPINFOHEADER);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
246 mux_v->bih->biWidth=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
247 mux_v->bih->biHeight=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
248 mux_v->bih->biPlanes=1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
249 mux_v->bih->biBitCount=24;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
250 if (!lavc_param_vcodec)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
251 {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
252 printf("No libavcodec codec specified! It's requested!\n");
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
253 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
254 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
255
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
256 if (!strcasecmp(lavc_param_vcodec, "mpeg1") || !strcasecmp(lavc_param_vcodec, "mpeg1video"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
257 mux_v->bih->biCompression = mmioFOURCC('m', 'p', 'g', '1');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
258 else if (!strcasecmp(lavc_param_vcodec, "h263") || !strcasecmp(lavc_param_vcodec, "h263p"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
259 mux_v->bih->biCompression = mmioFOURCC('h', '2', '6', '3');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
260 else if (!strcasecmp(lavc_param_vcodec, "rv10"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
261 mux_v->bih->biCompression = mmioFOURCC('R', 'V', '1', '0');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
262 else if (!strcasecmp(lavc_param_vcodec, "mjpeg"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
263 mux_v->bih->biCompression = mmioFOURCC('M', 'J', 'P', 'G');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
264 else if (!strcasecmp(lavc_param_vcodec, "mpeg4"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
265 mux_v->bih->biCompression = mmioFOURCC('D', 'I', 'V', 'X');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
266 else if (!strcasecmp(lavc_param_vcodec, "msmpeg4"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
267 mux_v->bih->biCompression = mmioFOURCC('d', 'i', 'v', '3');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
268 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
269 mux_v->bih->biCompression = mmioFOURCC(lavc_param_vcodec[0],
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
270 lavc_param_vcodec[1], lavc_param_vcodec[2], lavc_param_vcodec[3]); /* FIXME!!! */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
271
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
272 if (!avcodec_inited){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
273 avcodec_init();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
274 avcodec_register_all();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
275 avcodec_inited=1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
276 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
277
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
278 vf->priv->codec = (AVCodec *)avcodec_find_encoder_by_name(lavc_param_vcodec);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
279 if (!vf->priv->codec) {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
280 mp_msg(MSGT_MENCODER,MSGL_ERR,MSGTR_MissingLAVCcodec, lavc_param_vcodec);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
281 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
282 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
283
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
284 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
285 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
286
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
287 vf_info_t ve_info_lavc = {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
288 "libavcodec encoder",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
289 "lavc",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
290 "A'rpi",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
291 "for internal use by mencoder",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
292 vf_open
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
293 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
294
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
295 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
296 #endif