Support decoding yuv dpx images.
This commit is contained in:
parent
ea329b60f5
commit
2efaaf9476
@ -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,
|
|||||||
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,
|
|||||||
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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user