ffmpeg | branch: master | Michael Niedermayer <michae...@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 _______________________________________________ ffmpeg-cvslog mailing list ffmpeg-cvslog@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-cvslog