[FFmpeg-cvslog] lavc/msmpeg4enc: use AVCodecContext.framerate when available
Anton Khirnov
git at videolan.org
Mon May 15 11:36:46 EEST 2023
ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Thu May 4 11:45:29 2023 +0200| [3fabf712070cb060a01e93d70dbdf837f0efa98e] | committer: Anton Khirnov
lavc/msmpeg4enc: use AVCodecContext.framerate when available
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=3fabf712070cb060a01e93d70dbdf837f0efa98e
---
libavcodec/msmpeg4enc.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/libavcodec/msmpeg4enc.c b/libavcodec/msmpeg4enc.c
index 54121438a0..df190d376c 100644
--- a/libavcodec/msmpeg4enc.c
+++ b/libavcodec/msmpeg4enc.c
@@ -280,7 +280,13 @@ void ff_msmpeg4_encode_picture_header(MpegEncContext * s)
void ff_msmpeg4_encode_ext_header(MpegEncContext * s)
{
- unsigned fps = s->avctx->time_base.den / s->avctx->time_base.num / FFMAX(s->avctx->ticks_per_frame, 1);
+ unsigned fps;
+
+ if (s->avctx->framerate.num > 0 && s->avctx->framerate.den > 0)
+ fps = s->avctx->framerate.num / s->avctx->framerate.den;
+ else
+ fps = s->avctx->time_base.den / s->avctx->time_base.num / FFMAX(s->avctx->ticks_per_frame, 1);
+
put_bits(&s->pb, 5, FFMIN(fps, 31)); //yes 29.97 -> 29
put_bits(&s->pb, 11, FFMIN(s->bit_rate / 1024, 2047));
More information about the ffmpeg-cvslog
mailing list