Commit d9b3097b authored by Michael Niedermayer's avatar Michael Niedermayer

pamdec: fix mono support.

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 3fa6d205
...@@ -112,7 +112,7 @@ int ff_pnm_decode_header(AVCodecContext *avctx, PNMContext * const s) ...@@ -112,7 +112,7 @@ int ff_pnm_decode_header(AVCodecContext *avctx, PNMContext * const s)
s->maxval = maxval; s->maxval = maxval;
if (depth == 1) { if (depth == 1) {
if (maxval == 1) { if (maxval == 1) {
avctx->pix_fmt = PIX_FMT_MONOWHITE; avctx->pix_fmt = PIX_FMT_MONOBLACK;
} else if (maxval == 255) { } else if (maxval == 255) {
avctx->pix_fmt = PIX_FMT_GRAY8; avctx->pix_fmt = PIX_FMT_GRAY8;
} else { } else {
...@@ -148,7 +148,7 @@ int ff_pnm_decode_header(AVCodecContext *avctx, PNMContext * const s) ...@@ -148,7 +148,7 @@ int ff_pnm_decode_header(AVCodecContext *avctx, PNMContext * const s)
avctx->height = atoi(buf1); avctx->height = atoi(buf1);
if(avctx->height <= 0 || av_image_check_size(avctx->width, avctx->height, 0, avctx)) if(avctx->height <= 0 || av_image_check_size(avctx->width, avctx->height, 0, avctx))
return -1; return -1;
if (avctx->pix_fmt != PIX_FMT_MONOWHITE) { if (avctx->pix_fmt != PIX_FMT_MONOWHITE && avctx->pix_fmt != PIX_FMT_MONOBLACK) {
pnm_get(s, buf1, sizeof(buf1)); pnm_get(s, buf1, sizeof(buf1));
s->maxval = atoi(buf1); s->maxval = atoi(buf1);
if (s->maxval <= 0) { if (s->maxval <= 0) {
......
...@@ -108,20 +108,21 @@ static int pnm_decode_frame(AVCodecContext *avctx, void *data, ...@@ -108,20 +108,21 @@ static int pnm_decode_frame(AVCodecContext *avctx, void *data,
linesize = p->linesize[0]; linesize = p->linesize[0];
if (s->bytestream + n * avctx->height > s->bytestream_end) if (s->bytestream + n * avctx->height > s->bytestream_end)
return -1; return -1;
if(s->type < 4){ if(s->type < 4 || (is_mono && s->type==7)){
for (i=0; i<avctx->height; i++) { for (i=0; i<avctx->height; i++) {
PutBitContext pb; PutBitContext pb;
init_put_bits(&pb, ptr, linesize); init_put_bits(&pb, ptr, linesize);
for(j=0; j<avctx->width * components; j++){ for(j=0; j<avctx->width * components; j++){
unsigned int c=0; unsigned int c=0;
int v=0; int v=0;
if(s->type < 4)
while(s->bytestream < s->bytestream_end && (*s->bytestream < '0' || *s->bytestream > '9' )) while(s->bytestream < s->bytestream_end && (*s->bytestream < '0' || *s->bytestream > '9' ))
s->bytestream++; s->bytestream++;
if(s->bytestream >= s->bytestream_end) if(s->bytestream >= s->bytestream_end)
return -1; return -1;
if (is_mono) { if (is_mono) {
/* read a single digit */ /* read a single digit */
v = (*s->bytestream++) - '0'; v = (*s->bytestream++)&1;
} else { } else {
/* read a sequence of digits */ /* read a sequence of digits */
do { do {
...@@ -260,7 +261,7 @@ AVCodec ff_pam_decoder = { ...@@ -260,7 +261,7 @@ AVCodec ff_pam_decoder = {
.close = ff_pnm_end, .close = ff_pnm_end,
.decode = pnm_decode_frame, .decode = pnm_decode_frame,
.capabilities = CODEC_CAP_DR1, .capabilities = CODEC_CAP_DR1,
.pix_fmts = (const enum PixelFormat[]){PIX_FMT_RGB24, PIX_FMT_RGB32, PIX_FMT_GRAY8, PIX_FMT_MONOWHITE, PIX_FMT_NONE}, .pix_fmts = (const enum PixelFormat[]){PIX_FMT_RGB24, PIX_FMT_RGB32, PIX_FMT_GRAY8, PIX_FMT_MONOBLACK, PIX_FMT_NONE},
.long_name = NULL_IF_CONFIG_SMALL("PAM (Portable AnyMap) image"), .long_name = NULL_IF_CONFIG_SMALL("PAM (Portable AnyMap) image"),
}; };
#endif #endif
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