# HG changeset patch # User ranma # Date 1080141396 0 # Node ID 656a1b45b30975a4f06dd99489c70daef9d3b62a # Parent b245a429c896f4741fe64dcd6ca2e8ac8f9e2f74 Use aspect from encoder for AVI vprp header diff -r b245a429c896 -r 656a1b45b309 DOCS/man/en/mplayer.1 --- a/DOCS/man/en/mplayer.1 Tue Mar 23 20:10:23 2004 +0000 +++ b/DOCS/man/en/mplayer.1 Wed Mar 24 15:16:36 2004 +0000 @@ -364,27 +364,6 @@ Particularly useful on slow terminals or broken ones that do not properly handle carriage return (i.e. \\r). .TP -.B \-useaviaspect -With this option MPlayer and MEncoder will read and write the aspect -setting from the OpenDML AVI Video Property Header. - -This is a different method than the "aspect=..." option of -libavcodec or XviD, and is prioritized over it during playback, -because this header is processed first. - -Generally, encoding AVIs with square pixels is still the best -choice, so aspect headers should be avoided. -Some players can understand it, while they may not understand the -aspect headers produced by the codec. - -.I EXAMPLE: -.PD 0 -.RSs -.IPs "\-aspect 16:9 \-useaviaspect" -will add a header specifying 16:9 aspect ratio. -.RE -.PD 1 -.TP .B \-v, \-verbose Increment verbose level (more \-v means more verbosity). . @@ -3795,6 +3774,10 @@ .PD 1 . .TP +.B \-force-avi-aspect <0.2\-3.0> +Override the aspect stored in the AVI OpenDML vprp header. +This can be used to change the aspect ratio with \-ovc copy. +.TP .B \-info (AVI only) Specify the info header of the resulting AVI file. .br diff -r b245a429c896 -r 656a1b45b309 cfg-common.h --- a/cfg-common.h Tue Mar 23 20:10:23 2004 +0000 +++ b/cfg-common.h Wed Mar 24 15:16:36 2004 +0000 @@ -119,9 +119,6 @@ {"dvbin", dvbin_opts_conf, CONF_TYPE_SUBCONFIG, 0, 0, 0, NULL}, #endif - {"useaviaspect", &avi_use_vprp_aspect, CONF_TYPE_FLAG, 0, 0, 1, NULL}, - {"nouseaviaspect", &avi_use_vprp_aspect, CONF_TYPE_FLAG, 0, 1, 0, NULL}, - // ------------------------- a-v sync options -------------------- // AVI specific: A-V sync mode (bps vs. interleaving) @@ -319,8 +316,6 @@ extern int ts_keep_broken; extern off_t ts_probe; -extern int avi_use_vprp_aspect; /* defined in aviheader.c */ - #include "libmpdemux/tv.h" #ifdef USE_EDL diff -r b245a429c896 -r 656a1b45b309 cfg-mencoder.h --- a/cfg-mencoder.h Tue Mar 23 20:10:23 2004 +0000 +++ b/cfg-mencoder.h Wed Mar 24 15:16:36 2004 +0000 @@ -160,6 +160,8 @@ {NULL, NULL, 0, 0, 0, 0, NULL} }; +extern float avi_aspect_override; /* defined in libmpdemux/muxer_avi.c */ + m_option_t mencoder_opts[]={ /* name, pointer, type, flags, min, max */ @@ -192,6 +194,9 @@ // override FOURCC in output file {"ffourcc", &force_fourcc, CONF_TYPE_STRING, 0, 4, 4, NULL}, + // override avi aspect autodetection + {"force-avi-aspect", &avi_aspect_override, CONF_TYPE_FLOAT, CONF_RANGE, 0.2, 3.0, NULL}, + {"pass", "The -pass option is obsolete. Use -lavcopts vpass=n or -divx4opts pass=n!\nRTFM!\n", CONF_TYPE_PRINT, CONF_NOCFG, 0, 0, NULL}, {"passlogfile", &passtmpfile, CONF_TYPE_STRING, 0, 0, 0, NULL}, diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_divx4.c --- a/libmpcodecs/ve_divx4.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_divx4.c Wed Mar 24 15:16:36 2004 +0000 @@ -211,6 +211,7 @@ mux_v->bih->biWidth=width; mux_v->bih->biHeight=height; mux_v->bih->biSizeImage=width*height*3; + mux_v->aspect = (float)d_width/d_height; if(!divx4_param.bitrate) divx4_param.bitrate=800000; else if(divx4_param.bitrate<=16000) divx4_param.bitrate*=1000; diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_lavc.c --- a/libmpcodecs/ve_lavc.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_lavc.c Wed Mar 24 15:16:36 2004 +0000 @@ -519,6 +519,7 @@ #else lavc_venc_context->aspect_ratio= ratio; #endif + mux_v->aspect = ratio; mp_dbg(MSGT_MENCODER, MSGL_DBG2, "aspect_ratio: %f\n", ratio); } else { mp_dbg(MSGT_MENCODER, MSGL_ERR, "aspect ratio: cannot parse \"%s\"\n", lavc_param_aspect); @@ -529,8 +530,9 @@ #if LIBAVCODEC_BUILD >= 4687 lavc_venc_context->sample_aspect_ratio = av_d2q((float)d_width/d_height*height / width, 255); #else - lavc_venc_context->aspect_ratio = (float)d_width/d_height; + lavc_venc_context->aspect_ratio = #endif + mux_v->aspect = (float)d_width/d_height; /* keyframe interval */ if (lavc_param_keyint >= 0) /* != -1 */ diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_libdv.c --- a/libmpcodecs/ve_libdv.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_libdv.c Wed Mar 24 15:16:36 2004 +0000 @@ -55,6 +55,7 @@ mux_v->bih->biWidth=width; mux_v->bih->biHeight=height; mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8); + mux_v->aspect = (float)d_width/d_height; return 1; } diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_nuv.c --- a/libmpcodecs/ve_nuv.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_nuv.c Wed Mar 24 15:16:36 2004 +0000 @@ -80,6 +80,7 @@ mux_v->bih->biWidth=width; mux_v->bih->biHeight=height; mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8); + mux_v->aspect = (float)d_width/d_height; vf->priv->buffer = realloc(vf->priv->buffer,vf->priv->buf_size); vf->priv->tbl_wrote = 0; diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_qtvideo.c --- a/libmpcodecs/ve_qtvideo.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_qtvideo.c Wed Mar 24 15:16:36 2004 +0000 @@ -129,6 +129,7 @@ mux_v->bih->biWidth=width; mux_v->bih->biHeight=height; mux_v->bih->biSizeImage=width*height*2; + mux_v->aspect = (float)d_width/d_height; diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_raw.c --- a/libmpcodecs/ve_raw.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_raw.c Wed Mar 24 15:16:36 2004 +0000 @@ -83,6 +83,7 @@ int ret; mux_v->bih->biWidth = width; mux_v->bih->biHeight = height; + mux_v->aspect = (float)d_width/d_height; ret = set_format(vf, outfmt); if (!ret) return 0; diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_vfw.c --- a/libmpcodecs/ve_vfw.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_vfw.c Wed Mar 24 15:16:36 2004 +0000 @@ -217,6 +217,7 @@ vfw_bih->biWidth=width; vfw_bih->biHeight=height; vfw_bih->biSizeImage=width*height*((vfw_bih->biBitCount+7)/8); + mux_v->aspect = (float)d_width/d_height; if(!vfw_start_encoder(vfw_bih, mux_v->bih)) return 0; diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_xvid.c --- a/libmpcodecs/ve_xvid.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_xvid.c Wed Mar 24 15:16:36 2004 +0000 @@ -172,6 +172,7 @@ fp->mux->bih->biWidth = width; fp->mux->bih->biHeight = height; fp->mux->bih->biSizeImage = fp->mux->bih->biWidth * fp->mux->bih->biHeight * 3; + fp->mux->aspect = (float)d_width/d_height; mp_msg(MSGT_MENCODER,MSGL_INFO,"videocodec: XViD (%dx%d fourcc=%x [%.4s])\n", width, height, fp->mux->bih->biCompression, (char *)&fp->mux->bih->biCompression); diff -r b245a429c896 -r 656a1b45b309 libmpcodecs/ve_xvid4.c --- a/libmpcodecs/ve_xvid4.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpcodecs/ve_xvid4.c Wed Mar 24 15:16:36 2004 +0000 @@ -339,6 +339,7 @@ mod->mux->bih->biHeight = height; mod->mux->bih->biSizeImage = mod->mux->bih->biWidth * mod->mux->bih->biHeight * 3; + mod->mux->aspect = (float)d_width/d_height; /* Message the FourCC type */ mp_msg(MSGT_MENCODER, MSGL_INFO, diff -r b245a429c896 -r 656a1b45b309 libmpdemux/aviheader.c --- a/libmpdemux/aviheader.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpdemux/aviheader.c Wed Mar 24 15:16:36 2004 +0000 @@ -28,8 +28,6 @@ extern void print_avistdindex_chunk(avistdindex_chunk *h); extern void print_avisuperindex_chunk(avisuperindex_chunk *h); -int avi_use_vprp_aspect = 0; - static int odml_get_vstream_id(int id, unsigned char res[]) { unsigned char *p = (unsigned char *)&id; @@ -345,7 +343,7 @@ for (i=0; inbFieldPerFrame; i++) { le2me_VIDEO_FIELD_DESC(&vprp->FieldInfo[i]); } - if (avi_use_vprp_aspect && sh_video) { + if (sh_video) { sh_video->aspect = GET_AVI_ASPECT(vprp->dwFrameAspectRatio); } if(verbose>=1) print_vprp(vprp); diff -r b245a429c896 -r 656a1b45b309 libmpdemux/muxer.h --- a/libmpdemux/muxer.h Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpdemux/muxer.h Wed Mar 24 15:16:36 2004 +0000 @@ -17,6 +17,7 @@ uint32_t ckid; // chunk id (00dc 01wb etc) double timer; off_t size; + float aspect; // aspect ratio of this stream (set by ve_*.c) // buffering: unsigned char *buffer; unsigned int buffer_size; diff -r b245a429c896 -r 656a1b45b309 libmpdemux/muxer_avi.c --- a/libmpdemux/muxer_avi.c Tue Mar 23 20:10:23 2004 +0000 +++ b/libmpdemux/muxer_avi.c Wed Mar 24 15:16:36 2004 +0000 @@ -34,7 +34,7 @@ #define ODML_NOTKEYFRAME 0x80000000U #define MOVIALIGN 0x00001000 -extern int avi_use_vprp_aspect; +float avi_aspect_override = -1.0; struct avi_odmlidx_entry { uint64_t ofs; @@ -57,6 +57,35 @@ struct avi_odmlsuperidx_entry *superidx; }; +static unsigned int avi_aspect(muxer_stream_t *vstream) +{ + int x,y; + float aspect = vstream->aspect; + + if (avi_aspect_override > 0.0) { + aspect = avi_aspect_override; + } + + if (aspect <= 0.0) return 0; + + if (aspect > 15.99/9.0 && aspect < 16.01/9.0) { + return MAKE_AVI_ASPECT(16, 9); + } + if (aspect > 3.99/3.0 && aspect < 4.01/3.0) { + return MAKE_AVI_ASPECT(4, 3); + } + + if (aspect >= 1.0) { + x = 16384; + y = (float)x / aspect; + } else { + y = 16384; + x = (float)y * aspect; + } + + return MAKE_AVI_ASPECT(x, y); +} + static muxer_stream_t* avifile_new_stream(muxer_t *muxer,int type){ struct avi_stream_info *si; muxer_stream_t* s; @@ -225,21 +254,6 @@ #define WFSIZE(wf) (sizeof(WAVEFORMATEX)+(wf)->cbSize) -static unsigned int avi_aspect(float aspect) -{ - if (aspect <= 0.0) { - aspect = 4.0/3.0; - } - if (aspect >= 3.99/3.0 && - aspect <= 4.01/3.0) return MAKE_AVI_ASPECT(4,3); - if (aspect >= 15.99/9.0 && - aspect <= 16.01/9.0) return MAKE_AVI_ASPECT(16,9); - if (aspect >= 0.99 && - aspect <= 1.01) return MAKE_AVI_ASPECT(1,1); - if (aspect<1.0) return MAKE_AVI_ASPECT((int)(aspect*8192),8192); - return MAKE_AVI_ASPECT(8192,(int)(8192/aspect)); -} - static void avifile_write_header(muxer_t *muxer){ uint32_t riff[3]; unsigned int dmlh[1]; @@ -248,10 +262,16 @@ muxer_info_t info[16]; FILE *f = muxer->file; VideoPropHeader vprp; - + uint32_t aspect = avi_aspect(muxer->def_v); off_t pos; int isodml = muxer->file_end > ODML_CHUNKLEN ? 1 : 0; + if (aspect == 0) { + mp_msg(MSGT_MUXER, MSGL_INFO, "ODML: Aspect information not (yet?) available or unspecified, not writing vprp header.\n"); + } else { + mp_msg(MSGT_MUXER, MSGL_INFO, "ODML: vprp aspect is %d:%d.\n", aspect >> 16, aspect & 0xffff); + } + if (isodml) { for (pos = 0; pos < muxer->file_end; pos += ODML_CHUNKLEN) { unsigned int rifflen, movilen; @@ -316,7 +336,7 @@ switch(muxer->streams[i]->type){ case MUXER_TYPE_VIDEO: hdrsize+=muxer->streams[i]->bih->biSize+8; // strf - if (avi_use_vprp_aspect) { + if (aspect != 0) { hdrsize+=8+4*(9+8*1); // vprp } break; @@ -351,14 +371,13 @@ s->h.fccHandler = s->bih->biCompression; s->h.rcFrame.right = s->bih->biWidth; s->h.rcFrame.bottom = s->bih->biHeight; - if (avi_use_vprp_aspect) { - sh_video_t *sh_video = s->source; + if (aspect != 0) { // fill out vprp info memset(&vprp, 0, sizeof(vprp)); vprp.dwVerticalRefreshRate = (s->h.dwRate+s->h.dwScale-1)/s->h.dwScale; vprp.dwHTotalInT = muxer->avih.dwWidth; vprp.dwVTotalInLines = muxer->avih.dwHeight; - vprp.dwFrameAspectRatio = avi_aspect(sh_video->aspect); + vprp.dwFrameAspectRatio = aspect; vprp.dwFrameWidthInPixels = muxer->avih.dwWidth; vprp.dwFrameHeightInLines = muxer->avih.dwHeight; vprp.nbFieldPerFrame = 1; @@ -388,7 +407,7 @@ write_avi_chunk(f,ckidSTREAMFORMAT,biSize,s->bih); /* BITMAPINFOHEADER */ le2me_BITMAPINFOHEADER(s->bih); - if (avi_use_vprp_aspect) { + if (aspect != 0) { int fields = vprp.nbFieldPerFrame; le2me_VideoPropHeader(&vprp); le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[0]); diff -r b245a429c896 -r 656a1b45b309 mencoder.c --- a/mencoder.c Tue Mar 23 20:10:23 2004 +0000 +++ b/mencoder.c Wed Mar 24 15:16:36 2004 +0000 @@ -663,12 +663,6 @@ mux_v->bih->biBitCount=24; // FIXME!!! mux_v->bih->biSizeImage=mux_v->bih->biWidth*mux_v->bih->biHeight*(mux_v->bih->biBitCount/8); } - /* - * FIXME: with -ovc copy we don't get aspect ratio information - * from the source stream. - */ - if(movie_aspect>-1.0) sh_video->aspect = movie_aspect; - printf("videocodec: framecopy (%dx%d %dbpp fourcc=%x)\n", mux_v->bih->biWidth, mux_v->bih->biHeight, mux_v->bih->biBitCount, mux_v->bih->biCompression);