diff options
author | Carl Eugen Hoyos <cehoyos@ag.or.at> | 2016-11-25 11:06:14 +0100 |
---|---|---|
committer | Martin Storsjö <martin@martin.st> | 2017-03-22 14:26:15 +0200 |
commit | 628ce8b8b6b80cb3985d39e195b71b9d7fad9008 (patch) | |
tree | 62492b917fc858e287295507928863eaa3674488 /libavformat/flvdec.c | |
parent | 8e2346154e6d58b733fd20326ce706f82fd91b3e (diff) | |
download | ffmpeg-628ce8b8b6b80cb3985d39e195b71b9d7fad9008.tar.gz |
flvdec: Set avg_frame_rate for video streams
Signed-off-by: Martin Storsjö <martin@martin.st>
Diffstat (limited to 'libavformat/flvdec.c')
-rw-r--r-- | libavformat/flvdec.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/libavformat/flvdec.c b/libavformat/flvdec.c index b82ea3303b..693c859ebf 100644 --- a/libavformat/flvdec.c +++ b/libavformat/flvdec.c @@ -58,6 +58,7 @@ typedef struct FLVContext { int validate_next; int validate_count; int searched_for_end; + AVRational framerate; } FLVContext; static int flv_probe(AVProbeData *p) @@ -77,10 +78,14 @@ static int flv_probe(AVProbeData *p) static AVStream *create_stream(AVFormatContext *s, int codec_type) { + FLVContext *flv = s->priv_data; AVStream *st = avformat_new_stream(s, NULL); if (!st) return NULL; st->codecpar->codec_type = codec_type; + if (codec_type == AVMEDIA_TYPE_VIDEO) + st->avg_frame_rate = flv->framerate; + avpriv_set_pts_info(st, 32, 1, 1000); /* 32 bit pts in ms */ return st; } @@ -460,6 +465,10 @@ static int amf_parse_object(AVFormatContext *s, AVStream *astream, if (!st) return AVERROR(ENOMEM); st->codecpar->codec_id = AV_CODEC_ID_TEXT; + } else if (!strcmp(key, "framerate")) { + flv->framerate = av_d2q(num_val, 1000); + if (vstream) + vstream->avg_frame_rate = flv->framerate; } else if (flv->trust_metadata) { if (!strcmp(key, "videocodecid") && vpar) { flv_set_video_codec(s, vstream, num_val, 0); |