[FFmpeg-cvslog] avcodec/mjpegdec: rgba64 ljpeg support
Michael Niedermayer
git at videolan.org
Mon Sep 16 03:12:16 CEST 2013
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Mon Sep 16 03:00:54 2013 +0200| [7fb2622456b9c43b96b2a1e64a3aeb13281ce3de] | committer: Michael Niedermayer
avcodec/mjpegdec: rgba64 ljpeg support
Fixes Ticket2965
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=7fb2622456b9c43b96b2a1e64a3aeb13281ce3de
---
libavcodec/mjpegdec.c | 12 +++++++++---
1 file changed, 9 insertions(+), 3 deletions(-)
diff --git a/libavcodec/mjpegdec.c b/libavcodec/mjpegdec.c
index 266254c..fcf7ec1 100644
--- a/libavcodec/mjpegdec.c
+++ b/libavcodec/mjpegdec.c
@@ -371,7 +371,7 @@ int ff_mjpeg_decode_sof(MJpegDecodeContext *s)
break;
case 0x11111111:
if (s->rgb)
- s->avctx->pix_fmt = AV_PIX_FMT_ABGR;
+ s->avctx->pix_fmt = s->bits <= 8 ? AV_PIX_FMT_ABGR : AV_PIX_FMT_RGBA64;
else {
s->avctx->pix_fmt = s->bits <= 8 ? AV_PIX_FMT_YUVA444P : AV_PIX_FMT_YUVA444P16;
s->avctx->color_range = s->cs_itu601 ? AVCOL_RANGE_MPEG : AVCOL_RANGE_JPEG;
@@ -868,8 +868,14 @@ static int ljpeg_decode_rgb_scan(MJpegDecodeContext *s, int nb_components, int p
if (s->nb_components == 4) {
for(i=0; i<nb_components; i++) {
int c= s->comp_index[i];
- for(mb_x = 0; mb_x < s->mb_width; mb_x++) {
- ptr[4*mb_x+3-c] = buffer[mb_x][i];
+ if (s->bits <= 8) {
+ for(mb_x = 0; mb_x < s->mb_width; mb_x++) {
+ ptr[4*mb_x+3-c] = buffer[mb_x][i];
+ }
+ } else {
+ for(mb_x = 0; mb_x < s->mb_width; mb_x++) {
+ ((uint16_t*)ptr)[4*mb_x+c] = buffer[mb_x][i];
+ }
}
}
} else if (s->rct) {
More information about the ffmpeg-cvslog
mailing list