Improve code handling special winding cases.

This commit is contained in:
Jürg Lehni 2013-10-18 15:20:32 +02:00
parent 75a209c002
commit f8106ae18f
2 changed files with 22 additions and 4 deletions

View file

@ -780,8 +780,8 @@ statics: {
xt = y < mid ? left[0] : left[6]; xt = y < mid ? left[0] : left[6];
root = y < mid ? 0 : 1; root = y < mid ? 0 : 1;
// Filter out end points based on direction. // Filter out end points based on direction.
if (dir < 0 && root == 0 && y == left[1] || if (dir < 0 && abs(root) < tolerance && y == left[1] ||
dir > 0 && root == 1 && y == left[7]) dir > 0 && abs(root - 1) < tolerance && y == left[7])
continue; continue;
} }
// See if we're touching a horizontal stationary point by looking at // See if we're touching a horizontal stationary point by looking at
@ -797,8 +797,8 @@ statics: {
if (x >= xt + (flat ? -tolerance : tolerance * dir)) { if (x >= xt + (flat ? -tolerance : tolerance * dir)) {
// When touching a stationary point, only count it if we're // When touching a stationary point, only count it if we're
// actuall on it. // actuall on it.
if (flat && root == 0 && x != left[0] if (flat && (abs(root) < tolerance && x != left[0]
|| root == 1 && x != left[6]) || abs(root - 1) < tolerance && x != left[6]))
continue; continue;
// If this is a horizontal stationary point, and we're at the // If this is a horizontal stationary point, and we're at the
// end of the curve, flip the orientation of dir. // end of the curve, flip the orientation of dir.

View file

@ -56,6 +56,24 @@ test('Path#contains() (Circle Contours)', function() {
testPoint(path, path.bounds.bottomRight, false); testPoint(path, path.bounds.bottomRight, false);
}); });
test('Path#contains() (Transformed Circle Contours)', function() {
var path = new Path.Circle({
center: [200, 200],
radius: 50,
fillColor: 'blue',
});
path.translate(100, 100);
testPoint(path, path.bounds.topCenter, true);
testPoint(path, path.bounds.leftCenter, true);
testPoint(path, path.bounds.rightCenter, true);
testPoint(path, path.bounds.bottomCenter, true);
testPoint(path, path.bounds.topLeft, false);
testPoint(path, path.bounds.topRight, false);
testPoint(path, path.bounds.bottomLeft, false);
testPoint(path, path.bounds.bottomRight, false);
});
test('Path#contains() (Round Rectangle)', function() { test('Path#contains() (Round Rectangle)', function() {
var rectangle = new Rectangle({ var rectangle = new Rectangle({
point: new Point(0, 0), point: new Point(0, 0),