diff options
author | Nazo <lovesyao@aol.com> | 2006-09-17 09:39:49 +0000 |
---|---|---|
committer | Benjamin Larsson <banan@ludd.ltu.se> | 2006-09-17 09:39:49 +0000 |
commit | aeb20f7f9d37f38cd7df94158b19999a13ba5a12 (patch) | |
tree | 4f89fdd84405a4addce0f8fe3c33595c5990b413 | |
parent | e66477afbe0d3d48852b513c95497809a2fc2739 (diff) | |
download | ffmpeg-aeb20f7f9d37f38cd7df94158b19999a13ba5a12.tar.gz |
FLV seeking patch by Nazo. lovesyao at aol com.
Originally committed as revision 6285 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavformat/flvdec.c | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/libavformat/flvdec.c b/libavformat/flvdec.c index 0746fffcfe..9f9c33496f 100644 --- a/libavformat/flvdec.c +++ b/libavformat/flvdec.c @@ -55,15 +55,18 @@ static int flv_read_header(AVFormatContext *s, url_fseek(&s->pb, offset, SEEK_SET); + s->start_time = 0; + return 0; } static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) { - int ret, i, type, size, pts, flags, is_audio, next; + int ret, i, type, size, pts, flags, is_audio, next, pos; AVStream *st = NULL; for(;;){ + pos = url_ftell(&s->pb); url_fskip(&s->pb, 4); /* size of previous packet */ type = get_byte(&s->pb); size = get_be24(&s->pb); @@ -154,6 +157,8 @@ static int flv_read_packet(AVFormatContext *s, AVPacket *pkt) url_fseek(&s->pb, next, SEEK_SET); continue; } + if ((flags >> 4)==1) + av_add_index_entry(st, pos, pts, size, 0, AVINDEX_KEYFRAME); break; } @@ -216,6 +221,17 @@ static int flv_read_close(AVFormatContext *s) return 0; } +static int flv_read_seek(AVFormatContext *s, int stream_index, int64_t timestamp, int flags) +{ + AVStream *st = s->streams[stream_index]; + int index = av_index_search_timestamp(st, timestamp, flags); + if (index < 0) + return -1; + url_fseek(&s->pb, st->index_entries[index].pos, SEEK_SET); + + return 0; +} + AVInputFormat flv_demuxer = { "flv", "flv format", @@ -224,6 +240,7 @@ AVInputFormat flv_demuxer = { flv_read_header, flv_read_packet, flv_read_close, + flv_read_seek, .extensions = "flv", .value = CODEC_ID_FLV1, }; |