Some code formatting and a fix for a typo in new getConvexHull()

This commit is contained in:
Jürg Lehni 2015-10-06 16:09:35 +02:00
parent 6b421d5f72
commit 3a65c87843

View file

@ -1539,20 +1539,20 @@ new function() { // Scope for intersection using bezier fat-line clipping
dist1 = dq1 - (dq0 + (dq3 - dq0) / 3), dist1 = dq1 - (dq0 + (dq3 - dq0) / 3),
dist2 = dq2 - (dq0 + 2 * (dq3 - dq0) / 3), dist2 = dq2 - (dq0 + 2 * (dq3 - dq0) / 3),
hull; hull;
// Check if p1 and p2 are on the same side of the line [ p0, p3 ] // Check if p1 and p2 are on the opposite side of the line [p0, p3]
if (dist1 * dist2 < 0) { if (dist1 * dist2 < 0) {
// p1 and p2 lie on different sides of [p0, p3]. The hull is a // p1 and p2 lie on different sides of [p0, p3]. The hull is a
// quadrilateral and line [ p0, p3 ] is NOT part of the hull so we // quadrilateral and line [p0, p3] is NOT part of the hull so we are
// are pretty much done here. // pretty much done here. The top part includes p1, we will reverse
// The top part includes p1, // it later if that is not the case.
// we will reverse it later if that is not the case
hull = [[p0, p1, p3], [p0, p2, p3]]; hull = [[p0, p1, p3], [p0, p2, p3]];
} else { } else {
// p1 and p2 lie on the same sides of [ p0, p3 ]. The hull can be // p1 and p2 lie on the same sides of [p0, p3]. The hull can be a
// a triangle or a quadrilateral and line [ p0, p3 ] is part of the // triangle or a quadrilateral and line [p0, p3] is part of the
// hull. Check if the hull is a triangle or a quadrilateral. We have a // hull. Check if the hull is a triangle or a quadrilateral. We have
// triangle if the vertical distance of one of the middle points (p1, p2) // a triangle if the vertical distance of one of the middle points
// is equal or less than half the vertical distance of the other middle point. // (p1, p2) is equal or less than half the vertical distance of the
// other middle point.
var distRatio = dist1 / dist2; var distRatio = dist1 / dist2;
hull = [ hull = [
// p2 is inside, the hull is a triangle. // p2 is inside, the hull is a triangle.
@ -1565,8 +1565,7 @@ new function() { // Scope for intersection using bezier fat-line clipping
[p0, p3] [p0, p3]
]; ];
} }
} // Flip hull if dist1 is negative or if it is zero and dist2 is negative
// flip hull if dist1 is negative or if it is zero and dist2 is negative
return (dist1 || dist2) < 0 ? hull.reverse() : hull; return (dist1 || dist2) < 0 ? hull.reverse() : hull;
} }