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

Side by Side Diff: gm/colortypexfermode.cpp

Issue 2396953002: Revert[8] "replace SkXfermode obj with SkBlendMode enum in paints" (Closed)
Patch Set: add tmp virtual to unroll legacy arithmodes Created 4 years, 2 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 unified diff | Download patch
« no previous file with comments | « gm/colormatrix.cpp ('k') | gm/drawatlas.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2014 Google Inc. 2 * Copyright 2014 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 #include "gm.h" 7 #include "gm.h"
8 #include "SkBitmap.h" 8 #include "SkBitmap.h"
9 #include "SkGradientShader.h" 9 #include "SkGradientShader.h"
10 #include "SkShader.h" 10 #include "SkShader.h"
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
50 } 50 }
51 51
52 virtual SkISize onISize() override { 52 virtual SkISize onISize() override {
53 return SkISize::Make(400, 640); 53 return SkISize::Make(400, 640);
54 } 54 }
55 55
56 virtual void onDraw(SkCanvas* canvas) override { 56 virtual void onDraw(SkCanvas* canvas) override {
57 canvas->translate(SkIntToScalar(10), SkIntToScalar(20)); 57 canvas->translate(SkIntToScalar(10), SkIntToScalar(20));
58 58
59 const struct { 59 const struct {
60 SkXfermode::Mode fMode; 60 SkBlendMode fMode;
61 const char* fLabel; 61 const char* fLabel;
62 } gModes[] = { 62 } gModes[] = {
63 { SkXfermode::kClear_Mode, "Clear" }, 63 { SkBlendMode::kClear, "Clear" },
64 { SkXfermode::kSrc_Mode, "Src" }, 64 { SkBlendMode::kSrc, "Src" },
65 { SkXfermode::kDst_Mode, "Dst" }, 65 { SkBlendMode::kDst, "Dst" },
66 { SkXfermode::kSrcOver_Mode, "SrcOver" }, 66 { SkBlendMode::kSrcOver, "SrcOver" },
67 { SkXfermode::kDstOver_Mode, "DstOver" }, 67 { SkBlendMode::kDstOver, "DstOver" },
68 { SkXfermode::kSrcIn_Mode, "SrcIn" }, 68 { SkBlendMode::kSrcIn, "SrcIn" },
69 { SkXfermode::kDstIn_Mode, "DstIn" }, 69 { SkBlendMode::kDstIn, "DstIn" },
70 { SkXfermode::kSrcOut_Mode, "SrcOut" }, 70 { SkBlendMode::kSrcOut, "SrcOut" },
71 { SkXfermode::kDstOut_Mode, "DstOut" }, 71 { SkBlendMode::kDstOut, "DstOut" },
72 { SkXfermode::kSrcATop_Mode, "SrcATop" }, 72 { SkBlendMode::kSrcATop, "SrcATop" },
73 { SkXfermode::kDstATop_Mode, "DstATop" }, 73 { SkBlendMode::kDstATop, "DstATop" },
74 74
75 { SkXfermode::kXor_Mode, "Xor" }, 75 { SkBlendMode::kXor, "Xor" },
76 { SkXfermode::kPlus_Mode, "Plus" }, 76 { SkBlendMode::kPlus, "Plus" },
77 { SkXfermode::kModulate_Mode, "Modulate" }, 77 { SkBlendMode::kModulate, "Modulate" },
78 { SkXfermode::kScreen_Mode, "Screen" }, 78 { SkBlendMode::kScreen, "Screen" },
79 { SkXfermode::kOverlay_Mode, "Overlay" }, 79 { SkBlendMode::kOverlay, "Overlay" },
80 { SkXfermode::kDarken_Mode, "Darken" }, 80 { SkBlendMode::kDarken, "Darken" },
81 { SkXfermode::kLighten_Mode, "Lighten" }, 81 { SkBlendMode::kLighten, "Lighten" },
82 { SkXfermode::kColorDodge_Mode, "ColorDodge" }, 82 { SkBlendMode::kColorDodge, "ColorDodge" },
83 { SkXfermode::kColorBurn_Mode, "ColorBurn" }, 83 { SkBlendMode::kColorBurn, "ColorBurn" },
84 { SkXfermode::kHardLight_Mode, "HardLight" }, 84 { SkBlendMode::kHardLight, "HardLight" },
85 { SkXfermode::kSoftLight_Mode, "SoftLight" }, 85 { SkBlendMode::kSoftLight, "SoftLight" },
86 { SkXfermode::kDifference_Mode, "Difference" }, 86 { SkBlendMode::kDifference, "Difference" },
87 { SkXfermode::kExclusion_Mode, "Exclusion" }, 87 { SkBlendMode::kExclusion, "Exclusion" },
88 { SkXfermode::kMultiply_Mode, "Multiply" }, 88 { SkBlendMode::kMultiply, "Multiply" },
89 { SkXfermode::kHue_Mode, "Hue" }, 89 { SkBlendMode::kHue, "Hue" },
90 { SkXfermode::kSaturation_Mode, "Saturation" }, 90 { SkBlendMode::kSaturation, "Saturation" },
91 { SkXfermode::kColor_Mode, "Color" }, 91 { SkBlendMode::kColor, "Color" },
92 { SkXfermode::kLuminosity_Mode, "Luminosity" }, 92 { SkBlendMode::kLuminosity, "Luminosity" },
93 }; 93 };
94 94
95 const SkScalar w = SkIntToScalar(W); 95 const SkScalar w = SkIntToScalar(W);
96 const SkScalar h = SkIntToScalar(H); 96 const SkScalar h = SkIntToScalar(H);
97 SkMatrix m; 97 SkMatrix m;
98 m.setScale(SkIntToScalar(6), SkIntToScalar(6)); 98 m.setScale(SkIntToScalar(6), SkIntToScalar(6));
99 auto s = SkShader::MakeBitmapShader(fBG, SkShader::kRepeat_TileMode, 99 auto s = SkShader::MakeBitmapShader(fBG, SkShader::kRepeat_TileMode,
100 SkShader::kRepeat_TileMode, &m); 100 SkShader::kRepeat_TileMode, &m);
101 101
102 SkPaint labelP; 102 SkPaint labelP;
(...skipping 18 matching lines...) Expand all
121 SkPaint p; 121 SkPaint p;
122 p.setStyle(SkPaint::kFill_Style); 122 p.setStyle(SkPaint::kFill_Style);
123 p.setShader(s); 123 p.setShader(s);
124 canvas->drawRect(r, p); 124 canvas->drawRect(r, p);
125 125
126 r.inset(-SK_ScalarHalf, -SK_ScalarHalf); 126 r.inset(-SK_ScalarHalf, -SK_ScalarHalf);
127 p.setStyle(SkPaint::kStroke_Style); 127 p.setStyle(SkPaint::kStroke_Style);
128 p.setShader(nullptr); 128 p.setShader(nullptr);
129 canvas->drawRect(r, p); 129 canvas->drawRect(r, p);
130 130
131 textP.setXfermode(SkXfermode::Make(gModes[i].fMode)); 131 textP.setBlendMode(gModes[i].fMode);
132 canvas->drawText("H", 1, x+ w/10.f, y + 7.f*h/8.f, textP); 132 canvas->drawText("H", 1, x+ w/10.f, y + 7.f*h/8.f, textP);
133 #if 1 133 #if 1
134 canvas->drawText(gModes[i].fLabel, strlen(gModes[i].fLabel), 134 canvas->drawText(gModes[i].fLabel, strlen(gModes[i].fLabel),
135 x + w/2, y - labelP.getTextSize()/2, labelP); 135 x + w/2, y - labelP.getTextSize()/2, labelP);
136 #endif 136 #endif
137 x += w + SkIntToScalar(10); 137 x += w + SkIntToScalar(10);
138 if ((i % W) == W - 1) { 138 if ((i % W) == W - 1) {
139 x = x0; 139 x = x0;
140 y += h + SkIntToScalar(30); 140 y += h + SkIntToScalar(30);
141 } 141 }
142 } 142 }
143 } 143 }
144 144
145 private: 145 private:
146 SkBitmap fBG; 146 SkBitmap fBG;
147 sk_sp<SkTypeface> fColorType; 147 sk_sp<SkTypeface> fColorType;
148 148
149 typedef GM INHERITED; 149 typedef GM INHERITED;
150 }; 150 };
151 151
152 ////////////////////////////////////////////////////////////////////////////// 152 //////////////////////////////////////////////////////////////////////////////
153 153
154 static GM* MyFactory(void*) { return new ColorTypeXfermodeGM; } 154 static GM* MyFactory(void*) { return new ColorTypeXfermodeGM; }
155 static GMRegistry reg(MyFactory); 155 static GMRegistry reg(MyFactory);
156 156
157 } 157 }
OLDNEW
« no previous file with comments | « gm/colormatrix.cpp ('k') | gm/drawatlas.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698