Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(3)

Side by Side Diff: src/pathops/SkOpSegment.cpp

Issue 2239803002: start working on tiger again (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/pathops/SkOpCoincidence.cpp ('k') | tests/PathOpsOpTest.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2012 Google Inc. 2 * Copyright 2012 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 #include "SkOpCoincidence.h" 7 #include "SkOpCoincidence.h"
8 #include "SkOpContour.h" 8 #include "SkOpContour.h"
9 #include "SkOpSegment.h" 9 #include "SkOpSegment.h"
10 #include "SkPathWriter.h" 10 #include "SkPathWriter.h"
(...skipping 1149 matching lines...) Expand 10 before | Expand all | Expand 10 after
1160 // the resulting run from point 1 to point 2 is coincident on A and B. 1160 // the resulting run from point 1 to point 2 is coincident on A and B.
1161 bool SkOpSegment::missingCoincidence() { 1161 bool SkOpSegment::missingCoincidence() {
1162 if (this->done()) { 1162 if (this->done()) {
1163 return false; 1163 return false;
1164 } 1164 }
1165 SkOpSpan* prior = nullptr; 1165 SkOpSpan* prior = nullptr;
1166 SkOpSpanBase* spanBase = &fHead; 1166 SkOpSpanBase* spanBase = &fHead;
1167 bool result = false; 1167 bool result = false;
1168 do { 1168 do {
1169 SkOpPtT* ptT = spanBase->ptT(), * spanStopPtT = ptT; 1169 SkOpPtT* ptT = spanBase->ptT(), * spanStopPtT = ptT;
1170 SkASSERT(ptT->span() == spanBase); 1170 SkOPASSERT(ptT->span() == spanBase);
1171 while ((ptT = ptT->next()) != spanStopPtT) { 1171 while ((ptT = ptT->next()) != spanStopPtT) {
1172 if (ptT->deleted()) { 1172 if (ptT->deleted()) {
1173 continue; 1173 continue;
1174 } 1174 }
1175 SkOpSegment* opp = ptT->span()->segment(); 1175 SkOpSegment* opp = ptT->span()->segment();
1176 if (opp->done()) { 1176 if (opp->done()) {
1177 continue; 1177 continue;
1178 } 1178 }
1179 // when opp is encounted the 1st time, continue; on 2nd encounter, l ook for coincidence 1179 // when opp is encounted the 1st time, continue; on 2nd encounter, l ook for coincidence
1180 if (!opp->visited()) { 1180 if (!opp->visited()) {
(...skipping 625 matching lines...) Expand 10 before | Expand all | Expand 10 after
1806 int absOut = SkTAbs(outerWinding); 1806 int absOut = SkTAbs(outerWinding);
1807 int absIn = SkTAbs(innerWinding); 1807 int absIn = SkTAbs(innerWinding);
1808 bool result = absOut == absIn ? outerWinding < 0 : absOut < absIn; 1808 bool result = absOut == absIn ? outerWinding < 0 : absOut < absIn;
1809 return result; 1809 return result;
1810 } 1810 }
1811 1811
1812 int SkOpSegment::windSum(const SkOpAngle* angle) const { 1812 int SkOpSegment::windSum(const SkOpAngle* angle) const {
1813 const SkOpSpan* minSpan = angle->start()->starter(angle->end()); 1813 const SkOpSpan* minSpan = angle->start()->starter(angle->end());
1814 return minSpan->windSum(); 1814 return minSpan->windSum();
1815 } 1815 }
OLDNEW
« no previous file with comments | « src/pathops/SkOpCoincidence.cpp ('k') | tests/PathOpsOpTest.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698