Add comments about how to potentially improve getBounds() accuracy.

This commit is contained in:
Jürg Lehni 2011-07-07 23:00:40 +02:00
parent ca50461fd1
commit 23c4499d15

View file

@ -1761,6 +1761,7 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
// Solve for derivative for quadratic roots. Each good root // Solve for derivative for quadratic roots. Each good root
// (meaning a solution 0 < t < 1) is an extrema in the cubic // (meaning a solution 0 < t < 1) is an extrema in the cubic
// polynomial and thus a potential point defining the bounds // polynomial and thus a potential point defining the bounds
// TODO: Use tolerance here, just like Numerical.solveQuadratic
if (a == 0) { if (a == 0) {
if (b == 0) if (b == 0)
continue; continue;
@ -1771,11 +1772,12 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
continue; continue;
} }
var b2ac = b * b - 4 * a * c; var q = b * b - 4 * a * c;
if (b2ac < 0) if (q < 0)
continue; continue;
var sqrt = Math.sqrt(b2ac), // TODO: Match this with Numerical.solveQuadratic
f = 1 / (a * -2), var sqrt = Math.sqrt(q),
f = -0.5 / a,
t1 = (b - sqrt) * f, t1 = (b - sqrt) * f,
t2 = (b + sqrt) * f; t2 = (b + sqrt) * f;
if (tMin < t1 && t1 < tMax) if (tMin < t1 && t1 < tMax)