Change code sequence in tracePaths() to only calculate tangents and winding values if they are required.

This commit is contained in:
Jürg Lehni 2014-03-02 21:39:54 +01:00
parent d7be443119
commit 7911d8b42a

View file

@ -380,29 +380,31 @@ PathItem.inject(new function() {
&& (inter = seg._intersection) && (inter = seg._intersection)
&& (interSeg = inter._segment) && (interSeg = inter._segment)
&& interSeg !== startSeg) { && interSeg !== startSeg) {
var c1 = seg.getCurve();
if (dir > 0)
c1 = c1.getPrevious();
var t1 = c1.getTangentAt(dir < 1 ? ZERO : ONE, true),
// Get both curves at the intersection (except the entry
// curves) along with their winding values and tangents.
c4 = interSeg.getCurve(),
c3 = c4.getPrevious(),
t3 = c3.getTangentAt(ONE, true),
t4 = c4.getTangentAt(ZERO, true),
// Cross product of the entry and exit tangent vectors
// at the intersection, will let us select the correct
// countour to traverse next.
w3 = t1.cross(t3),
w4 = t1.cross(t4);
if (selfOp) { if (selfOp) {
// Switch to the intersection segment, if we are // Switch to the intersection segment, if we are
// resolving self-Intersections. // resolving self-Intersections.
seg._visited = interSeg._visited; seg._visited = interSeg._visited;
seg = interSeg; seg = interSeg;
dir = 1; dir = 1;
} else if (w3 * w4 !== 0) { } else {
// Do not attempt to switch contours if we aren't absolutely var c1 = seg.getCurve();
if (dir > 0)
c1 = c1.getPrevious();
var t1 = c1.getTangentAt(dir < 1 ? ZERO : ONE, true),
// Get both curves at the intersection (except the
// entry curves).
c4 = interSeg.getCurve(),
c3 = c4.getPrevious(),
// Calculate their winding values and tangents.
t3 = c3.getTangentAt(ONE, true),
t4 = c4.getTangentAt(ZERO, true),
// Cross product of the entry and exit tangent
// vectors at the intersection, will let us select
// the correct countour to traverse next.
w3 = t1.cross(t3),
w4 = t1.cross(t4);
if (w3 * w4 !== 0) {
// Do not attempt to switch contours if we aren't
// sure that there is a possible candidate. // sure that there is a possible candidate.
var curve = w3 < w4 ? c3 : c4, var curve = w3 < w4 ? c3 : c4,
nextCurve = operator(curve._segment1._winding) nextCurve = operator(curve._segment1._winding)
@ -410,8 +412,8 @@ PathItem.inject(new function() {
: w3 < w4 ? c4 : c3, : w3 < w4 ? c4 : c3,
nextSeg = nextCurve._segment1; nextSeg = nextCurve._segment1;
dir = nextCurve === c3 ? -1 : 1; dir = nextCurve === c3 ? -1 : 1;
// If we didn't manage to find a suitable direction for // If we didn't find a suitable direction for next
// next contour to traverse, stay on the same contour. // contour to traverse, stay on the same contour.
if (nextSeg._visited && seg._path !== nextSeg._path if (nextSeg._visited && seg._path !== nextSeg._path
|| !operator(nextSeg._winding)) { || !operator(nextSeg._winding)) {
dir = 1; dir = 1;
@ -425,6 +427,7 @@ PathItem.inject(new function() {
} else { } else {
dir = 1; dir = 1;
} }
}
handleOut = dir > 0 ? seg._handleOut : seg._handleIn; handleOut = dir > 0 ? seg._handleOut : seg._handleIn;
} }
// Add the current segment to the path, and mark the added // Add the current segment to the path, and mark the added