Rename p\d to part\d

This commit is contained in:
Jürg Lehni 2013-05-24 21:05:20 -07:00
parent 9cf6536e5b
commit eeac15ac46

View file

@ -53,8 +53,8 @@ function addLocation(locations, curve1, parameter, point, curve2) {
locations.push(new CurveLocation(curve1, parameter, point, curve2)); locations.push(new CurveLocation(curve1, parameter, point, curve2));
} }
function getCurveIntersections(v1, v2, curve1, curve2, locations, range1, range2, function getCurveIntersections(v1, v2, curve1, curve2, locations,
recursion) { range1, range2, recursion) {
// NOTE: range1 and range1 are only used for recusion // NOTE: range1 and range1 are only used for recusion
recursion = (recursion || 0) + 1; recursion = (recursion || 0) + 1;
// Avoid endless recursion. // Avoid endless recursion.
@ -68,11 +68,11 @@ function getCurveIntersections(v1, v2, curve1, curve2, locations, range1, range2
range1 = range1 || [ 0, 1 ]; range1 = range1 || [ 0, 1 ];
range2 = range2 || [ 0, 1 ]; range2 = range2 || [ 0, 1 ];
// Get the clipped parts from the original curve, to avoid cumulative errors // Get the clipped parts from the original curve, to avoid cumulative errors
var p1 = Curve.getPart(v1, range1[0], range1[1]); var part1 = Curve.getPart(v1, range1[0], range1[1]),
var p2 = Curve.getPart(v2, range2[0], range2[1]); part2 = Curve.getPart(v2, range2[0], range2[1]),
// markCurve(p1, '#f0f', true); iteration = 0;
// markCurve(p2, '#0ff', false); // markCurve(part1, '#f0f', true);
var iteration = 0; // markCurve(part2, '#0ff', false);
// Loop until both parameter range converge. We have to handle the // Loop until both parameter range converge. We have to handle the
// degenerate case seperately, where fat-line clipping can become // degenerate case seperately, where fat-line clipping can become
// numerically unstable when one of the curves has converged to a point and // numerically unstable when one of the curves has converged to a point and
@ -82,7 +82,7 @@ function getCurveIntersections(v1, v2, curve1, curve2, locations, range1, range2
|| Math.abs(range2[1] - range2[0]) > /*#=*/ Numerical.TOLERANCE)) { || Math.abs(range2[1] - range2[0]) > /*#=*/ Numerical.TOLERANCE)) {
// First we clip v2 with v1's fat-line // First we clip v2 with v1's fat-line
var range = range2.slice(); var range = range2.slice();
var intersects1 = clipFatLine(p1, p2, range), var intersects1 = clipFatLine(part1, part2, range),
intersects2 = 0; intersects2 = 0;
// Stop if there are no possible intersections // Stop if there are no possible intersections
if (intersects1 === 0) if (intersects1 === 0)
@ -91,10 +91,10 @@ function getCurveIntersections(v1, v2, curve1, curve2, locations, range1, range2
// Get the clipped parts from the original v2, to avoid cumulative // Get the clipped parts from the original v2, to avoid cumulative
// errors ...and reuse some objects. // errors ...and reuse some objects.
range2 = range; range2 = range;
p2 = Curve.getPart(v2, range2[0], range2[1]); part2 = Curve.getPart(v2, range2[0], range2[1]);
// markCurve(p2, '#0ff', false); // markCurve(part2, '#0ff', false);
// Next we clip v1 with nuv2's fat-line // Next we clip v1 with nuv2's fat-line
intersects2 = clipFatLine(p2, p1, range = range1.slice()); intersects2 = clipFatLine(part2, part1, range = range1.slice());
// Stop if there are no possible intersections // Stop if there are no possible intersections
if (intersects2 === 0) if (intersects2 === 0)
break; break;
@ -102,9 +102,9 @@ function getCurveIntersections(v1, v2, curve1, curve2, locations, range1, range2
// Get the clipped parts from the original v2, to avoid // Get the clipped parts from the original v2, to avoid
// cumulative errors // cumulative errors
range1 = range; range1 = range;
p1 = Curve.getPart(v1, range1[0], range1[1]); part1 = Curve.getPart(v1, range1[0], range1[1]);
} }
// markCurve(p1, '#f0f', true); // markCurve(part1, '#f0f', true);
} }
// Get the clipped parts from the original v1 // Get the clipped parts from the original v1
// Check if there could be multiple intersections // Check if there could be multiple intersections
@ -158,16 +158,17 @@ function getCurveIntersections(v1, v2, curve1, curve2, locations, range1, range2
} }
// see if either or both of the curves are flat enough to be treated // see if either or both of the curves are flat enough to be treated
// as lines. // as lines.
var flat1 = Curve.isFlatEnough(p1, /*#=*/ Numerical.TOLERANCE), var flat1 = Curve.isFlatEnough(part1, /*#=*/ Numerical.TOLERANCE),
flat2 = Curve.isFlatEnough(p2, /*#=*/ Numerical.TOLERANCE); flat2 = Curve.isFlatEnough(part2, /*#=*/ Numerical.TOLERANCE);
if (flat1 && flat2) { if (flat1 && flat2) {
getLineLineIntersection(p1, p2, curve1, curve2, locations); getLineLineIntersection(part1, part2, curve1, curve2, locations);
break; break;
} }
if (flat1 || flat2) { if (flat1 || flat2) {
// Use curve line intersection method while specifying which // Use curve line intersection method while specifying which
// curve to be treated as line // curve to be treated as line
getCurveLineIntersections(p1, p2, curve1, curve2, locations, flat1); getCurveLineIntersections(part1, part2, curve1, curve2, locations,
flat1);
break; break;
} }
} }