From 6de09834cfa376d3ecd70fe55f729c0c52696b37 Mon Sep 17 00:00:00 2001 From: Alexander Parshin Date: Sat, 25 Apr 2015 10:02:44 +0300 Subject: [PATCH 1/2] Optimize getImageData() Mostly for fully transparent pixels --- src/PixelArray.cc | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/PixelArray.cc b/src/PixelArray.cc index 0a773cc..4838eee 100644 --- a/src/PixelArray.cc +++ b/src/PixelArray.cc @@ -114,10 +114,16 @@ PixelArray::PixelArray(Canvas *canvas, int sx, int sy, int width, int height): uint8_t g = *pixel >> 8; uint8_t b = *pixel; dst[bx + 3] = a; - float alpha = (float) a / 255; - dst[bx + 0] = (int)((float) r / alpha); - dst[bx + 1] = (int)((float) g / alpha); - dst[bx + 2] = (int)((float) b / alpha); + if (a != 0 && a != 255) { + float alpha = (float) a / 255; + dst[bx + 0] = (int)((float) r / alpha); + dst[bx + 1] = (int)((float) g / alpha); + dst[bx + 2] = (int)((float) b / alpha); + } else { + dst[bx + 0] = r; + dst[bx + 1] = g; + dst[bx + 2] = b; + } } dst += dstStride; } From dc8db1695dbbfa0febd726f71a8c46ca152917c4 Mon Sep 17 00:00:00 2001 From: Alexander Parshin Date: Sun, 26 Apr 2015 16:13:32 +0300 Subject: [PATCH 2/2] Add comment about optimization --- src/PixelArray.cc | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) diff --git a/src/PixelArray.cc b/src/PixelArray.cc index 4838eee..f39b337 100644 --- a/src/PixelArray.cc +++ b/src/PixelArray.cc @@ -114,15 +114,18 @@ PixelArray::PixelArray(Canvas *canvas, int sx, int sy, int width, int height): uint8_t g = *pixel >> 8; uint8_t b = *pixel; dst[bx + 3] = a; + + // Performance optimization: fully transparent/opaque pixels + // can be processed more efficiently if (a != 0 && a != 255) { - float alpha = (float) a / 255; - dst[bx + 0] = (int)((float) r / alpha); - dst[bx + 1] = (int)((float) g / alpha); - dst[bx + 2] = (int)((float) b / alpha); + float alpha = (float) a / 255; + dst[bx + 0] = (int)((float) r / alpha); + dst[bx + 1] = (int)((float) g / alpha); + dst[bx + 2] = (int)((float) b / alpha); } else { - dst[bx + 0] = r; - dst[bx + 1] = g; - dst[bx + 2] = b; + dst[bx + 0] = r; + dst[bx + 1] = g; + dst[bx + 2] = b; } } dst += dstStride;