diff options
Diffstat (limited to 'src/effects/SkBlurImageFilter.cpp')
-rw-r--r-- | src/effects/SkBlurImageFilter.cpp | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/src/effects/SkBlurImageFilter.cpp b/src/effects/SkBlurImageFilter.cpp index ffebe54225..adcb28f90d 100644 --- a/src/effects/SkBlurImageFilter.cpp +++ b/src/effects/SkBlurImageFilter.cpp @@ -146,13 +146,15 @@ bool SkBlurImageFilter::onFilterImage(Proxy* proxy, return false; } - SkIRect srcBounds, dstBounds; - if (!this->applyCropRect(ctx, proxy, src, &srcOffset, &srcBounds, &src)) { + SkAutoLockPixels alp(src); + if (!src.getPixels()) { return false; } - SkAutoLockPixels alp(src); - if (!src.getPixels()) { + SkIRect srcBounds, dstBounds; + src.getBounds(&srcBounds); + srcBounds.offset(srcOffset); + if (!this->applyCropRect(&srcBounds, ctx.ctm())) { return false; } @@ -256,11 +258,13 @@ bool SkBlurImageFilter::filterImageGPU(Proxy* proxy, const SkBitmap& src, const if (getInput(0) && !getInput(0)->getInputResultGPU(proxy, src, ctx, &input, &srcOffset)) { return false; } + GrTexture* source = input.getTexture(); SkIRect rect; - if (!this->applyCropRect(ctx, proxy, input, &srcOffset, &rect, &input)) { + src.getBounds(&rect); + rect.offset(srcOffset); + if (!this->applyCropRect(&rect, ctx.ctm())) { return false; } - GrTexture* source = input.getTexture(); SkVector sigma, localSigma = SkVector::Make(fSigma.width(), fSigma.height()); ctx.ctm().mapVectors(&sigma, &localSigma, 1); offset->fX = rect.fLeft; |