From d369f10aa56deafbc1816037d5a30af2f9bdbc50 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bert=20M=C3=BCnnich?= Date: Wed, 28 Sep 2011 12:53:44 +0200 Subject: Fix layering of small gif frames --- image.c | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) (limited to 'image.c') diff --git a/image.c b/image.c index 9896a54..77a89b0 100644 --- a/image.c +++ b/image.c @@ -173,6 +173,9 @@ bool img_load_gif(img_t *img, const fileinfo_t *file) { delay = 10 * ((unsigned int) ext[3] << 8 | (unsigned int) ext[2]); if (delay) delay = MAX(delay, MIN_GIF_DELAY); + + /* TODO: handle disposal method, section 23.c.iv of + http://www.w3.org/Graphics/GIF/spec-gif89a.txt */ } ext = NULL; DGifGetExtensionNext(gif, &ext); @@ -209,12 +212,9 @@ bool img_load_gif(img_t *img, const fileinfo_t *file) { for (i = 0; i < sh; i++) { for (j = 0; j < sw; j++) { - if (i < y || i >= y + h || j < x || j >= x + w) { - if (transp >= 0 && prev_frame) - *ptr = prev_frame[i * sw + j]; - else - *ptr = bgpixel; - } else if (rows[i-y][j-x] == transp) { + if (i < y || i >= y + h || j < x || j >= x + w || + rows[i-y][j-x] == transp) + { if (prev_frame) *ptr = prev_frame[i * sw + j]; else -- cgit v1.2.3