Commit 0ed151f9 authored by bcoudurier's avatar bcoudurier

set got_key_frame when packet is video, fix first video packet with index 0 and 2 streams

git-svn-id: file:///var/local/repositories/ffmpeg/trunk@13551 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 87f6400d
...@@ -2100,17 +2100,11 @@ static int http_prepare_data(HTTPContext *c) ...@@ -2100,17 +2100,11 @@ static int http_prepare_data(HTTPContext *c)
for(i=0;i<c->stream->nb_streams;i++) { for(i=0;i<c->stream->nb_streams;i++) {
if (c->feed_streams[i] == pkt.stream_index) { if (c->feed_streams[i] == pkt.stream_index) {
pkt.stream_index = i; pkt.stream_index = i;
if (pkt.flags & PKT_FLAG_KEY) if (pkt.flags & PKT_FLAG_KEY &&
c->got_key_frame |= 1 << i; c->fmt_in->streams[source_index]->codec->codec_type
/* See if we have all the key frames, then == CODEC_TYPE_VIDEO)
* we start to send. This logic is not quite c->got_key_frame = 1;
* right, but it works for the case of a if (!c->stream->send_on_key || c->got_key_frame)
* single video stream with one or more
* audio streams (for which every frame is
* typically a key frame).
*/
if (!c->stream->send_on_key ||
((c->got_key_frame + 1) >> c->stream->nb_streams))
goto send_it; goto send_it;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment