reduce stutter if we learn too late that the stream contains B-frames.

Originally committed as revision 3801 to svn://svn.ffmpeg.org/ffmpeg/trunk
pull/126/head
Loren Merritt 20 years ago
parent 2d74541476
commit 1b2dcdc1e0
  1. 16
      libavcodec/h264.c

@ -6111,22 +6111,26 @@ static int decode_frame(AVCodecContext *avctx,
Picture *prev = h->delayed_pic[0]; Picture *prev = h->delayed_pic[0];
Picture *out; Picture *out;
if(cur->pict_type == B_TYPE if(s->low_delay
&& (cur->pict_type == B_TYPE
|| (!h->sps.gaps_in_frame_num_allowed_flag || (!h->sps.gaps_in_frame_num_allowed_flag
&& prev && cur->poc - prev->poc > 2)){ && prev && cur->poc - prev->poc > 2))){
s->low_delay = 0; s->low_delay = 0;
s->avctx->has_b_frames = 1; s->avctx->has_b_frames = 1;
if(prev && prev->poc > cur->poc)
// too late to display this frame
cur = prev;
} }
if(s->low_delay || !prev || cur->pict_type == B_TYPE) if(s->low_delay || !prev || cur->pict_type == B_TYPE)
out = cur; out = cur;
else{ else
out = prev; out = prev;
if(prev->reference == 1) if(s->low_delay || !prev || out == prev){
if(prev && prev->reference == 1)
prev->reference = 0; prev->reference = 0;
}
if(!s->low_delay && (!prev || out == prev))
h->delayed_pic[0] = cur; h->delayed_pic[0] = cur;
}
*pict= *(AVFrame*)out; *pict= *(AVFrame*)out;
} }

Loading…
Cancel
Save