diff options
author | Marton Balint <cus@passwd.hu> | 2013-05-25 21:51:35 +0200 |
---|---|---|
committer | Marton Balint <cus@passwd.hu> | 2013-11-16 14:55:08 +0100 |
commit | 02b76aa3774cc97c1633a767e7e8e56a28e58bcc (patch) | |
tree | 13f4449ae404e7a2e88c754a70ac1a68567fe0bf | |
parent | d04b7de786780747878c080ba522405c6f542ccb (diff) | |
download | ffmpeg-02b76aa3774cc97c1633a767e7e8e56a28e58bcc.tar.gz |
ffplay: simplify early frame drop code
Also never early frame drop the first frame after a flush.
Signed-off-by: Marton Balint <cus@passwd.hu>
-rw-r--r-- | ffplay.c | 11 |
1 files changed, 5 insertions, 6 deletions
@@ -1722,12 +1722,11 @@ static int get_video_frame(VideoState *is, AVFrame *frame, AVPacket *pkt, int *s if (framedrop>0 || (framedrop && get_master_sync_type(is) != AV_SYNC_VIDEO_MASTER)) { SDL_LockMutex(is->pictq_mutex); - if (is->frame_last_pts != AV_NOPTS_VALUE && frame->pts != AV_NOPTS_VALUE) { - double clockdiff = get_clock(&is->vidclk) - get_master_clock(is); - double ptsdiff = dpts - is->frame_last_pts; - if (!isnan(clockdiff) && fabs(clockdiff) < AV_NOSYNC_THRESHOLD && - !isnan(ptsdiff) && ptsdiff > 0 && ptsdiff < AV_NOSYNC_THRESHOLD && - clockdiff + ptsdiff - is->frame_last_filter_delay < 0 && + if (frame->pts != AV_NOPTS_VALUE) { + double diff = dpts - get_master_clock(is); + if (!isnan(diff) && fabs(diff) < AV_NOSYNC_THRESHOLD && + diff - is->frame_last_filter_delay < 0 && + *serial == is->vidclk.serial && is->videoq.nb_packets) { is->frame_last_dropped_pos = av_frame_get_pkt_pos(frame); is->frame_last_dropped_pts = dpts; |