Commit eabe58ad authored by michael's avatar michael

fix useless framerate messup


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4167 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent d986979c
...@@ -205,13 +205,13 @@ static const CodecTag nsv_codec_audio_tags[] = { ...@@ -205,13 +205,13 @@ static const CodecTag nsv_codec_audio_tags[] = {
{ 0, 0 }, { 0, 0 },
}; };
static const uint64_t nsv_framerate_table[] = { static const AVRational nsv_framerate_table[] = {
((uint64_t)AV_TIME_BASE * 30), {30,1},
((uint64_t)AV_TIME_BASE * 30000 / 1001), /* 29.97 */ {30000,1001},
((uint64_t)AV_TIME_BASE * 25), {25,1},
((uint64_t)AV_TIME_BASE * 24000 / 1001), /* 23.98 */ {24000,1001},
((uint64_t)AV_TIME_BASE * 30), /* ?? */ {30,1},
((uint64_t)AV_TIME_BASE * 15000 / 1001), /* 14.98 */ {15000,1001},
}; };
//static int nsv_load_index(AVFormatContext *s); //static int nsv_load_index(AVFormatContext *s);
...@@ -401,7 +401,8 @@ static int nsv_parse_NSVs_header(AVFormatContext *s, AVFormatParameters *ap) ...@@ -401,7 +401,8 @@ static int nsv_parse_NSVs_header(AVFormatContext *s, AVFormatParameters *ap)
ByteIOContext *pb = &s->pb; ByteIOContext *pb = &s->pb;
uint32_t vtag, atag; uint32_t vtag, atag;
uint16_t vwidth, vheight; uint16_t vwidth, vheight;
uint32_t framerate; AVRational framerate;
int i;
uint16_t unknown; uint16_t unknown;
AVStream *st; AVStream *st;
NSVStream *nst; NSVStream *nst;
...@@ -411,17 +412,17 @@ static int nsv_parse_NSVs_header(AVFormatContext *s, AVFormatParameters *ap) ...@@ -411,17 +412,17 @@ static int nsv_parse_NSVs_header(AVFormatContext *s, AVFormatParameters *ap)
atag = get_le32(pb); atag = get_le32(pb);
vwidth = get_le16(pb); vwidth = get_le16(pb);
vheight = get_le16(pb); vheight = get_le16(pb);
framerate = (uint8_t)get_byte(pb); i = get_byte(pb);
/* XXX how big must the table be ? */ /* XXX how big must the table be ? */
/* seems there is more to that... */ /* seems there is more to that... */
PRINT(("NSV NSVs framerate code %2x\n", framerate)); PRINT(("NSV NSVs framerate code %2x\n", i));
framerate = (framerate & 0x80)?(nsv_framerate_table[framerate & 0x7F]):(framerate*AV_TIME_BASE); if(i&0x80) framerate= nsv_framerate_table[i & 0x7F];
else framerate= (AVRational){i, 1};
unknown = get_le16(pb); unknown = get_le16(pb);
#ifdef DEBUG #ifdef DEBUG
print_tag("NSV NSVs vtag", vtag, 0); print_tag("NSV NSVs vtag", vtag, 0);
print_tag("NSV NSVs atag", atag, 0); print_tag("NSV NSVs atag", atag, 0);
PRINT(("NSV NSVs vsize %dx%d\n", vwidth, vheight)); PRINT(("NSV NSVs vsize %dx%d\n", vwidth, vheight));
PRINT(("NSV NSVs framerate %2x\n", framerate));
#endif #endif
/* XXX change to ap != NULL ? */ /* XXX change to ap != NULL ? */
...@@ -446,9 +447,9 @@ static int nsv_parse_NSVs_header(AVFormatContext *s, AVFormatParameters *ap) ...@@ -446,9 +447,9 @@ static int nsv_parse_NSVs_header(AVFormatContext *s, AVFormatParameters *ap)
st->codec.height = vheight; st->codec.height = vheight;
st->codec.bits_per_sample = 24; /* depth XXX */ st->codec.bits_per_sample = 24; /* depth XXX */
st->codec.frame_rate = framerate; av_set_pts_info(st, 64, framerate.den, framerate.num);
st->codec.frame_rate_base = AV_TIME_BASE; st->codec.frame_rate = framerate.num;
av_set_pts_info(st, 64, AV_TIME_BASE, framerate); st->codec.frame_rate_base = framerate.den;
st->start_time = 0; st->start_time = 0;
st->duration = nsv->duration; st->duration = nsv->duration;
} }
......
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