Index: src/image/SkImage_Gpu.cpp |
diff --git a/src/image/SkImage_Gpu.cpp b/src/image/SkImage_Gpu.cpp |
index 1a63a0d6ba3cf51af625d616d77cb27de4c459fb..4417c7bc939bdb3c143fec0dd70f4c1c86a1b788 100644 |
--- a/src/image/SkImage_Gpu.cpp |
+++ b/src/image/SkImage_Gpu.cpp |
@@ -7,6 +7,7 @@ |
#include "SkBitmapCache.h" |
#include "SkImage_Gpu.h" |
+#include "GrCaps.h" |
#include "GrContext.h" |
#include "GrDrawContext.h" |
#include "effects/GrYUVtoRGBEffect.h" |
@@ -35,13 +36,6 @@ extern void SkTextureImageApplyBudgetedDecision(SkImage* image) { |
} |
} |
-SkShader* SkImage_Gpu::onNewShader(SkShader::TileMode tileX, SkShader::TileMode tileY, |
- const SkMatrix* localMatrix) const { |
- SkBitmap bm; |
- GrWrapTextureInBitmap(fTexture, this->width(), this->height(), this->isOpaque(), &bm); |
- return SkShader::CreateBitmapShader(bm, tileX, tileY, localMatrix); |
-} |
- |
bool SkImage_Gpu::getROPixels(SkBitmap* dst) const { |
if (SkBitmapCache::Find(this->uniqueID(), dst)) { |
SkASSERT(dst->getGenerationID() == this->uniqueID()); |
@@ -66,6 +60,19 @@ bool SkImage_Gpu::getROPixels(SkBitmap* dst) const { |
} |
GrTexture* SkImage_Gpu::asTextureRef(GrContext* ctx, SkImageUsageType usage) const { |
+ const bool is_pow2 = SkIsPow2(this->width()) && SkIsPow2(this->height()); |
+ const bool npot_tex_supported = ctx->caps()->npotTextureTileSupport(); |
+ if (!is_pow2 && kUntiled_SkImageUsageType != usage && !npot_tex_supported) { |
+ // load as bitmap, since the GPU can support tiling a non-pow2 texture |
+ // related to skbug.com/4365 |
+ SkBitmap bitmap; |
+ if (this->getROPixels(&bitmap)) { |
+ return GrRefCachedBitmapTexture(ctx, bitmap, usage); |
+ } else { |
+ return nullptr; |
+ } |
+ } |
+ |
fTexture->ref(); |
return fTexture; |
} |