aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/gpu/GrLayerCache.h5
-rw-r--r--src/gpu/GrLayerHoister.cpp21
-rw-r--r--src/gpu/GrRecordReplaceDraw.cpp6
3 files changed, 26 insertions, 6 deletions
diff --git a/src/gpu/GrLayerCache.h b/src/gpu/GrLayerCache.h
index cdbd0806cc..df8c670689 100644
--- a/src/gpu/GrLayerCache.h
+++ b/src/gpu/GrLayerCache.h
@@ -164,7 +164,7 @@ public:
SkASSERT(SK_InvalidGenID != pictureID);
if (fPaint) {
- if (fPaint->getImageFilter() && fPaint->getImageFilter()->canFilterImageGPU()) {
+ if (fPaint->getImageFilter()) {
fFilter = SkSafeRef(fPaint->getImageFilter());
fPaint->setImageFilter(NULL);
}
@@ -190,6 +190,9 @@ public:
void setTexture(GrTexture* texture, const SkIRect& rect) {
SkRefCnt_SafeAssign(fTexture, texture);
fRect = rect;
+ if (!fTexture) {
+ fLocked = false;
+ }
}
GrTexture* texture() { return fTexture; }
const SkPaint* paint() const { return fPaint; }
diff --git a/src/gpu/GrLayerHoister.cpp b/src/gpu/GrLayerHoister.cpp
index 7d6f5ab1b3..70c10d7f69 100644
--- a/src/gpu/GrLayerHoister.cpp
+++ b/src/gpu/GrLayerHoister.cpp
@@ -10,6 +10,8 @@
#include "GrRecordReplaceDraw.h"
#include "SkCanvas.h"
+#include "SkDeviceImageFilterProxy.h"
+#include "SkDeviceProperties.h"
#include "SkGpuDevice.h"
#include "SkGrPixelRef.h"
#include "SkLayerInfo.h"
@@ -274,13 +276,21 @@ void GrLayerHoister::DrawLayersToAtlas(GrContext* context,
}
}
+SkBitmap wrap_texture(GrTexture* texture) {
+ SkASSERT(texture);
+
+ SkBitmap result;
+ result.setInfo(texture->surfacePriv().info());
+ result.setPixelRef(SkNEW_ARGS(SkGrPixelRef, (result.info(), texture)))->unref();
+ return result;
+}
+
void GrLayerHoister::FilterLayer(GrContext* context,
SkGpuDevice* device,
const GrHoistedLayer& info) {
GrCachedLayer* layer = info.fLayer;
SkASSERT(layer->filter());
- SkASSERT(layer->filter()->canFilterImageGPU());
static const int kDefaultCacheSize = 32 * 1024 * 1024;
@@ -294,7 +304,6 @@ void GrLayerHoister::FilterLayer(GrContext* context,
totMat.preConcat(info.fLocalMat);
totMat.postTranslate(-SkIntToScalar(filterOffset.fX), -SkIntToScalar(filterOffset.fY));
-
SkASSERT(0 == layer->rect().fLeft && 0 == layer->rect().fTop);
SkIRect clipBounds = layer->rect();
@@ -303,9 +312,11 @@ void GrLayerHoister::FilterLayer(GrContext* context,
SkAutoTUnref<SkImageFilter::Cache> cache(SkImageFilter::Cache::Create(kDefaultCacheSize));
SkImageFilter::Context filterContext(totMat, clipBounds, cache);
- if (!device->filterTexture(context, layer->texture(), layer->filter(),
- filterContext, &filteredBitmap, &offset)) {
- // Filtering failed. Press on with the unfiltered version
+ SkDeviceImageFilterProxy proxy(device, SkSurfaceProps(0, kUnknown_SkPixelGeometry));
+ const SkBitmap src = wrap_texture(layer->texture());
+
+ if (!layer->filter()->filterImage(&proxy, src, filterContext, &filteredBitmap, &offset)) {
+ // Filtering failed. Press on with the unfiltered version.
return;
}
diff --git a/src/gpu/GrRecordReplaceDraw.cpp b/src/gpu/GrRecordReplaceDraw.cpp
index 234f92f24f..dacc939e62 100644
--- a/src/gpu/GrRecordReplaceDraw.cpp
+++ b/src/gpu/GrRecordReplaceDraw.cpp
@@ -22,6 +22,12 @@ static inline void wrap_texture(GrTexture* texture, int width, int height, SkBit
static inline void draw_replacement_bitmap(GrCachedLayer* layer, SkCanvas* canvas) {
+ // Some image filter can totally filter away a layer (e.g., SkPictureImageFilter's with
+ // no picture).
+ if (!layer->texture()) {
+ return;
+ }
+
SkBitmap bm;
wrap_texture(layer->texture(),
!layer->isAtlased() ? layer->rect().width() : layer->texture()->width(),