Commit c36edf38 authored by Michael Niedermayer's avatar Michael Niedermayer

jpeg: rgb support

Fixes Ticket297

Based on a patch by Carl
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 3638f56d
...@@ -325,10 +325,14 @@ int ff_mjpeg_decode_sof(MJpegDecodeContext *s) ...@@ -325,10 +325,14 @@ int ff_mjpeg_decode_sof(MJpegDecodeContext *s)
case 0x11111100: case 0x11111100:
if(s->rgb){ if(s->rgb){
s->avctx->pix_fmt = PIX_FMT_BGRA; s->avctx->pix_fmt = PIX_FMT_BGRA;
}else{
if(s->component_id[0] == 'Q' && s->component_id[1] == 'F' && s->component_id[2] == 'A'){
s->avctx->pix_fmt = PIX_FMT_GBR24P;
}else{ }else{
s->avctx->pix_fmt = s->cs_itu601 ? PIX_FMT_YUV444P : PIX_FMT_YUVJ444P; s->avctx->pix_fmt = s->cs_itu601 ? PIX_FMT_YUV444P : PIX_FMT_YUVJ444P;
s->avctx->color_range = s->cs_itu601 ? AVCOL_RANGE_MPEG : AVCOL_RANGE_JPEG; s->avctx->color_range = s->cs_itu601 ? AVCOL_RANGE_MPEG : AVCOL_RANGE_JPEG;
} }
}
assert(s->nb_components==3); assert(s->nb_components==3);
break; break;
case 0x11000000: case 0x11000000:
...@@ -992,6 +996,9 @@ int ff_mjpeg_decode_sos(MJpegDecodeContext *s, ...@@ -992,6 +996,9 @@ int ff_mjpeg_decode_sos(MJpegDecodeContext *s,
&& nb_components == 3 && s->nb_components == 3 && i) && nb_components == 3 && s->nb_components == 3 && i)
index = 3 - i; index = 3 - i;
if(nb_components == 3 && s->nb_components == 3 && s->avctx->pix_fmt == PIX_FMT_GBR24P)
index = (i+2)%3;
s->comp_index[i] = index; s->comp_index[i] = index;
s->nb_blocks[i] = s->h_count[index] * s->v_count[index]; s->nb_blocks[i] = s->h_count[index] * s->v_count[index];
......
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