From d89995a78199e26b42ca1f1852b5e5a203c5bcac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrg=20Lehni?= Date: Wed, 6 Jan 2016 00:34:23 +0100 Subject: [PATCH] Fix winding calculation in rare edge case. Closes #889 --- src/path/PathItem.Boolean.js | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/path/PathItem.Boolean.js b/src/path/PathItem.Boolean.js index 9ef83242..5b611210 100644 --- a/src/path/PathItem.Boolean.js +++ b/src/path/PathItem.Boolean.js @@ -401,14 +401,17 @@ PathItem.inject(new function() { // the ray. This essentially is not a crossing. if (Numerical.isZero(slope) && !Curve.isStraight(values) + // NOTE: We include 0 in the checks, since + // even following a horizontal tangent is a + // tip that is only touched, not crossed. // Does the slope over the beginning change? || t < tMin && prevCurve && slope * Curve.getTangent( - prevCurve.values, 1).y < 0 + prevCurve.values, 1).y <= 0 // Does the slope over the end change? || t > tMax && nextCurve && slope * Curve.getTangent( - nextCurve.values, 0).y < 0) { + nextCurve.values, 0).y <= 0) { if (x > xBefore && x < xAfter) { ++windLeft; ++windRight;