mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
avformat/smush: read ANIMv2 a/v parameters
SMUSH ANIM files with subversion 2 provide additional fields for framerate and samplerate, use them if available, otherwise default to 12 fps which is the default for almost all ANIMv2 since 1995. Fixes the too-fast playback of test files from LucasArts games released 1995-1997. It was not noticed since Audio for those isn't decoded by ffmpeg. Signed-off-by: Manuel Lauss <manuel.lauss@gmail.com> Signed-off-by: Marton Balint <cus@passwd.hu>
This commit is contained in:
parent
3b0e6c0ecc
commit
d21134313f
@ -51,7 +51,7 @@ static int smush_read_header(AVFormatContext *ctx)
|
|||||||
AVStream *vst, *ast;
|
AVStream *vst, *ast;
|
||||||
uint32_t magic, nframes, size, subversion, i;
|
uint32_t magic, nframes, size, subversion, i;
|
||||||
uint32_t width = 0, height = 0, got_audio = 0, read = 0;
|
uint32_t width = 0, height = 0, got_audio = 0, read = 0;
|
||||||
uint32_t sample_rate, channels, palette[256];
|
uint32_t sample_rate, channels, palette[256], frame_rate = 15;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
magic = avio_rb32(pb);
|
magic = avio_rb32(pb);
|
||||||
@ -64,6 +64,7 @@ static int smush_read_header(AVFormatContext *ctx)
|
|||||||
size = avio_rb32(pb);
|
size = avio_rb32(pb);
|
||||||
if (size < 3 * 256 + 6)
|
if (size < 3 * 256 + 6)
|
||||||
return AVERROR_INVALIDDATA;
|
return AVERROR_INVALIDDATA;
|
||||||
|
size -= 3 * 256 + 6;
|
||||||
|
|
||||||
smush->version = 0;
|
smush->version = 0;
|
||||||
subversion = avio_rl16(pb);
|
subversion = avio_rl16(pb);
|
||||||
@ -76,7 +77,17 @@ static int smush_read_header(AVFormatContext *ctx)
|
|||||||
for (i = 0; i < 256; i++)
|
for (i = 0; i < 256; i++)
|
||||||
palette[i] = avio_rb24(pb);
|
palette[i] = avio_rb24(pb);
|
||||||
|
|
||||||
avio_skip(pb, size - (3 * 256 + 6));
|
if (subversion > 1) {
|
||||||
|
if (size < 12)
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
size -= 12;
|
||||||
|
frame_rate = avio_rl32(pb);
|
||||||
|
avio_skip(pb, 4); // max size of FRME chunk in file
|
||||||
|
sample_rate = avio_rl32(pb);
|
||||||
|
if (frame_rate < 1 || frame_rate > 70)
|
||||||
|
frame_rate = 12;
|
||||||
|
}
|
||||||
|
avio_skip(pb, size);
|
||||||
} else if (magic == MKBETAG('S', 'A', 'N', 'M')) {
|
} else if (magic == MKBETAG('S', 'A', 'N', 'M')) {
|
||||||
if (avio_rb32(pb) != MKBETAG('S', 'H', 'D', 'R'))
|
if (avio_rb32(pb) != MKBETAG('S', 'H', 'D', 'R'))
|
||||||
return AVERROR_INVALIDDATA;
|
return AVERROR_INVALIDDATA;
|
||||||
@ -146,7 +157,7 @@ static int smush_read_header(AVFormatContext *ctx)
|
|||||||
|
|
||||||
smush->video_stream_index = vst->index;
|
smush->video_stream_index = vst->index;
|
||||||
|
|
||||||
avpriv_set_pts_info(vst, 64, 1, 15);
|
avpriv_set_pts_info(vst, 64, 1, frame_rate);
|
||||||
|
|
||||||
vst->start_time = 0;
|
vst->start_time = 0;
|
||||||
vst->duration =
|
vst->duration =
|
||||||
|
Loading…
Reference in New Issue
Block a user