Commit 2efaaf94 authored by Carl Eugen Hoyos's avatar Carl Eugen Hoyos

Support decoding yuv dpx images.

parent ea329b60
...@@ -173,11 +173,16 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -173,11 +173,16 @@ static int decode_frame(AVCodecContext *avctx,
break; break;
case 52: // ABGR case 52: // ABGR
case 51: // RGBA case 51: // RGBA
case 103: // UYVA4444
elements = 4; elements = 4;
break; break;
case 50: // RGB case 50: // RGB
case 102: // UYV444
elements = 3; elements = 3;
break; break;
case 100: // UYVY422
elements = 2;
break;
default: default:
avpriv_report_missing_feature(avctx, "Descriptor %d", descriptor); avpriv_report_missing_feature(avctx, "Descriptor %d", descriptor);
return AVERROR_PATCHWELCOME; return AVERROR_PATCHWELCOME;
...@@ -280,6 +285,15 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -280,6 +285,15 @@ static int decode_frame(AVCodecContext *avctx,
case 51160: case 51160:
avctx->pix_fmt = AV_PIX_FMT_RGBA64LE; avctx->pix_fmt = AV_PIX_FMT_RGBA64LE;
break; break;
case 100081:
avctx->pix_fmt = AV_PIX_FMT_UYVY422;
break;
case 102081:
avctx->pix_fmt = AV_PIX_FMT_YUV444P;
break;
case 103081:
avctx->pix_fmt = AV_PIX_FMT_YUVA444P;
break;
default: default:
av_log(avctx, AV_LOG_ERROR, "Unsupported format\n"); av_log(avctx, AV_LOG_ERROR, "Unsupported format\n");
return AVERROR_PATCHWELCOME; return AVERROR_PATCHWELCOME;
...@@ -344,9 +358,26 @@ static int decode_frame(AVCodecContext *avctx, ...@@ -344,9 +358,26 @@ static int decode_frame(AVCodecContext *avctx,
case 16: case 16:
elements *= 2; elements *= 2;
case 8: case 8:
if ( avctx->pix_fmt == AV_PIX_FMT_YUVA444P
|| avctx->pix_fmt == AV_PIX_FMT_YUV444P) {
for (x = 0; x < avctx->height; x++) {
ptr[0] = p->data[0] + x * p->linesize[0];
ptr[1] = p->data[1] + x * p->linesize[1];
ptr[2] = p->data[2] + x * p->linesize[2];
ptr[3] = p->data[3] + x * p->linesize[3];
for (y = 0; y < avctx->width; y++) {
*ptr[1]++ = *buf++;
*ptr[0]++ = *buf++;
*ptr[2]++ = *buf++;
if (avctx->pix_fmt == AV_PIX_FMT_YUVA444P)
*ptr[3]++ = *buf++;
}
}
} else {
av_image_copy_plane(ptr[0], p->linesize[0], av_image_copy_plane(ptr[0], p->linesize[0],
buf, stride, buf, stride,
elements * avctx->width, avctx->height); elements * avctx->width, avctx->height);
}
break; break;
} }
......
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