From fb5c9be82ea870fd0a7643214ebf8728d8e29991 Mon Sep 17 00:00:00 2001 From: Paul B Mahol Date: Wed, 22 Feb 2017 15:32:26 +0100 Subject: avcodec/qdrw: add support for 0x0001 code Fixes decoding of files which sets frame width/height this way. Signed-off-by: Paul B Mahol --- libavcodec/qdrw.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'libavcodec/qdrw.c') diff --git a/libavcodec/qdrw.c b/libavcodec/qdrw.c index e3d69c226d..2462e2ffcc 100644 --- a/libavcodec/qdrw.c +++ b/libavcodec/qdrw.c @@ -33,6 +33,7 @@ #include "internal.h" enum QuickdrawOpcodes { + CLIP = 0x0001, PACKBITSRECT = 0x0098, PACKBITSRGN, DIRECTBITSRECT, @@ -309,7 +310,7 @@ static int decode_frame(AVCodecContext *avctx, AVFrame * const p = data; GetByteContext gbc; int colors; - int w, h, ret; + int w, h, x0, y0, x1, y1, ret; int ver; bytestream2_init(&gbc, avpkt->data, avpkt->size); @@ -353,6 +354,16 @@ static int decode_frame(AVCodecContext *avctx, int opcode = bytestream2_get_be16(&gbc); switch(opcode) { + case CLIP: + bytestream2_get_be16(&gbc); + y0 = bytestream2_get_be16(&gbc); + x0 = bytestream2_get_be16(&gbc); + y1 = bytestream2_get_be16(&gbc); + x1 = bytestream2_get_be16(&gbc); + ret = ff_set_dimensions(avctx, x1 - x0, y1 - y0); + if (ret < 0) + return ret; + break; case PACKBITSRECT: case PACKBITSRGN: av_log(avctx, AV_LOG_DEBUG, "Parsing Packbit opcode\n"); -- cgit v1.2.1