blob: a614761e69bfcf68cde965f2440ae39ed2d271b9 [file] [log] [blame]
bsalomon@google.coma3108262011-10-10 14:08:47 +00001/*
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
reed@google.com76166152011-11-14 13:14:58 +000013static void test4(SkCanvas* canvas) {
14 SkPaint paint;
15 paint.setAntiAlias(true);
16 SkPoint pts[] = {
17 {10, 160}, {610, 160},
18 {610, 160}, {10, 160},
rmistry@google.comd6176b02012-08-23 18:14:13 +000019
reed@google.com76166152011-11-14 13:14:58 +000020 {610, 160}, {610, 160},
21 {610, 199}, {610, 199},
rmistry@google.comd6176b02012-08-23 18:14:13 +000022
reed@google.com76166152011-11-14 13:14:58 +000023 {10, 198}, {610, 198},
24 {610, 199}, {10, 199},
rmistry@google.comd6176b02012-08-23 18:14:13 +000025
reed@google.com76166152011-11-14 13:14:58 +000026 {10, 160}, {10, 160},
27 {10, 199}, {10, 199}
28 };
29 char verbs[] = {
rmistry@google.comd6176b02012-08-23 18:14:13 +000030 0, 1, 1, 1, 4,
reed@google.com76166152011-11-14 13:14:58 +000031 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;
bsalomon@google.com31648eb2011-11-23 15:01:08 +000037 for (size_t i = 0; i < sizeof(verbs); ++i) {
reed@google.com76166152011-11-14 13:14:58 +000038 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;
bsalomon@google.com31648eb2011-11-23 15:01:08 +000050 default:
51 SkASSERT(false);
52 break;
reed@google.com76166152011-11-14 13:14:58 +000053 }
54 }
55 SkRect clip = {0, 130, 772, 531};
56 canvas->clipRect(clip);
57 canvas->drawPath(path, paint);
58}
59
bsalomon@google.coma3108262011-10-10 14:08:47 +000060static 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
78const int gWidth = 64;
79const int gHeight = 64;
80const SkScalar W = SkIntToScalar(gWidth);
81const SkScalar H = SkIntToScalar(gHeight);
82
83static 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);
rmistry@google.comd6176b02012-08-23 18:14:13 +0000105
bsalomon@google.coma3108262011-10-10 14:08:47 +0000106 return H;
107}
108
109static SkShader* make_bg_shader() {
110 SkBitmap bm;
reed@google.comeb9a46c2014-01-25 16:46:20 +0000111 bm.allocN32Pixels(2, 2);
bsalomon@google.coma3108262011-10-10 14:08:47 +0000112 *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 SkShader* s = SkShader::CreateBitmapShader(bm,
117 SkShader::kRepeat_TileMode,
118 SkShader::kRepeat_TileMode);
rmistry@google.comd6176b02012-08-23 18:14:13 +0000119
bsalomon@google.coma3108262011-10-10 14:08:47 +0000120 SkMatrix m;
121 m.setScale(SkIntToScalar(6), SkIntToScalar(6));
122 s->setLocalMatrix(m);
123 return s;
124}
125
126namespace skiagm {
rmistry@google.comd6176b02012-08-23 18:14:13 +0000127
bsalomon@google.coma3108262011-10-10 14:08:47 +0000128 class AARectModesGM : public GM {
129 SkPaint fBGPaint;
130 public:
131 AARectModesGM () {
132 fBGPaint.setShader(make_bg_shader())->unref();
133 }
134
135 protected:
136
137 virtual SkString onShortName() {
138 return SkString("aarectmodes");
139 }
140
141 virtual SkISize onISize() { return make_isize(640, 480); }
142
143 virtual void onDraw(SkCanvas* canvas) {
caryclark@google.com13130862012-06-06 12:10:45 +0000144 if (false) { // avoid bit rot, suppress warning
145 test4(canvas);
146 }
bsalomon@google.coma3108262011-10-10 14:08:47 +0000147 const SkRect bounds = SkRect::MakeWH(W, H);
148 static const SkAlpha gAlphaValue[] = { 0xFF, 0x88, 0x88 };
149
150 canvas->translate(SkIntToScalar(4), SkIntToScalar(4));
151
152 for (int alpha = 0; alpha < 4; ++alpha) {
153 canvas->save();
154 canvas->save();
155 for (size_t i = 0; i < SK_ARRAY_COUNT(gModes); ++i) {
156 if (6 == i) {
157 canvas->restore();
158 canvas->translate(W * 5, 0);
159 canvas->save();
160 }
161 SkXfermode* mode = SkXfermode::Create(gModes[i].fMode);
rmistry@google.comd6176b02012-08-23 18:14:13 +0000162
bsalomon@google.coma3108262011-10-10 14:08:47 +0000163 canvas->drawRect(bounds, fBGPaint);
164 canvas->saveLayer(&bounds, NULL);
165 SkScalar dy = drawCell(canvas, mode,
166 gAlphaValue[alpha & 1],
167 gAlphaValue[alpha & 2]);
168 canvas->restore();
169
170 canvas->translate(0, dy * 5 / 4);
171 SkSafeUnref(mode);
172 }
173 canvas->restore();
174 canvas->restore();
175 canvas->translate(W * 5 / 4, 0);
176 }
177 }
178
bsalomon@google.coma3108262011-10-10 14:08:47 +0000179 private:
180 typedef GM INHERITED;
181 };
182
183//////////////////////////////////////////////////////////////////////////////
184
185 static GM* MyFactory(void*) { return new AARectModesGM; }
186 static GMRegistry reg(MyFactory);
187
188}