[FFmpeg-cvslog] ffmpeg: Use input packet duration in vfr/cfr code if available and valid

Michael Niedermayer git at videolan.org
Wed Nov 19 18:40:43 CET 2014


ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Wed Nov 19 15:44:42 2014 +0100| [c5092025901b37aa5de4f290afb61fc5377eb79d] | committer: Michael Niedermayer

ffmpeg: Use input packet duration in vfr/cfr code if available and valid

Fixes Ticket3052

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=c5092025901b37aa5de4f290afb61fc5377eb79d
---

 ffmpeg.c                            |    8 ++++++++
 tests/ref/fate/gif-disposal-restore |    1 +
 2 files changed, 9 insertions(+)

diff --git a/ffmpeg.c b/ffmpeg.c
index 0f4b2aa..3b24cf9 100644
--- a/ffmpeg.c
+++ b/ffmpeg.c
@@ -893,6 +893,14 @@ static void do_video_out(AVFormatContext *s,
     if(ist && ist->st->start_time != AV_NOPTS_VALUE && ist->st->first_dts != AV_NOPTS_VALUE && ost->frame_rate.num)
         duration = 1/(av_q2d(ost->frame_rate) * av_q2d(enc->time_base));
 
+    if (!ost->filters_script &&
+        !ost->filters &&
+        next_picture &&
+        ist &&
+        lrintf(av_frame_get_pkt_duration(next_picture) * av_q2d(ist->st->time_base) / av_q2d(enc->time_base)) > 0) {
+        duration = lrintf(av_frame_get_pkt_duration(next_picture) * av_q2d(ist->st->time_base) / av_q2d(enc->time_base));
+    }
+
     sync_ipts = next_picture->pts;
     delta0 = sync_ipts - ost->sync_opts;
     delta  = delta0 + duration;
diff --git a/tests/ref/fate/gif-disposal-restore b/tests/ref/fate/gif-disposal-restore
index c5ebfcb..c0c04b4 100644
--- a/tests/ref/fate/gif-disposal-restore
+++ b/tests/ref/fate/gif-disposal-restore
@@ -1,3 +1,4 @@
 #tb 0: 1/1
 0,          0,          0,        1,   112320, 0xb8afe429
+0,          0,          0,        1,   112320, 0xae588a4b
 0,          3,          3,        1,   112320, 0xccdd27b7



More information about the ffmpeg-cvslog mailing list