1 /*
2  * Copyright 2012 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 #ifndef SkIntersectionHelper_DEFINED
8 #define SkIntersectionHelper_DEFINED
9 
10 #include "SkOpContour.h"
11 #include "SkOpSegment.h"
12 #include "SkPath.h"
13 
14 #ifdef SK_DEBUG
15 #include "SkPathOpsPoint.h"
16 #endif
17 
18 class SkIntersectionHelper {
19 public:
20     enum SegmentType {
21         kHorizontalLine_Segment = -1,
22         kVerticalLine_Segment = 0,
23         kLine_Segment = SkPath::kLine_Verb,
24         kQuad_Segment = SkPath::kQuad_Verb,
25         kConic_Segment = SkPath::kConic_Verb,
26         kCubic_Segment = SkPath::kCubic_Verb,
27     };
28 
29     bool advance() {
30         fSegment = fSegment->next();
31         return fSegment != nullptr;
32     }
33 
34     SkScalar bottom() const {
35         return bounds().fBottom;
36     }
37 
38     const SkPathOpsBounds& bounds() const {
39         return fSegment->bounds();
40     }
41 
42     SkOpContour* contour() const {
43         return fSegment->contour();
44     }
45 
46     void init(SkOpContour* contour) {
47         fSegment = contour->first();
48     }
49 
50     SkScalar left() const {
51         return bounds().fLeft;
52     }
53 
54     const SkPoint* pts() const {
55         return fSegment->pts();
56     }
57 
58     SkScalar right() const {
59         return bounds().fRight;
60     }
61 
62     SkOpSegment* segment() const {
63         return fSegment;
64     }
65 
66     SegmentType segmentType() const {
67         SegmentType type = (SegmentType) fSegment->verb();
68         if (type != kLine_Segment) {
69             return type;
70         }
71         if (fSegment->isHorizontal()) {
72             return kHorizontalLine_Segment;
73         }
74         if (fSegment->isVertical()) {
75             return kVerticalLine_Segment;
76         }
77         return kLine_Segment;
78     }
79 
80     bool startAfter(const SkIntersectionHelper& after) {
81         fSegment = after.fSegment->next();
82         return fSegment != nullptr;
83     }
84 
85     SkScalar top() const {
86         return bounds().fTop;
87     }
88 
89     SkScalar weight() const {
90         return fSegment->weight();
91     }
92 
93     SkScalar x() const {
94         return bounds().fLeft;
95     }
96 
97     bool xFlipped() const {
98         return x() != pts()[0].fX;
99     }
100 
101     SkScalar y() const {
102         return bounds().fTop;
103     }
104 
105     bool yFlipped() const {
106         return y() != pts()[0].fY;
107     }
108 
109 private:
110     SkOpSegment* fSegment;
111 };
112 
113 #endif
114