• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright 2013 Google Inc.
3  *
4  * Use of this source code is governed by a BSD-style license that can be
5  * found in the LICENSE file.
6  */
7 
8 #include "gm.h"
9 #include "SkBlurDrawLooper.h"
10 #include "SkBlurMask.h"
11 #include "SkBlurMaskFilter.h"
12 #include "SkGradientShader.h"
13 #include "SkMatrix.h"
14 #include "SkTArray.h"
15 
16 namespace skiagm {
17 
18 class RectsGM : public GM {
19 public:
RectsGM()20     RectsGM() {
21         this->setBGColor(0xFF000000);
22         this->makePaints();
23         this->makeMatrices();
24         this->makeRects();
25     }
26 
27 protected:
28 
onShortName()29     SkString onShortName() override {
30         return SkString("rects");
31     }
32 
onISize()33     SkISize onISize() override {
34         return SkISize::Make(1200, 900);
35     }
36 
makePaints()37     void makePaints() {
38         {
39             // no AA
40             SkPaint p;
41             p.setColor(SK_ColorWHITE);
42             fPaints.push_back(p);
43         }
44 
45         {
46             // AA
47             SkPaint p;
48             p.setColor(SK_ColorWHITE);
49             p.setAntiAlias(true);
50             fPaints.push_back(p);
51         }
52 
53         {
54             // AA with translucent
55             SkPaint p;
56             p.setColor(SK_ColorWHITE);
57             p.setAntiAlias(true);
58             p.setAlpha(0x66);
59             fPaints.push_back(p);
60         }
61 
62         {
63             // AA with mask filter
64             SkPaint p;
65             p.setColor(SK_ColorWHITE);
66             p.setAntiAlias(true);
67             SkMaskFilter* mf = SkBlurMaskFilter::Create(
68                                    kNormal_SkBlurStyle,
69                                    SkBlurMask::ConvertRadiusToSigma(SkIntToScalar(5)),
70                                    SkBlurMaskFilter::kHighQuality_BlurFlag);
71             p.setMaskFilter(mf)->unref();
72             fPaints.push_back(p);
73         }
74 
75         {
76             // AA with radial shader
77             SkPaint p;
78             p.setColor(SK_ColorWHITE);
79             p.setAntiAlias(true);
80             SkPoint center = SkPoint::Make(SkIntToScalar(-5), SkIntToScalar(30));
81             SkColor colors[] = { SK_ColorBLUE, SK_ColorRED, SK_ColorGREEN };
82             SkScalar pos[] = { 0, SK_ScalarHalf, SK_Scalar1 };
83             SkShader* s = SkGradientShader::CreateRadial(center,
84                                                          SkIntToScalar(20),
85                                                          colors,
86                                                          pos,
87                                                          SK_ARRAY_COUNT(colors),
88                                                          SkShader::kClamp_TileMode);
89             p.setShader(s)->unref();
90             fPaints.push_back(p);
91         }
92 
93         {
94             // AA with blur
95             SkPaint p;
96             p.setColor(SK_ColorWHITE);
97             p.setAntiAlias(true);
98             SkDrawLooper* shadowLooper =
99                 SkBlurDrawLooper::Create(SK_ColorWHITE,
100                                          SkBlurMask::ConvertRadiusToSigma(SkIntToScalar(10)),
101                                          SkIntToScalar(5), SkIntToScalar(10),
102                                          SkBlurDrawLooper::kIgnoreTransform_BlurFlag |
103                                          SkBlurDrawLooper::kOverrideColor_BlurFlag |
104                                          SkBlurDrawLooper::kHighQuality_BlurFlag);
105             SkAutoUnref aurL0(shadowLooper);
106             p.setLooper(shadowLooper);
107             fPaints.push_back(p);
108         }
109 
110         {
111             // AA with stroke style
112             SkPaint p;
113             p.setColor(SK_ColorWHITE);
114             p.setAntiAlias(true);
115             p.setStyle(SkPaint::kStroke_Style);
116             p.setStrokeWidth(SkIntToScalar(3));
117             fPaints.push_back(p);
118         }
119 
120         {
121             // AA with bevel-stroke style
122             SkPaint p;
123             p.setColor(SK_ColorWHITE);
124             p.setAntiAlias(true);
125             p.setStyle(SkPaint::kStroke_Style);
126             p.setStrokeJoin(SkPaint::kBevel_Join);
127             p.setStrokeWidth(SkIntToScalar(3));
128             fPaints.push_back(p);
129         }
130 
131         {
132             // AA with round-stroke style
133             SkPaint p;
134             p.setColor(SK_ColorWHITE);
135             p.setAntiAlias(true);
136             p.setStyle(SkPaint::kStroke_Style);
137             p.setStrokeJoin(SkPaint::kRound_Join);
138             p.setStrokeWidth(SkIntToScalar(3));
139             fPaints.push_back(p);
140         }
141 
142         {
143             // AA with stroke style, width = 0
144             SkPaint p;
145             p.setColor(SK_ColorWHITE);
146             p.setAntiAlias(true);
147             p.setStyle(SkPaint::kStroke_Style);
148             fPaints.push_back(p);
149         }
150 
151         {
152             // AA with stroke style, width wider than rect width and/or height
153             SkPaint p;
154             p.setColor(SK_ColorWHITE);
155             p.setAntiAlias(true);
156             p.setStyle(SkPaint::kStroke_Style);
157             p.setStrokeWidth(SkIntToScalar(40));
158             fPaints.push_back(p);
159         }
160 
161         {
162             // AA with stroke and fill style
163             SkPaint p;
164             p.setColor(SK_ColorWHITE);
165             p.setAntiAlias(true);
166             p.setStyle(SkPaint::kStrokeAndFill_Style);
167             p.setStrokeWidth(SkIntToScalar(2));
168             fPaints.push_back(p);
169         }
170     }
171 
makeMatrices()172     void makeMatrices() {
173         {
174             // 1x1.5 scale
175             SkMatrix m;
176             m.setScale(1, 1.5f);
177             fMatrices.push_back(m);
178         }
179 
180         {
181             // 1.5x1.5 scale
182             SkMatrix m;
183             m.setScale(1.5f, 1.5f);
184             fMatrices.push_back(m);
185         }
186 
187         {
188             // 1x1.5 skew
189             SkMatrix m;
190             m.setSkew(1, 1.5f);
191             fMatrices.push_back(m);
192         }
193 
194         {
195             // 1.5x1.5 skew
196             SkMatrix m;
197             m.setSkew(1.5f, 1.5f);
198             fMatrices.push_back(m);
199         }
200 
201         {
202             // 30 degree rotation
203             SkMatrix m;
204             m.setRotate(SkIntToScalar(30));
205             fMatrices.push_back(m);
206         }
207 
208         {
209             // 90 degree rotation
210             SkMatrix m;
211             m.setRotate(SkIntToScalar(90));
212             fMatrices.push_back(m);
213         }
214     }
215 
makeRects()216     void makeRects() {
217         {
218             // small square
219             SkRect r = SkRect::MakeLTRB(0, 0, 30, 30);
220             fRects.push_back(r);
221         }
222 
223         {
224             // thin vertical
225             SkRect r = SkRect::MakeLTRB(0, 0, 2, 40);
226             fRects.push_back(r);
227         }
228 
229         {
230             // thin horizontal
231             SkRect r = SkRect::MakeLTRB(0, 0, 40, 2);
232             fRects.push_back(r);
233         }
234 
235         {
236             // very thin
237             SkRect r = SkRect::MakeLTRB(0, 0, 0.25f, 10);
238             fRects.push_back(r);
239         }
240 
241         {
242             // zaftig
243             SkRect r = SkRect::MakeLTRB(0, 0, 60, 60);
244             fRects.push_back(r);
245         }
246     }
247 
248     // position the current test on the canvas
position(SkCanvas * canvas,int testCount)249     static void position(SkCanvas* canvas, int testCount) {
250         canvas->translate(SK_Scalar1 * 100 * (testCount % 10) + SK_Scalar1 / 4,
251                           SK_Scalar1 * 100 * (testCount / 10) + 3 * SK_Scalar1 / 4);
252     }
253 
onDraw(SkCanvas * canvas)254     void onDraw(SkCanvas* canvas) override {
255         canvas->translate(20 * SK_Scalar1, 20 * SK_Scalar1);
256 
257         int testCount = 0;
258 
259         for (int i = 0; i < fPaints.count(); ++i) {
260             for (int j = 0; j < fRects.count(); ++j, ++testCount) {
261                 canvas->save();
262                 this->position(canvas, testCount);
263                 canvas->drawRect(fRects[j], fPaints[i]);
264                 canvas->restore();
265             }
266         }
267 
268         SkPaint paint;
269         paint.setColor(SK_ColorWHITE);
270         paint.setAntiAlias(true);
271 
272         for (int i = 0; i < fMatrices.count(); ++i) {
273             for (int j = 0; j < fRects.count(); ++j, ++testCount) {
274                 canvas->save();
275                 this->position(canvas, testCount);
276                 canvas->concat(fMatrices[i]);
277                 canvas->drawRect(fRects[j], paint);
278                 canvas->restore();
279             }
280         }
281     }
282 
283 private:
284     SkTArray<SkPaint>  fPaints;
285     SkTArray<SkMatrix> fMatrices;
286     SkTArray<SkRect>   fRects;
287 
288     typedef GM INHERITED;
289 };
290 
291 //////////////////////////////////////////////////////////////////////////////
292 
MyFactory(void *)293 static GM* MyFactory(void*) { return new RectsGM; }
294 static GMRegistry reg(MyFactory);
295 
296 }
297