OLD | NEW |
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 "SkGeometry.h" | 7 #include "SkGeometry.h" |
8 #include "SkLineParameters.h" | 8 #include "SkLineParameters.h" |
9 #include "SkPathOpsConic.h" | 9 #include "SkPathOpsConic.h" |
10 #include "SkPathOpsCubic.h" | 10 #include "SkPathOpsCubic.h" |
(...skipping 292 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
303 o1Pts[0] = &fPts[offset]; | 303 o1Pts[0] = &fPts[offset]; |
304 o1Pts[1] = &fPts[++offset]; | 304 o1Pts[1] = &fPts[++offset]; |
305 o1Pts[2] = &fPts[++offset]; | 305 o1Pts[2] = &fPts[++offset]; |
306 } | 306 } |
307 | 307 |
308 int SkDCubic::searchRoots(double extremeTs[6], int extrema, double axisIntercept
, | 308 int SkDCubic::searchRoots(double extremeTs[6], int extrema, double axisIntercept
, |
309 SearchAxis xAxis, double* validRoots) const { | 309 SearchAxis xAxis, double* validRoots) const { |
310 extrema += findInflections(&extremeTs[extrema]); | 310 extrema += findInflections(&extremeTs[extrema]); |
311 extremeTs[extrema++] = 0; | 311 extremeTs[extrema++] = 0; |
312 extremeTs[extrema] = 1; | 312 extremeTs[extrema] = 1; |
| 313 SkASSERT(extrema < 6); |
313 SkTQSort(extremeTs, extremeTs + extrema); | 314 SkTQSort(extremeTs, extremeTs + extrema); |
314 int validCount = 0; | 315 int validCount = 0; |
315 for (int index = 0; index < extrema; ) { | 316 for (int index = 0; index < extrema; ) { |
316 double min = extremeTs[index]; | 317 double min = extremeTs[index]; |
317 double max = extremeTs[++index]; | 318 double max = extremeTs[++index]; |
318 if (min == max) { | 319 if (min == max) { |
319 continue; | 320 continue; |
320 } | 321 } |
321 double newT = binarySearch(min, max, axisIntercept, xAxis); | 322 double newT = binarySearch(min, max, axisIntercept, xAxis); |
322 if (newT >= 0) { | 323 if (newT >= 0) { |
| 324 if (validCount >= 3) { |
| 325 return 0; |
| 326 } |
323 validRoots[validCount++] = newT; | 327 validRoots[validCount++] = newT; |
324 } | 328 } |
325 } | 329 } |
326 return validCount; | 330 return validCount; |
327 } | 331 } |
328 | 332 |
329 // cubic roots | 333 // cubic roots |
330 | 334 |
331 static const double PI = 3.141592653589793; | 335 static const double PI = 3.141592653589793; |
332 | 336 |
(...skipping 357 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
690 for (int index = 0; index < roots; ++index) { | 694 for (int index = 0; index < roots; ++index) { |
691 double t = startT + (endT - startT) * extremeTs[index]; | 695 double t = startT + (endT - startT) * extremeTs[index]; |
692 SkDPoint mid = dCurve.ptAtT(t); | 696 SkDPoint mid = dCurve.ptAtT(t); |
693 if (topPt->fY > mid.fY || (topPt->fY == mid.fY && topPt->fX > mid.fX)) { | 697 if (topPt->fY > mid.fY || (topPt->fY == mid.fY && topPt->fX > mid.fX)) { |
694 topT = t; | 698 topT = t; |
695 *topPt = mid; | 699 *topPt = mid; |
696 } | 700 } |
697 } | 701 } |
698 return topT; | 702 return topT; |
699 } | 703 } |
OLD | NEW |