diff options
author | reed <reed@google.com> | 2016-02-08 12:56:56 -0800 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-02-08 12:56:57 -0800 |
commit | 3125565804054691b110b4731bc5a32070fab780 (patch) | |
tree | 9025e54e4d523d4cd2c87363ebc841f0f5a2b871 /gm/color4f.cpp | |
parent | 21eaf3b00aa23ec352b595d5c54dd2c0faa0b0c6 (diff) |
extend modecolorfilter to 4f
BUG=skia:
GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1670063002
Review URL: https://codereview.chromium.org/1670063002
Diffstat (limited to 'gm/color4f.cpp')
-rw-r--r-- | gm/color4f.cpp | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/gm/color4f.cpp b/gm/color4f.cpp index e912654bc9..9e6fcf6060 100644 --- a/gm/color4f.cpp +++ b/gm/color4f.cpp @@ -45,10 +45,14 @@ static SkColorFilter* make_cf1() { return SkColorFilter::CreateComposeFilter(a, b); } +static SkColorFilter* make_cf2() { + return SkColorFilter::CreateModeFilter(0x8044CC88, SkXfermode::kSrcATop_Mode); +} + static void draw_into_canvas(SkCanvas* canvas) { - const SkRect r = SkRect::MakeWH(100, 100); + const SkRect r = SkRect::MakeWH(50, 100); SkShader* (*shaders[])() { make_opaque_color, make_alpha_color }; - SkColorFilter* (*filters[])() { make_cf_null, make_cf0, make_cf1 }; + SkColorFilter* (*filters[])() { make_cf_null, make_cf0, make_cf1, make_cf2 }; SkPaint paint; for (auto shProc : shaders) { @@ -56,13 +60,13 @@ static void draw_into_canvas(SkCanvas* canvas) { for (auto cfProc : filters) { SkSafeUnref(paint.setColorFilter(cfProc())); canvas->drawRect(r, paint); - canvas->translate(120, 0); + canvas->translate(60, 0); } } } -DEF_SIMPLE_GM(color4f, canvas, 620, 260) { - canvas->translate(20, 20); +DEF_SIMPLE_GM(color4f, canvas, 1024, 260) { + canvas->translate(10, 10); SkPaint bg; // need the target to be opaque, so we can draw it to the screen @@ -71,7 +75,7 @@ DEF_SIMPLE_GM(color4f, canvas, 620, 260) { SkColorProfileType const profiles[] { kLinear_SkColorProfileType, kSRGB_SkColorProfileType }; for (auto profile : profiles) { - const SkImageInfo info = SkImageInfo::Make(600, 100, kN32_SkColorType, kPremul_SkAlphaType, + const SkImageInfo info = SkImageInfo::Make(1024, 100, kN32_SkColorType, kPremul_SkAlphaType, profile); SkAutoTUnref<SkSurface> surface(SkSurface::NewRaster(info)); surface->getCanvas()->drawPaint(bg); |