diff options
author | Mats Peterson <matsp888@yahoo.com> | 2016-02-24 18:14:05 +0100 |
---|---|---|
committer | Michael Niedermayer <michael@niedermayer.cc> | 2016-02-27 02:03:02 +0100 |
commit | 6aac43f1805dcc65d51c1e4a9df34746b8e0d0fd (patch) | |
tree | 0d7500b14e9888554888cbaeef4021075265856e /libavformat/matroskadec.c | |
parent | 9a2778082121ea44d06a2f00f822ea99109c7fd8 (diff) | |
download | ffmpeg-6aac43f1805dcc65d51c1e4a9df34746b8e0d0fd.tar.gz |
lavf/matroskadec: Process QuickTime palette per track
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
Diffstat (limited to 'libavformat/matroskadec.c')
-rw-r--r-- | libavformat/matroskadec.c | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/libavformat/matroskadec.c b/libavformat/matroskadec.c index d788232150..d20568cfb1 100644 --- a/libavformat/matroskadec.c +++ b/libavformat/matroskadec.c @@ -190,6 +190,9 @@ typedef struct MatroskaTrack { int64_t end_timecode; int ms_compat; uint64_t max_block_additional_id; + + uint32_t palette[AVPALETTE_COUNT]; + int has_palette; } MatroskaTrack; typedef struct MatroskaAttachment { @@ -314,9 +317,6 @@ typedef struct MatroskaDemuxContext { /* WebM DASH Manifest live flag/ */ int is_live; - - uint32_t palette[AVPALETTE_COUNT]; - int has_palette; } MatroskaDemuxContext; typedef struct MatroskaBlock { @@ -1930,9 +1930,9 @@ static int matroska_parse_tracks(AVFormatContext *s) ffio_init_context(&b, track->codec_priv.data, track->codec_priv.size, 0, NULL, NULL, NULL, NULL); - if (ff_get_qtpalette(codec_id, &b, matroska->palette)) { + if (ff_get_qtpalette(codec_id, &b, track->palette)) { bit_depth &= 0x1F; - matroska->has_palette = 1; + track->has_palette = 1; } } } else if (codec_id == AV_CODEC_ID_PCM_S16BE) { @@ -2378,16 +2378,19 @@ static int matroska_deliver_packet(MatroskaDemuxContext *matroska, AVPacket *pkt) { if (matroska->num_packets > 0) { + MatroskaTrack *tracks = matroska->tracks.elem; + MatroskaTrack *track; memcpy(pkt, matroska->packets[0], sizeof(AVPacket)); av_freep(&matroska->packets[0]); - if (matroska->has_palette) { + track = &tracks[pkt->stream_index]; + if (track->has_palette) { uint8_t *pal = av_packet_new_side_data(pkt, AV_PKT_DATA_PALETTE, AVPALETTE_SIZE); if (!pal) { av_log(matroska->ctx, AV_LOG_ERROR, "Cannot append palette to packet\n"); } else { - memcpy(pal, matroska->palette, AVPALETTE_SIZE); + memcpy(pal, track->palette, AVPALETTE_SIZE); } - matroska->has_palette = 0; + track->has_palette = 0; } if (matroska->num_packets > 1) { void *newpackets; |