annotate libmpcodecs/ve_lavc.c @ 5677:a21cab74cde8

bitrate>16000 means bits not kbits - noticed by George Hawkins <george_hawkins@yahoo.com>
author arpi
date Thu, 18 Apr 2002 15:23:34 +0000
parents ee2efbf3dc9d
children f2586f1a3a96
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
5607
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5565
diff changeset
19 #include "img_format.h"
1972c3475d93 mp_image.h and img_format.h moved to libmpcodecs
arpi
parents: 5565
diff changeset
20 #include "mp_image.h"
5550
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;
5556
4016b44a1230 vme default changed 3->4
arpi
parents: 5551
diff changeset
44 static int lavc_param_vme = 4;
5550
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;
5657
ee2efbf3dc9d Preliminary support for lavcs b-frame encoding, disabled by default.
atmos4
parents: 5646
diff changeset
51 static int lavc_param_vmax_b_frames = 0;
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
52 static int lavc_param_keyint = -1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
53
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
54 #include "cfgparser.h"
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
55
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
56 #ifdef USE_LIBAVCODEC
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
57 struct config lavcopts_conf[]={
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
58 {"vcodec", &lavc_param_vcodec, CONF_TYPE_STRING, 0, 0, 0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
59 {"vbitrate", &lavc_param_vbitrate, CONF_TYPE_INT, CONF_RANGE, 4, 24000000, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
60 {"vratetol", &lavc_param_vrate_tolerance, CONF_TYPE_INT, CONF_RANGE, 4, 24000000, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
61 {"vhq", &lavc_param_vhq, CONF_TYPE_FLAG, 0, 0, 1, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
62 {"v4mv", &lavc_param_v4mv, CONF_TYPE_FLAG, 0, 0, 1, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
63 {"vme", &lavc_param_vme, CONF_TYPE_INT, CONF_RANGE, 0, 5, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
64 {"vqscale", &lavc_param_vqscale, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
65 {"vqmin", &lavc_param_vqmin, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
66 {"vqmax", &lavc_param_vqmax, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
67 {"vqdiff", &lavc_param_vqdiff, CONF_TYPE_INT, CONF_RANGE, 1, 31, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
68 {"vqcomp", &lavc_param_vqcompress, CONF_TYPE_FLOAT, CONF_RANGE, 0.0, 1.0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
69 {"vqblur", &lavc_param_vqblur, CONF_TYPE_FLOAT, CONF_RANGE, 0.0, 1.0, NULL},
5657
ee2efbf3dc9d Preliminary support for lavcs b-frame encoding, disabled by default.
atmos4
parents: 5646
diff changeset
70 {"vmax_b_frames", &lavc_param_vmax_b_frames, CONF_TYPE_INT, CONF_RANGE, 0, FF_MAX_B_FRAMES, NULL},
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
71 {"keyint", &lavc_param_keyint, CONF_TYPE_INT, 0, 0, 0, NULL},
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
72 {NULL, NULL, 0, 0, 0, 0, NULL}
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
73 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
74 #endif
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
75
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
76 struct vf_priv_s {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
77 aviwrite_stream_t* mux;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
78 AVCodecContext context;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
79 AVCodec *codec;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
80 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
81
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
82 #define mux_v (vf->priv->mux)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
83 #define lavc_venc_context (vf->priv->context)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
84
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
85 static int config(struct vf_instance_s* vf,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
86 int width, int height, int d_width, int d_height,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
87 unsigned int flags, unsigned int outfmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
88
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
89 mux_v->bih->biWidth=width;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
90 mux_v->bih->biHeight=height;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
91 mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
92
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
93 memset(&lavc_venc_context, 0, sizeof(lavc_venc_context));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
94
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
95 printf("videocodec: libavcodec (%dx%d fourcc=%x [%.4s])\n",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
96 mux_v->bih->biWidth, mux_v->bih->biHeight, mux_v->bih->biCompression,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
97 (char *)&mux_v->bih->biCompression);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
98
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
99 lavc_venc_context.width = width;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
100 lavc_venc_context.height = height;
5677
a21cab74cde8 bitrate>16000 means bits not kbits - noticed by George Hawkins <george_hawkins@yahoo.com>
arpi
parents: 5657
diff changeset
101 if (lavc_param_vbitrate > 16000) /* != -1 */
a21cab74cde8 bitrate>16000 means bits not kbits - noticed by George Hawkins <george_hawkins@yahoo.com>
arpi
parents: 5657
diff changeset
102 lavc_venc_context.bit_rate = lavc_param_vbitrate;
a21cab74cde8 bitrate>16000 means bits not kbits - noticed by George Hawkins <george_hawkins@yahoo.com>
arpi
parents: 5657
diff changeset
103 else if (lavc_param_vbitrate >= 0) /* != -1 */
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
104 lavc_venc_context.bit_rate = lavc_param_vbitrate*1000;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
105 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
106 lavc_venc_context.bit_rate = 800000; /* default */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
107 lavc_venc_context.bit_rate_tolerance= lavc_param_vrate_tolerance*1000;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
108 lavc_venc_context.frame_rate = (float)mux_v->h.dwRate/mux_v->h.dwScale * FRAME_RATE_BASE;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
109 lavc_venc_context.qmin= lavc_param_vqmin;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
110 lavc_venc_context.qmax= lavc_param_vqmax;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
111 lavc_venc_context.max_qdiff= lavc_param_vqdiff;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
112 lavc_venc_context.qcompress= lavc_param_vqcompress;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
113 lavc_venc_context.qblur= lavc_param_vqblur;
5657
ee2efbf3dc9d Preliminary support for lavcs b-frame encoding, disabled by default.
atmos4
parents: 5646
diff changeset
114 lavc_venc_context.max_b_frames= lavc_param_vmax_b_frames;
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
115 /* keyframe interval */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
116 if (lavc_param_keyint >= 0) /* != -1 */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
117 lavc_venc_context.gop_size = lavc_param_keyint;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
118 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
119 lavc_venc_context.gop_size = 250; /* default */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
120
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
121 if (lavc_param_vhq)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
122 {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
123 printf("High quality encoding selected (non real time)!\n");
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
124 lavc_venc_context.flags = CODEC_FLAG_HQ;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
125 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
126 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
127 lavc_venc_context.flags = 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
128
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
129 lavc_venc_context.flags|= lavc_param_v4mv ? CODEC_FLAG_4MV : 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
130
5624
d9af91d38449 workaround Juanjo's stupid vme change
arpi
parents: 5607
diff changeset
131 #ifdef ME_ZERO
d9af91d38449 workaround Juanjo's stupid vme change
arpi
parents: 5607
diff changeset
132 // workaround Juanjo's stupid incompatible change:
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
133 motion_estimation_method = lavc_param_vme;
5624
d9af91d38449 workaround Juanjo's stupid vme change
arpi
parents: 5607
diff changeset
134 #else
d9af91d38449 workaround Juanjo's stupid vme change
arpi
parents: 5607
diff changeset
135 lavc_venc_context.me_method = ME_ZERO+lavc_param_vme;
d9af91d38449 workaround Juanjo's stupid vme change
arpi
parents: 5607
diff changeset
136 #endif
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
137
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
138 /* fixed qscale :p */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
139 if (lavc_param_vqscale)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
140 {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
141 printf("Using constant qscale = %d (VBR)\n", lavc_param_vqscale);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
142 lavc_venc_context.flags |= CODEC_FLAG_QSCALE;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
143 lavc_venc_context.quality = lavc_param_vqscale;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
144 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
145
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
146 switch(pass){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
147 case 1:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
148 if (VbrControl_init_2pass_vbr_analysis(passtmpfile, 5) == -1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
149 mp_msg(MSGT_MENCODER,MSGL_ERR,"2pass failed: filename=%s\n", passtmpfile);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
150 pass=0;
5646
8bec4d7d04f0 disable hq for 1st pass
arpi
parents: 5632
diff changeset
151 } else
8bec4d7d04f0 disable hq for 1st pass
arpi
parents: 5632
diff changeset
152 lavc_venc_context.flags &= ~CODEC_FLAG_HQ;
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
153 break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
154 case 2:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
155 if (VbrControl_init_2pass_vbr_encoding(passtmpfile,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
156 lavc_venc_context.bit_rate,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
157 (float)mux_v->h.dwRate/mux_v->h.dwScale,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
158 100, /* crispness */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
159 5) == -1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
160 mp_msg(MSGT_MENCODER,MSGL_ERR,"2pass failed: filename=%s\n", passtmpfile);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
161 pass=0;
5632
93c9df5225a7 2-pass qscale fixed
arpi
parents: 5624
diff changeset
162 } else
93c9df5225a7 2-pass qscale fixed
arpi
parents: 5624
diff changeset
163 lavc_venc_context.flags|=CODEC_FLAG_QSCALE|CODEC_FLAG_TYPE; // VBR
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
164 break;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
165 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
166
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
167 if (avcodec_open(&lavc_venc_context, vf->priv->codec) != 0) {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
168 mp_msg(MSGT_MENCODER,MSGL_ERR,MSGTR_CantOpenCodec);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
169 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
170 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
171
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
172 if (lavc_venc_context.codec->encode == NULL) {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
173 mp_msg(MSGT_MENCODER,MSGL_ERR,"avcodec init failed (ctx->codec->encode == NULL)!\n");
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
174 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
175 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
176
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
177 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
178 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
179
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
180 static int control(struct vf_instance_s* vf, int request, void* data){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
181
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
182 return CONTROL_UNKNOWN;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
183 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
184
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
185 static int query_format(struct vf_instance_s* vf, unsigned int fmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
186 switch(fmt){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
187 case IMGFMT_YV12:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
188 case IMGFMT_IYUV:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
189 case IMGFMT_I420:
5565
0b301fec999a capabilities support -> automatic insertion of scale, expand, pp
arpi
parents: 5556
diff changeset
190 return VFCAP_CSP_SUPPORTED | VFCAP_ACCEPT_STRIDE;
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
191 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
192 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
193 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
194
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
195 static void put_image(struct vf_instance_s* vf, mp_image_t *mpi){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
196 int out_size;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
197 AVPicture lavc_venc_picture;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
198
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
199 lavc_venc_picture.data[0]=mpi->planes[0];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
200 lavc_venc_picture.data[1]=mpi->planes[1];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
201 lavc_venc_picture.data[2]=mpi->planes[2];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
202 lavc_venc_picture.linesize[0]=mpi->stride[0];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
203 lavc_venc_picture.linesize[1]=mpi->stride[1];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
204 lavc_venc_picture.linesize[2]=mpi->stride[2];
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
205
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
206 if(pass==2){ // handle 2-pass:
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
207 lavc_venc_context.flags|=CODEC_FLAG_QSCALE; // enable VBR
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
208 lavc_venc_context.quality=VbrControl_get_quant();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
209 lavc_venc_context.key_frame=VbrControl_get_intra();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
210 lavc_venc_context.gop_size=0x3fffffff;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
211 out_size = avcodec_encode_video(&lavc_venc_context, mux_v->buffer, mux_v->buffer_size,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
212 &lavc_venc_picture);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
213 VbrControl_update_2pass_vbr_encoding(lavc_venc_context.mv_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
214 lavc_venc_context.i_tex_bits+lavc_venc_context.p_tex_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
215 8*out_size);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
216 } else {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
217 out_size = avcodec_encode_video(&lavc_venc_context, mux_v->buffer, mux_v->buffer_size,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
218 &lavc_venc_picture);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
219
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
220 if(pass==1){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
221 VbrControl_update_2pass_vbr_analysis(lavc_venc_context.key_frame,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
222 lavc_venc_context.mv_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
223 lavc_venc_context.i_tex_bits+lavc_venc_context.p_tex_bits,
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
224 8*out_size, lavc_venc_context.quality);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
225 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
226
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
227 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
228
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
229 mencoder_write_chunk(mux_v,out_size,lavc_venc_context.key_frame?0x10:0);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
230 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
231
5551
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
232 static void uninit(struct vf_instance_s* vf){
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
233 avcodec_close(&lavc_venc_context);
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
234 }
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
235
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
236 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
237
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
238 static int vf_open(vf_instance_t *vf, char* args){
5551
73978162b6a1 soem fixes
arpi
parents: 5550
diff changeset
239 vf->uninit=uninit;
5550
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
240 vf->config=config;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
241 vf->control=control;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
242 vf->query_format=query_format;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
243 vf->put_image=put_image;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
244 vf->priv=malloc(sizeof(struct vf_priv_s));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
245 memset(vf->priv,0,sizeof(struct vf_priv_s));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
246 vf->priv->mux=args;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
247
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
248 mux_v->bih=malloc(sizeof(BITMAPINFOHEADER));
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
249 mux_v->bih->biSize=sizeof(BITMAPINFOHEADER);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
250 mux_v->bih->biWidth=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
251 mux_v->bih->biHeight=0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
252 mux_v->bih->biPlanes=1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
253 mux_v->bih->biBitCount=24;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
254 if (!lavc_param_vcodec)
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
255 {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
256 printf("No libavcodec codec specified! It's requested!\n");
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
257 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
258 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
259
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
260 if (!strcasecmp(lavc_param_vcodec, "mpeg1") || !strcasecmp(lavc_param_vcodec, "mpeg1video"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
261 mux_v->bih->biCompression = mmioFOURCC('m', 'p', 'g', '1');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
262 else if (!strcasecmp(lavc_param_vcodec, "h263") || !strcasecmp(lavc_param_vcodec, "h263p"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
263 mux_v->bih->biCompression = mmioFOURCC('h', '2', '6', '3');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
264 else if (!strcasecmp(lavc_param_vcodec, "rv10"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
265 mux_v->bih->biCompression = mmioFOURCC('R', 'V', '1', '0');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
266 else if (!strcasecmp(lavc_param_vcodec, "mjpeg"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
267 mux_v->bih->biCompression = mmioFOURCC('M', 'J', 'P', 'G');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
268 else if (!strcasecmp(lavc_param_vcodec, "mpeg4"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
269 mux_v->bih->biCompression = mmioFOURCC('D', 'I', 'V', 'X');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
270 else if (!strcasecmp(lavc_param_vcodec, "msmpeg4"))
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
271 mux_v->bih->biCompression = mmioFOURCC('d', 'i', 'v', '3');
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
272 else
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
273 mux_v->bih->biCompression = mmioFOURCC(lavc_param_vcodec[0],
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
274 lavc_param_vcodec[1], lavc_param_vcodec[2], lavc_param_vcodec[3]); /* FIXME!!! */
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
275
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
276 if (!avcodec_inited){
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
277 avcodec_init();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
278 avcodec_register_all();
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
279 avcodec_inited=1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
280 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
281
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
282 vf->priv->codec = (AVCodec *)avcodec_find_encoder_by_name(lavc_param_vcodec);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
283 if (!vf->priv->codec) {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
284 mp_msg(MSGT_MENCODER,MSGL_ERR,MSGTR_MissingLAVCcodec, lavc_param_vcodec);
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
285 return 0;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
286 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
287
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
288 return 1;
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
289 }
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
290
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
291 vf_info_t ve_info_lavc = {
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
292 "libavcodec encoder",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
293 "lavc",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
294 "A'rpi",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
295 "for internal use by mencoder",
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
296 vf_open
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
297 };
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
298
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
299 //===========================================================================//
7d1dfb59c6c0 encoders
arpi
parents:
diff changeset
300 #endif