Fix some failing tests with PathItem#contains(), introduced by commit 6c6ad76c94

This commit is contained in:
Jürg Lehni 2015-01-04 23:28:39 +01:00
parent 5d875f2d83
commit 5f3df1f5a1

View file

@ -313,16 +313,19 @@ PathItem.inject(new function() {
// Due to numerical precision issues, two consecutive curves // Due to numerical precision issues, two consecutive curves
// may register an intercept twice, at t = 1 and 0, if y is // may register an intercept twice, at t = 1 and 0, if y is
// almost equal to one of the endpoints of the curves. // almost equal to one of the endpoints of the curves.
if (!(lastT !== null && abs(lastX0 - x0) < tolerance if (!(lastT != null && abs(lastX0 - x0) < tolerance
&& (lastT <= tMin && t >= tMax && lastT > tMax && t < tMin)) {
|| t <= tMin && lastT >= tMax))) {
// Take care of cases where the curve and the preceding // Take care of cases where the curve and the preceding
// curve merely touches the ray towards +-x direction, // curve merely touches the ray towards +-x direction,
// but proceeds to the same side of the ray. // but proceeds to the same side of the ray.
// This essentially is not a crossing. // This essentially is not a crossing.
if (Numerical.isZero(slope) && !Curve.isLinear(values) if (Numerical.isZero(slope) && !Curve.isLinear(values)
// Does the slope over curve beginning change?
|| t < tMin && slope * Curve.evaluate( || t < tMin && slope * Curve.evaluate(
curve.previous.values, t, 1).y < 0) { curve.previous.values, 1, 1).y < 0
// Does the slope over curve end change?
|| t > tMax && slope * Curve.evaluate(
curve.next.values, 0, 1).y < 0) {
if (testContains && x0 >= xBefore && x0 <= xAfter) { if (testContains && x0 >= xBefore && x0 <= xAfter) {
++windLeft; ++windLeft;
++windRight; ++windRight;