diff options
author | Peter Ross <pross@xvid.org> | 2012-11-10 10:31:14 +1100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2012-11-10 02:02:35 +0100 |
commit | 8b67ec77f04841f7c589a152b5f492befc538828 (patch) | |
tree | 9ba0376e5a3ee0fd3b994cbaf0ae2c0fa3ce6b51 /libavcodec/pictordec.c | |
parent | 49c2f2d57e11510fe1a22769d45363dee02af98f (diff) | |
download | ffmpeg-8b67ec77f04841f7c589a152b5f492befc538828.tar.gz |
pictordec: fill any unset portion of the image
Fixes ticket #1710
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/pictordec.c')
-rw-r--r-- | libavcodec/pictordec.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/libavcodec/pictordec.c b/libavcodec/pictordec.c index 5c872c955e..748d9b3bcb 100644 --- a/libavcodec/pictordec.c +++ b/libavcodec/pictordec.c @@ -111,7 +111,7 @@ static int decode_frame(AVCodecContext *avctx, PicContext *s = avctx->priv_data; uint32_t *palette; int bits_per_plane, bpp, etype, esize, npal, pos_after_pal; - int i, x, y, plane, tmp; + int i, x, y, plane, tmp, val; bytestream2_init(&s->g, avpkt->data, avpkt->size); @@ -206,6 +206,7 @@ static int decode_frame(AVCodecContext *avctx, // skip remaining palette bytes bytestream2_seek(&s->g, pos_after_pal, SEEK_SET); + val = 0; y = s->height - 1; if (bytestream2_get_le16(&s->g)) { x = 0; @@ -223,7 +224,7 @@ static int decode_frame(AVCodecContext *avctx, while (plane < s->nb_planes && y >= 0 && bytestream2_get_bytes_left(&s->g) > stop_size) { int run = 1; - int val = bytestream2_get_byte(&s->g); + val = bytestream2_get_byte(&s->g); if (val == marker) { run = bytestream2_get_byte(&s->g); if (run == 0) @@ -240,6 +241,14 @@ static int decode_frame(AVCodecContext *avctx, } } } + + if (x < avctx->width && y >= 0) { + int run = (y + 1) * avctx->width - x; + if (bits_per_plane == 8) + picmemset_8bpp(s, val, run, &x, &y); + else + picmemset(s, val, run / (8 / bits_per_plane), &x, &y, &plane, bits_per_plane); + } } else { while (y >= 0 && bytestream2_get_bytes_left(&s->g) > 0) { memcpy(s->frame.data[0] + y * s->frame.linesize[0], s->g.buffer, FFMIN(avctx->width, bytestream2_get_bytes_left(&s->g))); |