Index: src/core/SkBitmapFilter.cpp |
diff --git a/src/core/SkBitmapFilter.cpp b/src/core/SkBitmapFilter.cpp |
index a9c3223fbc731531c88263a189412ea11425a85b..20a05142506c1890e2c4eea964299def656da068 100644 |
--- a/src/core/SkBitmapFilter.cpp |
+++ b/src/core/SkBitmapFilter.cpp |
@@ -28,6 +28,7 @@ template <typename Color, typename ColorPacker> |
void highQualityFilter(ColorPacker pack, const SkBitmapProcState& s, int x, int y, Color* SK_RESTRICT colors, int count) { |
const int maxX = s.fBitmap->width(); |
const int maxY = s.fBitmap->height(); |
+ SkAutoTMalloc<SkScalar> xWeights(maxX); |
while (count-- > 0) { |
SkPoint srcPt; |
@@ -44,11 +45,16 @@ void highQualityFilter(ColorPacker pack, const SkBitmapProcState& s, int x, int |
int x0 = SkClampMax(SkScalarCeilToInt(srcPt.fX-s.getBitmapFilter()->width()), maxX); |
int x1 = SkClampMax(SkScalarFloorToInt(srcPt.fX+s.getBitmapFilter()->width())+1, maxX); |
+ for (int srcX = x0; srcX < x1 ; srcX++) { |
+ // Looking these up once instead of each loop is a ~15% speedup. |
+ xWeights[srcX - x0] = s.getBitmapFilter()->lookupScalar((srcPt.fX - srcX)); |
+ } |
+ |
for (int srcY = y0; srcY < y1; srcY++) { |
SkScalar yWeight = s.getBitmapFilter()->lookupScalar((srcPt.fY - srcY)); |
for (int srcX = x0; srcX < x1 ; srcX++) { |
- SkScalar xWeight = s.getBitmapFilter()->lookupScalar((srcPt.fX - srcX)); |
+ SkScalar xWeight = xWeights[srcX - x0]; |
SkScalar combined_weight = SkScalarMul(xWeight, yWeight); |