Minor clean up in getWinding() code.

This commit is contained in:
Jürg Lehni 2014-02-21 00:40:24 +01:00
parent b4bc16330a
commit 4973ea9845

View file

@ -255,8 +255,6 @@ PathItem.inject(new function() {
var TOLERANCE = /*#=*/ Numerical.TOLERANCE, var TOLERANCE = /*#=*/ Numerical.TOLERANCE,
x = point.x, x = point.x,
y = point.y, y = point.y,
xAfter = x + TOLERANCE,
xBefore = x - TOLERANCE,
windLeft = 0, windLeft = 0,
windRight = 0, windRight = 0,
roots = [], roots = [],
@ -266,7 +264,9 @@ PathItem.inject(new function() {
// indeterminate state. // indeterminate state.
if (horizontal) { if (horizontal) {
var yTop = -Infinity, var yTop = -Infinity,
yBottom = Infinity; yBottom = Infinity,
yBefore = y - TOLERANCE,
yAfter = y + TOLERANCE;
// Find the closest top and bottom intercepts for the same vertical // Find the closest top and bottom intercepts for the same vertical
// line. // line.
for (var i = 0, l = curves.length; i < l; i++) { for (var i = 0, l = curves.length; i < l; i++) {
@ -274,10 +274,10 @@ PathItem.inject(new function() {
if (Curve.solveCubic(v, 0, x, roots, 0, 1) > 0) { if (Curve.solveCubic(v, 0, x, roots, 0, 1) > 0) {
for (var j = roots.length - 1; j >= 0; j--) { for (var j = roots.length - 1; j >= 0; j--) {
var y0 = Curve.evaluate(v, roots[j], 0).y; var y0 = Curve.evaluate(v, roots[j], 0).y;
if (y0 > y + TOLERANCE && y0 < yBottom) { if (y0 < yBefore && y0 > yTop) {
yBottom = y0;
} else if (y0 < y - TOLERANCE && y0 > yTop) {
yTop = y0; yTop = y0;
} else if (y0 > yAfter && y0 < yBottom) {
yBottom = y0;
} }
} }
} }
@ -291,6 +291,8 @@ PathItem.inject(new function() {
if (yBottom < Infinity) if (yBottom < Infinity)
windRight = getWinding(new Point(x, yBottom), curves); windRight = getWinding(new Point(x, yBottom), curves);
} else { } else {
var xBefore = x - TOLERANCE,
xAfter = x + TOLERANCE;
// Find the winding number for right side of the curve, inclusive of // Find the winding number for right side of the curve, inclusive of
// the curve itself, while tracing along its +-x direction. // the curve itself, while tracing along its +-x direction.
for (var i = 0, l = curves.length; i < l; i++) { for (var i = 0, l = curves.length; i < l; i++) {