Commit c19830aa authored by Carl Eugen Hoyos's avatar Carl Eugen Hoyos Committed by Vittorio Giovara

rscc: Support palette format

Signed-off-by: 's avatarVittorio Giovara <vittorio.giovara@gmail.com>
parent b8d5070d
......@@ -31,7 +31,7 @@
* and it can be deflated or not. Similarly, pixel data comes after the header
* and a variable size value, and it can be deflated or just raw.
*
* Supports: BGRA, BGR24, RGB555, RGB8
* Supports: PAL8, BGRA, BGR24, RGB555, RGB8
*/
#include <stdint.h>
......@@ -59,6 +59,8 @@ typedef struct RsccContext {
unsigned int tiles_size;
int component_size;
uint8_t palette[AVPALETTE_SIZE];
/* zlib interaction */
uint8_t *inflated_buf;
uLongf inflated_size;
......@@ -89,8 +91,8 @@ static av_cold int rscc_init(AVCodecContext *avctx)
ctx->component_size = avctx->bits_per_coded_sample / 8;
switch (avctx->bits_per_coded_sample) {
case 8:
avpriv_report_missing_feature(avctx, "8 bits per pixel");
return AVERROR_PATCHWELCOME;
avctx->pix_fmt = AV_PIX_FMT_PAL8;
break;
case 16:
avctx->pix_fmt = AV_PIX_FMT_RGB555LE;
break;
......@@ -291,6 +293,19 @@ static int rscc_decode_frame(AVCodecContext *avctx, void *data,
} else {
frame->pict_type = AV_PICTURE_TYPE_P;
}
/* Palette handling */
if (avctx->pix_fmt == AV_PIX_FMT_PAL8) {
const uint8_t *palette = av_packet_get_side_data(avpkt,
AV_PKT_DATA_PALETTE,
NULL);
if (palette) {
frame->palette_has_changed = 1;
memcpy(ctx->palette, palette, AVPALETTE_SIZE);
}
memcpy(frame->data[1], ctx->palette, AVPALETTE_SIZE);
}
*got_frame = 1;
end:
......
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