aboutsummaryrefslogtreecommitdiffhomepage
path: root/experimental/Intersection
diff options
context:
space:
mode:
authorGravatar caryclark@google.com <caryclark@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-13 11:57:28 +0000
committerGravatar caryclark@google.com <caryclark@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-13 11:57:28 +0000
commit5c286d32869cb4a648cc048b6f522847cfe277c3 (patch)
treef75f48f67b9893e1318b365a7423ba85d9b2de44 /experimental/Intersection
parentc665832fbf636a73a2fd59c5970abec7e4109d4a (diff)
shape ops work in progress
Review URL: https://codereview.appspot.com/6392058 git-svn-id: http://skia.googlecode.com/svn/trunk@4591 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'experimental/Intersection')
-rw-r--r--experimental/Intersection/Simplify.cpp21
-rw-r--r--experimental/Intersection/SimplifyFindNext_Test.cpp2
2 files changed, 14 insertions, 9 deletions
diff --git a/experimental/Intersection/Simplify.cpp b/experimental/Intersection/Simplify.cpp
index 8cdec8f994..859755f5f6 100644
--- a/experimental/Intersection/Simplify.cpp
+++ b/experimental/Intersection/Simplify.cpp
@@ -1157,9 +1157,10 @@ public:
// it is guaranteed to have an end which describes a non-zero length (?)
// winding -1 means ccw, 1 means cw
// firstFind allows coincident edges to be treated differently
- Segment* findNext(SkTDArray<Span*>& chase, int winding, const int startIndex,
- const int endIndex,
- int& nextStart, int& nextEnd, int& flipped, bool firstFind) {
+ Segment* findNext(SkTDArray<Span*>& chase, int winding,
+ const int startIndex, const int endIndex,
+ int& nextStart, int& nextEnd, int& flipped, bool firstFind
+ ,bool active /* active param is debugging only */ ) {
SkASSERT(startIndex != endIndex);
int count = fTs.count();
SkASSERT(startIndex < endIndex ? startIndex < count - 1
@@ -1217,11 +1218,14 @@ public:
}
firstEdge = false;
if (!winding) {
+ if (!active) {
+ SkASSERT(nextAngle->segment() == this);
+ markWinding(SkMin32(nextAngle->start(), nextAngle->end()),
+ maxWinding);
+ SkDebugf("%s inactive\n", __FUNCTION__);
+ return NULL;
+ }
if (!foundAngle) {
-#if 0
- nextAngle->segment()->markWinding(
- SkMin32(nextAngle->start(), nextAngle->end()), maxWinding);
-#endif
foundAngle = nextAngle;
}
continue;
@@ -2941,7 +2945,8 @@ static void bridge(SkTDArray<Contour*>& contourList, SkPath& simple) {
int nextStart, nextEnd, flipped = 1;
Segment* next = current->findNext(chaseArray,
winding + spanWinding, index,
- endIndex, nextStart, nextEnd, flipped, firstTime);
+ endIndex, nextStart, nextEnd, flipped, firstTime
+ , active /* active is debugging only */ );
if (!next) {
break;
}
diff --git a/experimental/Intersection/SimplifyFindNext_Test.cpp b/experimental/Intersection/SimplifyFindNext_Test.cpp
index 4edc53254f..8ae35d2082 100644
--- a/experimental/Intersection/SimplifyFindNext_Test.cpp
+++ b/experimental/Intersection/SimplifyFindNext_Test.cpp
@@ -35,7 +35,7 @@ static const SimplifyFindNextTest::Segment* testCommon(
int nextStart, nextEnd, flipped = 1;
SkTDArray<SimplifyFindNextTest::Span*> chaseArray;
SimplifyFindNextTest::Segment* next = segment.findNext(chaseArray, winding,
- startIndex, endIndex, nextStart, nextEnd, flipped, true);
+ startIndex, endIndex, nextStart, nextEnd, flipped, true, true);
pts[1] = next->xyAtT(&next->span(nextStart));
SkASSERT(pts[0] == pts[1]);
return next;