Commit aec96e23 authored by Carl Eugen Hoyos's avatar Carl Eugen Hoyos

lavc/dpx: Support decoding 12 bit colourspace with transparency information.

parent 346b3c5c
...@@ -264,11 +264,13 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -264,11 +264,13 @@ static int decode_frame(AVCodecContext *avctx,
avctx->pix_fmt = AV_PIX_FMT_GBRAP10; avctx->pix_fmt = AV_PIX_FMT_GBRAP10;
break; break;
case 50120: case 50120:
case 51120:
case 50121: case 50121:
case 51121:
avctx->pix_fmt = AV_PIX_FMT_GBRP12; avctx->pix_fmt = AV_PIX_FMT_GBRP12;
break; break;
case 51120:
case 51121:
avctx->pix_fmt = AV_PIX_FMT_GBRAP12;
break;
case 6161: case 6161:
avctx->pix_fmt = AV_PIX_FMT_GRAY16BE; avctx->pix_fmt = AV_PIX_FMT_GRAY16BE;
break; break;
...@@ -338,9 +340,10 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -338,9 +340,10 @@ static int decode_frame(AVCodecContext *avctx,
break; break;
case 12: case 12:
for (x = 0; x < avctx->height; x++) { for (x = 0; x < avctx->height; x++) {
uint16_t *dst[3] = {(uint16_t*)ptr[0], uint16_t *dst[4] = {(uint16_t*)ptr[0],
(uint16_t*)ptr[1], (uint16_t*)ptr[1],
(uint16_t*)ptr[2]}; (uint16_t*)ptr[2],
(uint16_t*)ptr[3]};
for (y = 0; y < avctx->width; y++) { for (y = 0; y < avctx->width; y++) {
*dst[2] = read16(&buf, endian) >> 4; *dst[2] = read16(&buf, endian) >> 4;
dst[2]++; dst[2]++;
...@@ -348,11 +351,10 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -348,11 +351,10 @@ static int decode_frame(AVCodecContext *avctx,
dst[0]++; dst[0]++;
*dst[1] = read16(&buf, endian) >> 4; *dst[1] = read16(&buf, endian) >> 4;
dst[1]++; dst[1]++;
// For 12 bit, ignore alpha
if (elements == 4) if (elements == 4)
buf += 2; *dst[3]++ = read16(&buf, endian) >> 4;
} }
for (i = 0; i < 3; i++) for (i = 0; i < elements; i++)
ptr[i] += p->linesize[i]; ptr[i] += p->linesize[i];
// Jump to next aligned position // Jump to next aligned position
buf += need_align; buf += need_align;
......
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