1 /*
2 * Copyright 2011 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 "SkCanvas.h"
10 #include "SkColorPriv.h"
11 #include "SkShader.h"
12
test4(SkCanvas * canvas)13 static void test4(SkCanvas* canvas) {
14 SkPaint paint;
15 paint.setAntiAlias(true);
16 SkPoint pts[] = {
17 {10, 160}, {610, 160},
18 {610, 160}, {10, 160},
19
20 {610, 160}, {610, 160},
21 {610, 199}, {610, 199},
22
23 {10, 198}, {610, 198},
24 {610, 199}, {10, 199},
25
26 {10, 160}, {10, 160},
27 {10, 199}, {10, 199}
28 };
29 char verbs[] = {
30 0, 1, 1, 1, 4,
31 0, 1, 1, 1, 4,
32 0, 1, 1, 1, 4,
33 0, 1, 1, 1, 4
34 };
35 SkPath path;
36 SkPoint* ptPtr = pts;
37 for (size_t i = 0; i < sizeof(verbs); ++i) {
38 switch ((SkPath::Verb) verbs[i]) {
39 case SkPath::kMove_Verb:
40 path.moveTo(ptPtr->fX, ptPtr->fY);
41 ++ptPtr;
42 break;
43 case SkPath::kLine_Verb:
44 path.lineTo(ptPtr->fX, ptPtr->fY);
45 ++ptPtr;
46 break;
47 case SkPath::kClose_Verb:
48 path.close();
49 break;
50 default:
51 SkASSERT(false);
52 break;
53 }
54 }
55 SkRect clip = {0, 130, 772, 531};
56 canvas->clipRect(clip);
57 canvas->drawPath(path, paint);
58 }
59
60 static const struct {
61 SkXfermode::Mode fMode;
62 const char* fLabel;
63 } gModes[] = {
64 { SkXfermode::kClear_Mode, "Clear" },
65 { SkXfermode::kSrc_Mode, "Src" },
66 { SkXfermode::kDst_Mode, "Dst" },
67 { SkXfermode::kSrcOver_Mode, "SrcOver" },
68 { SkXfermode::kDstOver_Mode, "DstOver" },
69 { SkXfermode::kSrcIn_Mode, "SrcIn" },
70 { SkXfermode::kDstIn_Mode, "DstIn" },
71 { SkXfermode::kSrcOut_Mode, "SrcOut" },
72 { SkXfermode::kDstOut_Mode, "DstOut" },
73 { SkXfermode::kSrcATop_Mode, "SrcATop" },
74 { SkXfermode::kDstATop_Mode, "DstATop" },
75 { SkXfermode::kXor_Mode, "Xor" },
76 };
77
78 const int gWidth = 64;
79 const int gHeight = 64;
80 const SkScalar W = SkIntToScalar(gWidth);
81 const SkScalar H = SkIntToScalar(gHeight);
82
drawCell(SkCanvas * canvas,SkXfermode * mode,SkAlpha a0,SkAlpha a1)83 static SkScalar drawCell(SkCanvas* canvas, SkXfermode* mode,
84 SkAlpha a0, SkAlpha a1) {
85
86 SkPaint paint;
87 paint.setAntiAlias(true);
88
89 SkRect r = SkRect::MakeWH(W, H);
90 r.inset(W/10, H/10);
91
92 paint.setColor(SK_ColorBLUE);
93 paint.setAlpha(a0);
94 canvas->drawOval(r, paint);
95
96 paint.setColor(SK_ColorRED);
97 paint.setAlpha(a1);
98 paint.setXfermode(mode);
99
100 SkScalar offset = SK_Scalar1 / 3;
101 SkRect rect = SkRect::MakeXYWH(W / 4 + offset,
102 H / 4 + offset,
103 W / 2, H / 2);
104 canvas->drawRect(rect, paint);
105
106 return H;
107 }
108
make_bg_shader()109 static SkShader* make_bg_shader() {
110 SkBitmap bm;
111 bm.allocN32Pixels(2, 2);
112 *bm.getAddr32(0, 0) = *bm.getAddr32(1, 1) = 0xFFFFFFFF;
113 *bm.getAddr32(1, 0) = *bm.getAddr32(0, 1) = SkPackARGB32(0xFF, 0xCC,
114 0xCC, 0xCC);
115
116 SkMatrix m;
117 m.setScale(SkIntToScalar(6), SkIntToScalar(6));
118 SkShader* s = SkShader::CreateBitmapShader(bm,
119 SkShader::kRepeat_TileMode,
120 SkShader::kRepeat_TileMode,
121 &m);
122
123 return s;
124 }
125
126 namespace skiagm {
127
128 class AARectModesGM : public GM {
129 SkPaint fBGPaint;
130 public:
AARectModesGM()131 AARectModesGM () {
132 fBGPaint.setShader(make_bg_shader())->unref();
133 }
134
135 protected:
onGetFlags() const136 virtual uint32_t onGetFlags() const SK_OVERRIDE {
137 return kSkipTiled_Flag;
138 }
139
onShortName()140 virtual SkString onShortName() {
141 return SkString("aarectmodes");
142 }
143
onISize()144 virtual SkISize onISize() { return SkISize::Make(640, 480); }
145
onDraw(SkCanvas * canvas)146 virtual void onDraw(SkCanvas* canvas) {
147 if (false) { // avoid bit rot, suppress warning
148 test4(canvas);
149 }
150 const SkRect bounds = SkRect::MakeWH(W, H);
151 static const SkAlpha gAlphaValue[] = { 0xFF, 0x88, 0x88 };
152
153 canvas->translate(SkIntToScalar(4), SkIntToScalar(4));
154
155 for (int alpha = 0; alpha < 4; ++alpha) {
156 canvas->save();
157 canvas->save();
158 for (size_t i = 0; i < SK_ARRAY_COUNT(gModes); ++i) {
159 if (6 == i) {
160 canvas->restore();
161 canvas->translate(W * 5, 0);
162 canvas->save();
163 }
164 SkXfermode* mode = SkXfermode::Create(gModes[i].fMode);
165
166 canvas->drawRect(bounds, fBGPaint);
167 canvas->saveLayer(&bounds, NULL);
168 SkScalar dy = drawCell(canvas, mode,
169 gAlphaValue[alpha & 1],
170 gAlphaValue[alpha & 2]);
171 canvas->restore();
172
173 canvas->translate(0, dy * 5 / 4);
174 SkSafeUnref(mode);
175 }
176 canvas->restore();
177 canvas->restore();
178 canvas->translate(W * 5 / 4, 0);
179 }
180 }
181
182 private:
183 typedef GM INHERITED;
184 };
185
186 //////////////////////////////////////////////////////////////////////////////
187
MyFactory(void *)188 static GM* MyFactory(void*) { return new AARectModesGM; }
189 static GMRegistry reg(MyFactory);
190
191 }
192