X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=render%2Fimage.c;h=964864371825bb93c081de801d787d81d44a2a21;hb=c564b6245fcfaf0efd523cfa17bc1a73fe640d68;hp=c7452fceeb263aee3abff0b4d038008869dedd9d;hpb=66a897d9b24682e9d243e4d452800b8a5c1237f6;p=chaz%2Fopenbox diff --git a/render/image.c b/render/image.c index c7452fce..96486437 100644 --- a/render/image.c +++ b/render/image.c @@ -75,7 +75,7 @@ static void AddPicture(RrImage *self, RrImagePic ***list, gint *len, #ifdef DEBUG g_message("Adding %s picture to the cache:\n " - "Image 0x%x, w %d h %d Hash %u\n", + "Image 0x%x, w %d h %d Hash %u", (*list == self->original ? "ORIGINAL" : "RESIZED"), (guint)self, pic->width, pic->height, RrImagePicHash(pic)); #endif @@ -90,7 +90,7 @@ static void RemovePicture(RrImage *self, RrImagePic ***list, #ifdef DEBUG g_message("Removing %s picture from the cache:\n " - "Image 0x%x, w %d h %d Hash %u\n", + "Image 0x%x, w %d h %d Hash %u", (*list == self->original ? "ORIGINAL" : "RESIZED"), (guint)self, (*list)[i]->width, (*list)[i]->height, RrImagePicHash((*list)[i])); @@ -124,6 +124,12 @@ static RrImagePic* ResizeImage(RrPixel32 *src, gulong ratioX, ratioY; gulong aspectW, aspectH; + /* XXX should these variables be ensured to not be zero in the callers? */ + srcW = srcW ? srcW : 1; + srcH = srcH ? srcH : 1; + dstW = dstW ? dstW : 1; + dstH = dstH ? dstH : 1; + /* keep the aspect ratio */ aspectW = dstW; aspectH = (gint)(dstW * ((gdouble)srcH / srcW)); @@ -131,11 +137,11 @@ static RrImagePic* ResizeImage(RrPixel32 *src, aspectH = dstH; aspectW = (gint)(dstH * ((gdouble)srcW / srcH)); } - dstW = aspectW; - dstH = aspectH; + dstW = aspectW ? aspectW : 1; + dstH = aspectH ? aspectH : 1; if (srcW == dstW && srcH == dstH) - return NULL; /* no scaling needed ! */ + return NULL; /* no scaling needed! */ dststart = dst = g_new(RrPixel32, dstW * dstH); @@ -294,6 +300,7 @@ void RrImageDrawRGBA(RrPixel32 *target, RrTextureRGBA *rgba, DrawRGBA(target, target_w, target_h, scaled->data, scaled->width, scaled->height, rgba->alpha, area); + RrImagePicFree(scaled); } else DrawRGBA(target, target_w, target_h, @@ -324,7 +331,7 @@ void RrImageUnref(RrImage *self) if (self && --self->ref == 0) { #ifdef DEBUG g_message("Refcount to 0, removing ALL pictures from the cache:\n " - "Image 0x%x\n", (guint)self); + "Image 0x%x", (guint)self); #endif while (self->n_original > 0) RemovePicture(self, &self->original, 0, &self->n_original); @@ -347,7 +354,7 @@ void RrImageAddPicture(RrImage *self, RrPixel32 *data, gint w, gint h) if (self->original[i]->width == w && self->original[i]->height == h) { #ifdef DEBUG g_message("Found duplicate ORIGINAL image:\n " - "Image 0x%x, w %d h %d\n", (guint)self, w, h); + "Image 0x%x, w %d h %d", (guint)self, w, h); #endif return; }