summaryrefslogtreecommitdiff
path: root/ffplay.c
diff options
context:
space:
mode:
authorMarton Balint <cus@passwd.hu>2013-02-16 14:24:34 +0100
committerMarton Balint <cus@passwd.hu>2013-02-27 21:34:12 +0100
commit38f649662c12c0d23d1be6f066c6ca597f6c1cbb (patch)
tree2abc91ed342cdfdb23741291b15afd80c8117086 /ffplay.c
parent36dc476f83f7e5c4849e1c37f1cc9dc7ef75079d (diff)
ffplay: allow frame dropping if we redisplay an already displayed frame
Signed-off-by: Marton Balint <cus@passwd.hu>
Diffstat (limited to 'ffplay.c')
-rw-r--r--ffplay.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/ffplay.c b/ffplay.c
index 0d4fde6344..b4394e3619 100644
--- a/ffplay.c
+++ b/ffplay.c
@@ -1307,8 +1307,9 @@ static void video_refresh(void *opaque, double *remaining_time)
}
if (is->video_st) {
+ int redisplay = 0;
if (is->force_refresh)
- pictq_prev_picture(is);
+ redisplay = pictq_prev_picture(is);
retry:
if (is->pictq_size == 0) {
SDL_LockMutex(is->pictq_mutex);
@@ -1325,6 +1326,7 @@ retry:
if (vp->serial != is->videoq.serial) {
pictq_next_picture(is);
+ redisplay = 0;
goto retry;
}
@@ -1355,9 +1357,11 @@ retry:
if (is->pictq_size > 1) {
VideoPicture *nextvp = &is->pictq[(is->pictq_rindex + 1) % VIDEO_PICTURE_QUEUE_SIZE];
duration = nextvp->pts - vp->pts;
- if(!is->step && (framedrop>0 || (framedrop && get_master_sync_type(is) != AV_SYNC_VIDEO_MASTER)) && time > is->frame_timer + duration){
- is->frame_drops_late++;
+ if(!is->step && (redisplay || framedrop>0 || (framedrop && get_master_sync_type(is) != AV_SYNC_VIDEO_MASTER)) && time > is->frame_timer + duration){
+ if (!redisplay)
+ is->frame_drops_late++;
pictq_next_picture(is);
+ redisplay = 0;
goto retry;
}
}