| Index: gm/texdata.cpp
|
| diff --git a/gm/texdata.cpp b/gm/texdata.cpp
|
| index c89ce734f7584e3d12d015310d66768f53b26855..d6ab1f12f7f7eb95b5bc0e0daef68f36870dbd74 100644
|
| --- a/gm/texdata.cpp
|
| +++ b/gm/texdata.cpp
|
| @@ -22,6 +22,10 @@ static const int S = 200;
|
| DEF_SIMPLE_GM_BG(texdata, canvas, 2 * S, 2 * S, SK_ColorBLACK) {
|
| GrRenderTarget* target = canvas->internal_private_accessTopLayerRenderTarget();
|
| GrContext* ctx = canvas->getGrContext();
|
| + if (!ctx) {
|
| + skiagm::GM::DrawGpuOnlyMessage(canvas);
|
| + return;
|
| + }
|
| SkAutoTUnref<GrDrawContext> drawContext(ctx ? ctx->drawContext(target) : nullptr);
|
| if (drawContext && target) {
|
| SkAutoTArray<SkPMColor> gTextureData((2 * S) * (2 * S));
|
| @@ -77,6 +81,19 @@ DEF_SIMPLE_GM_BG(texdata, canvas, 2 * S, 2 * S, SK_ColorBLACK) {
|
| }
|
| SkAutoTUnref<GrTexture> au(texture);
|
|
|
| + SkASSERT(texture->fromRawPixels2());
|
| +
|
| + SkAutoTUnref<GrDrawContext> dc9;
|
| + if (i) {
|
| + texture->setFromRawPixels(false);
|
| + dc9.reset(ctx->drawContext(texture->asRenderTarget()));
|
| + if (!dc9) {
|
| + return;
|
| + }
|
| + } else {
|
| + texture->setException(true);
|
| + }
|
| +
|
| // setup new clip
|
| GrClip clip(SkRect::MakeWH(2*S, 2*S));
|
|
|
| @@ -94,10 +111,19 @@ DEF_SIMPLE_GM_BG(texdata, canvas, 2 * S, 2 * S, SK_ColorBLACK) {
|
| SkMatrix tm;
|
| tm = vm;
|
| tm.postIDiv(2*S, 2*S);
|
| - paint.addColorTextureProcessor(texture, tm);
|
| + paint.addColorTextureProcessor(texture, tm, target);
|
|
|
| drawContext->drawRect(clip, paint, vm, SkRect::MakeWH(2*S, 2*S));
|
|
|
| +#if 0
|
| + // Here we've used dc9/texture as a src for a drawRect. This "closed"
|
| + // the DT. We need to reopen it here so we can use dc9/texture for
|
| + // the writePixels
|
| + if (dc9) {
|
| + dc9 = ctx->drawContext(texture->asRenderTarget());
|
| + }
|
| +#endif
|
| +
|
| // now update the lower right of the texture in first pass
|
| // or upper right in second pass
|
| offset = 0;
|
| @@ -107,13 +133,11 @@ DEF_SIMPLE_GM_BG(texdata, canvas, 2 * S, 2 * S, SK_ColorBLACK) {
|
| ((x + y) % 2) ? (i ? green : red) : blue;
|
| }
|
| }
|
| - texture->writePixels(S, (i ? 0 : S), S, S,
|
| + texture->writePixels(dc9, S, (i ? 0 : S), S, S,
|
| texture->config(), gTextureData.get(),
|
| 4 * stride);
|
| drawContext->drawRect(clip, paint, vm, SkRect::MakeWH(2*S, 2*S));
|
| }
|
| - } else {
|
| - skiagm::GM::DrawGpuOnlyMessage(canvas);
|
| }
|
| }
|
| #endif
|
|
|