Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(47)

Unified Diff: gm/composeshader.cpp

Issue 263083011: change composeshader_alpha to exercise srcover as well (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gm/composeshader.cpp
diff --git a/gm/composeshader.cpp b/gm/composeshader.cpp
index b5607d511b9bcf92704ef1eb212a0f87990b2ead..9fdcb74369566e89e83bbe4ebd9f2d371004dcad 100644
--- a/gm/composeshader.cpp
+++ b/gm/composeshader.cpp
@@ -15,32 +15,33 @@
#include "SkString.h"
#include "SkXfermode.h"
+static SkShader* make_shader(SkXfermode::Mode mode) {
+ SkPoint pts[2];
+ SkColor colors[2];
+
+ pts[0].set(0, 0);
+ pts[1].set(SkIntToScalar(100), 0);
+ colors[0] = SK_ColorRED;
+ colors[1] = SK_ColorBLUE;
+ SkAutoTUnref<SkShader> shaderA(SkGradientShader::CreateLinear(pts, colors, NULL, 2,
+ SkShader::kClamp_TileMode));
+
+ pts[0].set(0, 0);
+ pts[1].set(0, SkIntToScalar(100));
+ colors[0] = SK_ColorBLACK;
+ colors[1] = SkColorSetARGB(0x80, 0, 0, 0);
+ SkAutoTUnref<SkShader> shaderB(SkGradientShader::CreateLinear(pts, colors, NULL, 2,
+ SkShader::kClamp_TileMode));
+
+ SkAutoTUnref<SkXfermode> xfer(SkXfermode::Create(mode));
+
+ return SkNEW_ARGS(SkComposeShader, (shaderA, shaderB, xfer));
+}
+
class ComposeShaderGM : public skiagm::GM {
public:
ComposeShaderGM() {
- SkPoint pts[2];
- SkColor colors[2];
-
- pts[0].set(0, 0);
- pts[1].set(SkIntToScalar(100), 0);
- colors[0] = SK_ColorRED;
- colors[1] = SK_ColorBLUE;
- SkShader* shaderA = SkGradientShader::CreateLinear(pts, colors, NULL, 2,
- SkShader::kClamp_TileMode);
-
- pts[0].set(0, 0);
- pts[1].set(0, SkIntToScalar(100));
- colors[0] = SK_ColorBLACK;
- colors[1] = SkColorSetARGB(0x80, 0, 0, 0);
- SkShader* shaderB = SkGradientShader::CreateLinear(pts, colors, NULL, 2,
- SkShader::kClamp_TileMode);
-
- SkXfermode* mode = SkXfermode::Create(SkXfermode::kDstIn_Mode);
-
- fShader = new SkComposeShader(shaderA, shaderB, mode);
- shaderA->unref();
- shaderB->unref();
- mode->unref();
+ fShader = make_shader(SkXfermode::kDstIn_Mode);
}
virtual ~ComposeShaderGM() {
@@ -77,7 +78,7 @@ private:
typedef GM INHERITED ;
};
-class ComposeShaderAlphaGM : public ComposeShaderGM {
+class ComposeShaderAlphaGM : public skiagm::GM {
public:
ComposeShaderAlphaGM() {}
@@ -87,24 +88,35 @@ protected:
}
virtual SkISize onISize() SK_OVERRIDE {
- return SkISize::Make(120, 1024);
+ return SkISize::Make(220, 750);
}
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
+ SkAutoTUnref<SkShader> shader0(make_shader(SkXfermode::kDstIn_Mode));
+ SkAutoTUnref<SkShader> shader1(make_shader(SkXfermode::kSrcOver_Mode));
+ SkShader* shaders[] = { shader0.get(), shader1.get() };
+
SkPaint paint;
paint.setColor(SK_ColorGREEN);
const SkRect r = SkRect::MakeXYWH(5, 5, 100, 100);
- for (int alpha = 0xFF; alpha > 0; alpha -= 0x20) {
- paint.setAlpha(0xFF);
- paint.setShader(NULL);
- canvas->drawRect(r, paint);
-
- paint.setAlpha(alpha);
- paint.setShader(fShader);
- canvas->drawRect(r, paint);
-
- canvas->translate(r.width() + 5, 0);
+
+ for (size_t y = 0; y < SK_ARRAY_COUNT(shaders); ++y) {
+ SkShader* shader = shaders[y];
+ canvas->save();
+ for (int alpha = 0xFF; alpha > 0; alpha -= 0x28) {
+ paint.setAlpha(0xFF);
+ paint.setShader(NULL);
+ canvas->drawRect(r, paint);
+
+ paint.setAlpha(alpha);
+ paint.setShader(shader);
+ canvas->drawRect(r, paint);
+
+ canvas->translate(r.width() + 5, 0);
+ }
+ canvas->restore();
+ canvas->translate(0, r.height() + 5);
}
}
};
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698