summaryrefslogtreecommitdiff
path: root/amiga/bitmap.c
diff options
context:
space:
mode:
authorChris Young <chris@unsatisfactorysoftware.co.uk>2012-08-10 19:03:56 +0100
committerChris Young <chris@unsatisfactorysoftware.co.uk>2012-08-10 19:03:56 +0100
commitad1336ac45a993ce911036844a95807dbbda61f6 (patch)
treec1c20fbe36eb37118b90a36c4e2d4e90cc58c9b9 /amiga/bitmap.c
parent3ed1339b3fc0f701417bbf0a618ed3bc6997f9fa (diff)
downloadnetsurf-ad1336ac45a993ce911036844a95807dbbda61f6.tar.gz
netsurf-ad1336ac45a993ce911036844a95807dbbda61f6.tar.bz2
alignment attempt 2. this seems right, but doesn't work even for previously-working images
Diffstat (limited to 'amiga/bitmap.c')
-rw-r--r--amiga/bitmap.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/amiga/bitmap.c b/amiga/bitmap.c
index b601e48cb..95d2947d2 100644
--- a/amiga/bitmap.c
+++ b/amiga/bitmap.c
@@ -481,15 +481,17 @@ PLANEPTR ami_bitmap_get_mask(struct bitmap *bitmap, int width, int height)
{
uint32 *bmi = (uint32 *) bitmap->pixdata;
UBYTE maskbit = 0;
- int y, x;
+ int y, x, w;
if((height != bitmap->height) || (width != bitmap->width)) return NULL;
if(bitmap_get_opaque(bitmap) == true) return NULL;
if(bitmap->native_mask) return bitmap->native_mask;
bitmap->native_mask = AllocRaster(width, height);
- while((width % 8) != 0) width++;
-
+
+ w = width / 8;
+ if((width % 8) != 0) w++;
+
for(int i=0; i<(height * (width / 8)); i++) {
bitmap->native_mask[i] = 0;
}
@@ -499,8 +501,8 @@ PLANEPTR ami_bitmap_get_mask(struct bitmap *bitmap, int width, int height)
if ((*bmi & 0x000000ffU) <= (ULONG)nsoption_int(mask_alpha)) maskbit = 0;
else maskbit = 1;
bmi++;
- bitmap->native_mask[(y*(width/8)) + (x/8)] =
- (bitmap->native_mask[(y*(width/8)) + (x/8)] << 1) | maskbit;
+ bitmap->native_mask[(y*w) + (x/8)] =
+ (bitmap->native_mask[(y*w) + (x/8)] << 1) | maskbit;
}
}