1 
2 /*
3  * Copyright 2011 Google Inc.
4  *
5  * Use of this source code is governed by a BSD-style license that can be
6  * found in the LICENSE file.
7  */
8 
9 #include "SampleCode.h"
10 #include "SkView.h"
11 #include "SkCanvas.h"
12 #include "SkGradientShader.h"
13 #include "SkGraphics.h"
14 #include "SkImageDecoder.h"
15 #include "SkPath.h"
16 #include "SkRegion.h"
17 #include "SkShader.h"
18 #include "SkUtils.h"
19 #include "SkXfermode.h"
20 #include "SkColorPriv.h"
21 #include "SkColorFilter.h"
22 #include "SkParsePath.h"
23 #include "SkTime.h"
24 #include "SkTypeface.h"
25 
26 #include "SkGeometry.h"
27 
28 class ConcavePathView : public SampleView {
29 public:
ConcavePathView()30     ConcavePathView() {}
31 
32 protected:
33     // overrides from SkEventSink
onQuery(SkEvent * evt)34     virtual bool onQuery(SkEvent* evt) {
35         if (SampleCode::TitleQ(*evt)) {
36             SampleCode::TitleR(evt, "ConcavePaths");
37             return true;
38         }
39         return this->INHERITED::onQuery(evt);
40     }
41 
onDrawContent(SkCanvas * canvas)42     virtual void onDrawContent(SkCanvas* canvas) {
43         SkPaint paint;
44 
45         paint.setAntiAlias(true);
46         paint.setStyle(SkPaint::kFill_Style);
47 
48         // Concave test
49         if (1) {
50             SkPath path;
51             canvas->translate(0, 0);
52             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
53             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
54             path.lineTo(SkIntToScalar(30), SkIntToScalar(30));
55             path.lineTo(SkIntToScalar(20), SkIntToScalar(80));
56             canvas->drawPath(path, paint);
57         }
58         // Reverse concave test
59         if (1) {
60             SkPath path;
61             canvas->save();
62             canvas->translate(100, 0);
63             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
64             path.lineTo(SkIntToScalar(20), SkIntToScalar(80));
65             path.lineTo(SkIntToScalar(30), SkIntToScalar(30));
66             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
67             canvas->drawPath(path, paint);
68             canvas->restore();
69         }
70         // Bowtie (intersection)
71         if (1) {
72             SkPath path;
73             canvas->save();
74             canvas->translate(200, 0);
75             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
76             path.lineTo(SkIntToScalar(80), SkIntToScalar(80));
77             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
78             path.lineTo(SkIntToScalar(20), SkIntToScalar(80));
79             canvas->drawPath(path, paint);
80             canvas->restore();
81         }
82         // "fake" bowtie (concave, but no intersection)
83         if (1) {
84             SkPath path;
85             canvas->save();
86             canvas->translate(300, 0);
87             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
88             path.lineTo(SkIntToScalar(50), SkIntToScalar(40));
89             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
90             path.lineTo(SkIntToScalar(80), SkIntToScalar(80));
91             path.lineTo(SkIntToScalar(50), SkIntToScalar(60));
92             path.lineTo(SkIntToScalar(20), SkIntToScalar(80));
93             canvas->drawPath(path, paint);
94             canvas->restore();
95         }
96         // Fish test (intersection/concave)
97         if (1) {
98             SkPath path;
99             canvas->save();
100             canvas->translate(0, 100);
101             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
102             path.lineTo(SkIntToScalar(80), SkIntToScalar(80));
103             path.lineTo(SkIntToScalar(70), SkIntToScalar(50));
104             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
105             path.lineTo(SkIntToScalar(20), SkIntToScalar(80));
106             path.lineTo(SkIntToScalar(0), SkIntToScalar(50));
107             canvas->drawPath(path, paint);
108             canvas->restore();
109         }
110         // Collinear test
111         if (1) {
112             SkPath path;
113             canvas->save();
114             canvas->translate(100, 100);
115             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
116             path.lineTo(SkIntToScalar(50), SkIntToScalar(20));
117             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
118             path.lineTo(SkIntToScalar(50), SkIntToScalar(80));
119             canvas->drawPath(path, paint);
120             canvas->restore();
121         }
122         // Hole test
123         if (1) {
124             SkPath path;
125             canvas->save();
126             canvas->translate(200, 100);
127             path.moveTo(SkIntToScalar(20), SkIntToScalar(20));
128             path.lineTo(SkIntToScalar(80), SkIntToScalar(20));
129             path.lineTo(SkIntToScalar(80), SkIntToScalar(80));
130             path.lineTo(SkIntToScalar(20), SkIntToScalar(80));
131             path.moveTo(SkIntToScalar(30), SkIntToScalar(30));
132             path.lineTo(SkIntToScalar(30), SkIntToScalar(70));
133             path.lineTo(SkIntToScalar(70), SkIntToScalar(70));
134             path.lineTo(SkIntToScalar(70), SkIntToScalar(30));
135             canvas->drawPath(path, paint);
136             canvas->restore();
137         }
138     }
139 
onFindClickHandler(SkScalar x,SkScalar y,unsigned modi)140     virtual SkView::Click* onFindClickHandler(SkScalar x, SkScalar y,
141                                               unsigned modi) {
142         this->inval(nullptr);
143         return this->INHERITED::onFindClickHandler(x, y, modi);
144     }
145 
146 private:
147     typedef SampleView INHERITED;
148 };
149 
150 //////////////////////////////////////////////////////////////////////////////
151 
MyFactory()152 static SkView* MyFactory() { return new ConcavePathView; }
153 static SkViewRegister reg(MyFactory);
154