mirror of
https://github.com/mpv-player/mpv
synced 2025-01-17 12:31:25 +00:00
explicit option for AVI PRP header
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@12052 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
parent
bd48e44489
commit
4d82f24e5b
@ -3774,6 +3774,30 @@ will have the output file contain 'div3' as video fourcc.
|
|||||||
.PD 1
|
.PD 1
|
||||||
.
|
.
|
||||||
.TP
|
.TP
|
||||||
|
.B \-aviaspect <w:h>
|
||||||
|
Encode an additional AVI header with aspect ratio. 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.
|
||||||
|
|
||||||
|
This option is included for completeness. Some players can understand
|
||||||
|
it, while they do not understand the aspect headers produced by the
|
||||||
|
codec. If you wish to target such a player, use this
|
||||||
|
option. Generally, encoding AVIs with square pixels is still the best
|
||||||
|
choice, so aspect headers should be avoided. Use this option only if
|
||||||
|
you know what you are doing. Avoid using it together with
|
||||||
|
the aspect option of the codec, as it could bring unpredictable
|
||||||
|
results.
|
||||||
|
|
||||||
|
.I EXAMPLE:
|
||||||
|
.PD 0
|
||||||
|
.RSs
|
||||||
|
.IPs "\-aviaspect 16:9"
|
||||||
|
will add a header specifying 16:9 aspect ratio.
|
||||||
|
.RE
|
||||||
|
.PD 1
|
||||||
|
.
|
||||||
|
.TP
|
||||||
.B \-info <option1:option2:...> (AVI only)
|
.B \-info <option1:option2:...> (AVI only)
|
||||||
Specify the info header of the resulting AVI file.
|
Specify the info header of the resulting AVI file.
|
||||||
.br
|
.br
|
||||||
|
@ -58,6 +58,8 @@ extern m_option_t vfwopts_conf[];
|
|||||||
extern m_option_t xvidencopts_conf[];
|
extern m_option_t xvidencopts_conf[];
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
extern float avi_prp_aspect;
|
||||||
|
|
||||||
extern m_option_t nuvopts_conf[];
|
extern m_option_t nuvopts_conf[];
|
||||||
|
|
||||||
m_option_t ovc_conf[]={
|
m_option_t ovc_conf[]={
|
||||||
@ -192,6 +194,9 @@ m_option_t mencoder_opts[]={
|
|||||||
// override FOURCC in output file
|
// override FOURCC in output file
|
||||||
{"ffourcc", &force_fourcc, CONF_TYPE_STRING, 0, 4, 4, NULL},
|
{"ffourcc", &force_fourcc, CONF_TYPE_STRING, 0, 4, 4, NULL},
|
||||||
|
|
||||||
|
// avi muxer - include prp header with aspect ratio
|
||||||
|
{"aviaspect", &avi_prp_aspect, 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},
|
{"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},
|
{"passlogfile", &passtmpfile, CONF_TYPE_STRING, 0, 0, 0, NULL},
|
||||||
|
|
||||||
|
@ -34,6 +34,8 @@ extern char *info_comment;
|
|||||||
#define ODML_NOTKEYFRAME 0x80000000U
|
#define ODML_NOTKEYFRAME 0x80000000U
|
||||||
#define MOVIALIGN 0x00001000
|
#define MOVIALIGN 0x00001000
|
||||||
|
|
||||||
|
float avi_prp_aspect = -1.0;
|
||||||
|
|
||||||
struct avi_odmlidx_entry {
|
struct avi_odmlidx_entry {
|
||||||
uint64_t ofs;
|
uint64_t ofs;
|
||||||
uint32_t len;
|
uint32_t len;
|
||||||
@ -223,12 +225,8 @@ static void write_avi_list(FILE *f,unsigned int id,int len){
|
|||||||
|
|
||||||
#define WFSIZE(wf) (sizeof(WAVEFORMATEX)+(wf)->cbSize)
|
#define WFSIZE(wf) (sizeof(WAVEFORMATEX)+(wf)->cbSize)
|
||||||
|
|
||||||
static unsigned int avi_aspect(sh_video_t *sh_video)
|
static unsigned int avi_aspect(float aspect)
|
||||||
{
|
{
|
||||||
float aspect = sh_video->aspect;
|
|
||||||
if (aspect <= 0.0) {
|
|
||||||
aspect = (float)sh_video->disp_w/(float)sh_video->disp_h;
|
|
||||||
}
|
|
||||||
if (aspect >= 3.99/3.0 &&
|
if (aspect >= 3.99/3.0 &&
|
||||||
aspect <= 4.01/3.0) return MAKE_AVI_ASPECT(4,3);
|
aspect <= 4.01/3.0) return MAKE_AVI_ASPECT(4,3);
|
||||||
if (aspect >= 15.99/9.0 &&
|
if (aspect >= 15.99/9.0 &&
|
||||||
@ -247,6 +245,7 @@ static void avifile_write_header(muxer_t *muxer){
|
|||||||
muxer_info_t info[16];
|
muxer_info_t info[16];
|
||||||
FILE *f = muxer->file;
|
FILE *f = muxer->file;
|
||||||
VideoPropHeader vprp;
|
VideoPropHeader vprp;
|
||||||
|
|
||||||
off_t pos;
|
off_t pos;
|
||||||
int isodml = muxer->file_end > ODML_CHUNKLEN ? 1 : 0;
|
int isodml = muxer->file_end > ODML_CHUNKLEN ? 1 : 0;
|
||||||
|
|
||||||
@ -314,7 +313,9 @@ static void avifile_write_header(muxer_t *muxer){
|
|||||||
switch(muxer->streams[i]->type){
|
switch(muxer->streams[i]->type){
|
||||||
case MUXER_TYPE_VIDEO:
|
case MUXER_TYPE_VIDEO:
|
||||||
hdrsize+=muxer->streams[i]->bih->biSize+8; // strf
|
hdrsize+=muxer->streams[i]->bih->biSize+8; // strf
|
||||||
hdrsize+=8+4*(9+8*1); // vprp
|
if (avi_prp_aspect > 0) {
|
||||||
|
hdrsize+=8+4*(9+8*1); // vprp
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case MUXER_TYPE_AUDIO:
|
case MUXER_TYPE_AUDIO:
|
||||||
hdrsize+=WFSIZE(muxer->streams[i]->wf)+8; // strf
|
hdrsize+=WFSIZE(muxer->streams[i]->wf)+8; // strf
|
||||||
@ -347,20 +348,22 @@ static void avifile_write_header(muxer_t *muxer){
|
|||||||
s->h.fccHandler = s->bih->biCompression;
|
s->h.fccHandler = s->bih->biCompression;
|
||||||
s->h.rcFrame.right = s->bih->biWidth;
|
s->h.rcFrame.right = s->bih->biWidth;
|
||||||
s->h.rcFrame.bottom = s->bih->biHeight;
|
s->h.rcFrame.bottom = s->bih->biHeight;
|
||||||
// fill out vprp info
|
if (avi_prp_aspect > 0) {
|
||||||
memset(&vprp, 0, sizeof(vprp));
|
// fill out vprp info
|
||||||
vprp.dwVerticalRefreshRate = (s->h.dwRate+s->h.dwScale-1)/s->h.dwScale;
|
memset(&vprp, 0, sizeof(vprp));
|
||||||
vprp.dwHTotalInT = muxer->avih.dwWidth;
|
vprp.dwVerticalRefreshRate = (s->h.dwRate+s->h.dwScale-1)/s->h.dwScale;
|
||||||
vprp.dwVTotalInLines = muxer->avih.dwHeight;
|
vprp.dwHTotalInT = muxer->avih.dwWidth;
|
||||||
vprp.dwFrameAspectRatio = avi_aspect(s->source);
|
vprp.dwVTotalInLines = muxer->avih.dwHeight;
|
||||||
vprp.dwFrameWidthInPixels = muxer->avih.dwWidth;
|
vprp.dwFrameAspectRatio = avi_aspect(avi_prp_aspect);
|
||||||
vprp.dwFrameHeightInLines = muxer->avih.dwHeight;
|
vprp.dwFrameWidthInPixels = muxer->avih.dwWidth;
|
||||||
vprp.nbFieldPerFrame = 1;
|
vprp.dwFrameHeightInLines = muxer->avih.dwHeight;
|
||||||
vprp.FieldInfo[0].CompressedBMHeight = muxer->avih.dwHeight;
|
vprp.nbFieldPerFrame = 1;
|
||||||
vprp.FieldInfo[0].CompressedBMWidth = muxer->avih.dwWidth;
|
vprp.FieldInfo[0].CompressedBMHeight = muxer->avih.dwHeight;
|
||||||
vprp.FieldInfo[0].ValidBMHeight = muxer->avih.dwHeight;
|
vprp.FieldInfo[0].CompressedBMWidth = muxer->avih.dwWidth;
|
||||||
vprp.FieldInfo[0].ValidBMWidth = muxer->avih.dwWidth;
|
vprp.FieldInfo[0].ValidBMHeight = muxer->avih.dwHeight;
|
||||||
hdrsize+=8+4*(9+8*1); // vprp
|
vprp.FieldInfo[0].ValidBMWidth = muxer->avih.dwWidth;
|
||||||
|
hdrsize+=8+4*(9+8*1); // vprp
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case MUXER_TYPE_AUDIO:
|
case MUXER_TYPE_AUDIO:
|
||||||
hdrsize+=WFSIZE(s->wf)+8; // strf
|
hdrsize+=WFSIZE(s->wf)+8; // strf
|
||||||
@ -379,14 +382,16 @@ static void avifile_write_header(muxer_t *muxer){
|
|||||||
int biSize=s->bih->biSize;
|
int biSize=s->bih->biSize;
|
||||||
le2me_BITMAPINFOHEADER(s->bih);
|
le2me_BITMAPINFOHEADER(s->bih);
|
||||||
write_avi_chunk(f,ckidSTREAMFORMAT,biSize,s->bih); /* BITMAPINFOHEADER */
|
write_avi_chunk(f,ckidSTREAMFORMAT,biSize,s->bih); /* BITMAPINFOHEADER */
|
||||||
le2me_BITMAPINFOHEADER(s->bih);
|
if (avi_prp_aspect > 0) {
|
||||||
le2me_VideoPropHeader(&vprp);
|
le2me_BITMAPINFOHEADER(s->bih);
|
||||||
le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[0]);
|
le2me_VideoPropHeader(&vprp);
|
||||||
le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[1]);
|
le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[0]);
|
||||||
write_avi_chunk(f,mmioFOURCC('v','p','r','p'),
|
le2me_VIDEO_FIELD_DESC(&vprp.FieldInfo[1]);
|
||||||
sizeof(VideoPropHeader) -
|
write_avi_chunk(f,mmioFOURCC('v','p','r','p'),
|
||||||
sizeof(VIDEO_FIELD_DESC)*(2-vprp.nbFieldPerFrame),
|
sizeof(VideoPropHeader) -
|
||||||
&vprp); /* Video Properties Header */
|
sizeof(VIDEO_FIELD_DESC)*(2-vprp.nbFieldPerFrame),
|
||||||
|
&vprp); /* Video Properties Header */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case MUXER_TYPE_AUDIO:
|
case MUXER_TYPE_AUDIO:
|
||||||
|
Loading…
Reference in New Issue
Block a user