1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
/*
* Copyright 2012 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "gm.h"
#include "SkCanvas.h"
#include "SkGraphics.h"
#include "SkRandom.h"
#include "SkLayerDrawLooper.h"
#include "SkBlurMaskFilter.h"
static SkRect inset(const SkRect& r) {
SkRect rect = r;
rect.inset(r.width() / 8, r.height() / 8);
return rect;
}
class PathInteriorGM : public skiagm::GM {
public:
PathInteriorGM() {
this->setBGColor(0xFFDDDDDD);
}
protected:
virtual SkISize onISize() {
return SkISize::Make(770, 770);
}
virtual SkString onShortName() SK_OVERRIDE {
return SkString("pathinterior");
}
void show(SkCanvas* canvas, const SkPath& path) {
SkPaint paint;
paint.setAntiAlias(true);
SkRect rect;
#if 0
bool hasInterior = path.hasRectangularInterior(&rect);
#else
bool hasInterior = false;
#endif
paint.setColor(hasInterior ? 0xFF8888FF : SK_ColorGRAY);
canvas->drawPath(path, paint);
paint.setStyle(SkPaint::kStroke_Style);
paint.setColor(SK_ColorRED);
canvas->drawPath(path, paint);
if (hasInterior) {
paint.setStyle(SkPaint::kFill_Style);
paint.setColor(0x8800FF00);
canvas->drawRect(rect, paint);
}
}
virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE {
canvas->translate(8.5f, 8.5f);
const SkRect rect = { 0, 0, 80, 80 };
const SkScalar RAD = rect.width()/8;
int i = 0;
for (int insetFirst = 0; insetFirst <= 1; ++insetFirst) {
for (int doEvenOdd = 0; doEvenOdd <= 1; ++doEvenOdd) {
for (int outerRR = 0; outerRR <= 1; ++outerRR) {
for (int innerRR = 0; innerRR <= 1; ++innerRR) {
for (int outerCW = 0; outerCW <= 1; ++outerCW) {
for (int innerCW = 0; innerCW <= 1; ++innerCW) {
SkPath path;
path.setFillType(doEvenOdd ? SkPath::kEvenOdd_FillType : SkPath::kWinding_FillType);
SkPath::Direction outerDir = outerCW ? SkPath::kCW_Direction : SkPath::kCCW_Direction;
SkPath::Direction innerDir = innerCW ? SkPath::kCW_Direction : SkPath::kCCW_Direction;
SkRect r = insetFirst ? inset(rect) : rect;
if (outerRR) {
path.addRoundRect(r, RAD, RAD, outerDir);
} else {
path.addRect(r, outerDir);
}
r = insetFirst ? rect : inset(rect);
if (innerRR) {
path.addRoundRect(r, RAD, RAD, innerDir);
} else {
path.addRect(r, innerDir);
}
SkScalar dx = (i / 8) * rect.width() * 6 / 5;
SkScalar dy = (i % 8) * rect.height() * 6 / 5;
i++;
path.offset(dx, dy);
this->show(canvas, path);
}
}
}
}
}
}
}
private:
typedef GM INHERITED;
};
//////////////////////////////////////////////////////////////////////////////
static skiagm::GM* MyFactory(void*) { return new PathInteriorGM; }
static skiagm::GMRegistry reg(MyFactory);
|