mirror of https://github.com/mpv-player/mpv
demux_mkv: support svq3
The most awesome codec, not. The actual code for svq3 is actually just the part that checks for MKV_V_QUICKTIME (no other QT-muxed codecs are supported). The rest is minor refactoring, that actually improves the code in general. This is just enough to support the 2 svq3-in-mkv sample files I have.
This commit is contained in:
parent
6a88de05a7
commit
e40792c820
|
@ -1176,7 +1176,6 @@ static int demux_mkv_open_video(demuxer_t *demuxer, mkv_track_t *track)
|
||||||
{
|
{
|
||||||
unsigned char *extradata = NULL;
|
unsigned char *extradata = NULL;
|
||||||
unsigned int extradata_size = 0;
|
unsigned int extradata_size = 0;
|
||||||
bool raw = false;
|
|
||||||
struct sh_stream *sh = new_sh_stream(demuxer, STREAM_VIDEO);
|
struct sh_stream *sh = new_sh_stream(demuxer, STREAM_VIDEO);
|
||||||
if (!sh)
|
if (!sh)
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -1200,6 +1199,7 @@ static int demux_mkv_open_video(demuxer_t *demuxer, mkv_track_t *track)
|
||||||
|
|
||||||
extradata = track->private_data + 40;
|
extradata = track->private_data + 40;
|
||||||
extradata_size = track->private_size - 40;
|
extradata_size = track->private_size - 40;
|
||||||
|
mp_set_codec_from_tag(sh);
|
||||||
} else {
|
} else {
|
||||||
sh_v->bits_per_coded_sample = 24;
|
sh_v->bits_per_coded_sample = 24;
|
||||||
|
|
||||||
|
@ -1224,28 +1224,38 @@ static int demux_mkv_open_video(demuxer_t *demuxer, mkv_track_t *track)
|
||||||
extradata_size = cnt + 8;
|
extradata_size = cnt + 8;
|
||||||
extradata = src - 8;
|
extradata = src - 8;
|
||||||
track->realmedia = 1;
|
track->realmedia = 1;
|
||||||
|
mp_set_codec_from_tag(sh);
|
||||||
} else if (strcmp(track->codec_id, MKV_V_UNCOMPRESSED) == 0) {
|
} else if (strcmp(track->codec_id, MKV_V_UNCOMPRESSED) == 0) {
|
||||||
// raw video, "like AVI" - this is a FourCC
|
// raw video, "like AVI" - this is a FourCC
|
||||||
sh->format = track->colorspace;
|
sh->format = track->colorspace;
|
||||||
raw = true;
|
sh->codec = "rawvideo";
|
||||||
|
} else if (strcmp(track->codec_id, MKV_V_QUICKTIME) == 0) {
|
||||||
|
uint32_t fourcc1 = 0, fourcc2 = 0;
|
||||||
|
if (track->private_size >= 8) {
|
||||||
|
fourcc1 = AV_RL32(track->private_data + 0);
|
||||||
|
fourcc2 = AV_RL32(track->private_data + 4);
|
||||||
|
}
|
||||||
|
if (fourcc1 == MP_FOURCC('S', 'V', 'Q', '3') ||
|
||||||
|
fourcc2 == MP_FOURCC('S', 'V', 'Q', '3'))
|
||||||
|
{
|
||||||
|
sh->codec = "svq3";
|
||||||
|
extradata = track->private_data;
|
||||||
|
extradata_size = track->private_size;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
const videocodec_info_t *vi = vinfo;
|
const videocodec_info_t *vi = vinfo;
|
||||||
while (vi->id && strcmp(vi->id, track->codec_id))
|
while (vi->id && strcmp(vi->id, track->codec_id))
|
||||||
vi++;
|
vi++;
|
||||||
|
if (vi->id) {
|
||||||
sh->format = vi->fourcc;
|
sh->format = vi->fourcc;
|
||||||
|
mp_set_codec_from_tag(sh);
|
||||||
|
}
|
||||||
if (vi->extradata && track->private_data && track->private_size > 0)
|
if (vi->extradata && track->private_data && track->private_size > 0)
|
||||||
{
|
{
|
||||||
extradata = track->private_data;
|
extradata = track->private_data;
|
||||||
extradata_size = track->private_size;
|
extradata_size = track->private_size;
|
||||||
}
|
}
|
||||||
track->parse = vi->parse;
|
track->parse = vi->parse;
|
||||||
if (!vi->id) {
|
|
||||||
MP_WARN(demuxer, "Unknown/unsupported "
|
|
||||||
"CodecID (%s) or missing/bad CodecPrivate\n"
|
|
||||||
"data (track %u).\n",
|
|
||||||
track->codec_id, track->tnum);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1258,10 +1268,10 @@ static int demux_mkv_open_video(demuxer_t *demuxer, mkv_track_t *track)
|
||||||
sh_v->coded_height = track->v_height;
|
sh_v->coded_height = track->v_height;
|
||||||
sh_v->extradata = talloc_memdup(sh_v, extradata, extradata_size);
|
sh_v->extradata = talloc_memdup(sh_v, extradata, extradata_size);
|
||||||
sh_v->extradata_len = extradata_size;
|
sh_v->extradata_len = extradata_size;
|
||||||
if (raw) {
|
if (!sh->codec) {
|
||||||
sh->codec = "rawvideo";
|
MP_WARN(demuxer, "Unknown/unsupported CodecID (%s) or missing/bad "
|
||||||
} else {
|
"CodecPrivate data (track %u).\n",
|
||||||
mp_set_codec_from_tag(sh);
|
track->codec_id, track->tnum);
|
||||||
}
|
}
|
||||||
if (track->v_frate == 0.0)
|
if (track->v_frate == 0.0)
|
||||||
track->v_frate = 25.0;
|
track->v_frate = 25.0;
|
||||||
|
|
Loading…
Reference in New Issue