diff options
author | Baptiste Coudurier <baptiste.coudurier@gmail.com> | 2011-03-01 23:54:29 +0000 |
---|---|---|
committer | Mans Rullgard <mans@mansr.com> | 2011-03-02 00:23:08 +0000 |
commit | 06ed4873e6e6aed8ec7cc24285d610ef4060880e (patch) | |
tree | 264c29de12d46488cb6ed6d51388b82e0ad01321 | |
parent | 99bbc781e9c134066887fc521db7a9d3607e3de1 (diff) | |
download | ffmpeg-06ed4873e6e6aed8ec7cc24285d610ef4060880e.tar.gz |
movenc: use correct tag for dvcpro hd
Signed-off-by: Mans Rullgard <mans@mansr.com>
-rw-r--r-- | libavformat/movenc.c | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/libavformat/movenc.c b/libavformat/movenc.c index 3722bb6384..231976b0c6 100644 --- a/libavformat/movenc.c +++ b/libavformat/movenc.c @@ -623,12 +623,23 @@ static int mov_get_dv_codec_tag(AVFormatContext *s, MOVTrack *track) { int tag; - if (track->enc->height == 480) /* NTSC */ - if (track->enc->pix_fmt == PIX_FMT_YUV422P) tag = MKTAG('d','v','5','n'); - else tag = MKTAG('d','v','c',' '); - else if (track->enc->pix_fmt == PIX_FMT_YUV422P) tag = MKTAG('d','v','5','p'); - else if (track->enc->pix_fmt == PIX_FMT_YUV420P) tag = MKTAG('d','v','c','p'); - else tag = MKTAG('d','v','p','p'); + if (track->enc->width == 720) /* SD */ + if (track->enc->height == 480) /* NTSC */ + if (track->enc->pix_fmt == PIX_FMT_YUV422P) tag = MKTAG('d','v','5','n'); + else tag = MKTAG('d','v','c',' '); + else if (track->enc->pix_fmt == PIX_FMT_YUV422P) tag = MKTAG('d','v','5','p'); + else if (track->enc->pix_fmt == PIX_FMT_YUV420P) tag = MKTAG('d','v','c','p'); + else tag = MKTAG('d','v','p','p'); + else if (track->enc->height == 720) /* HD 720 line */ + if (track->enc->time_base.den == 50) tag = MKTAG('d','v','h','q'); + else tag = MKTAG('d','v','h','p'); + else if (track->enc->height == 1080) /* HD 1080 line */ + if (track->enc->time_base.den == 25) tag = MKTAG('d','v','h','5'); + else tag = MKTAG('d','v','h','6'); + else { + av_log(s, AV_LOG_ERROR, "unsupported height for dv codec\n"); + return 0; + } return tag; } |