mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Add check of value range in solveCubic
Performance of `Curve.solveCubic()` can be improved by first checking if the specified value is within the curve's value range. If it is outside the range, the expensive call to `Numerical.solveCubic()` is not necessary.
This commit is contained in:
parent
eb752a43cd
commit
7009fc3ea0
1 changed files with 7 additions and 2 deletions
|
@ -628,8 +628,13 @@ statics: /** @lends Curve */{
|
||||||
var p1 = v[coord],
|
var p1 = v[coord],
|
||||||
c1 = v[coord + 2],
|
c1 = v[coord + 2],
|
||||||
c2 = v[coord + 4],
|
c2 = v[coord + 4],
|
||||||
p2 = v[coord + 6],
|
p2 = v[coord + 6];
|
||||||
c = 3 * (c1 - p1),
|
if (p1 < val && p2 < val && c1 < val && c2 < val
|
||||||
|
|| p1 > val && p2 > val && c1 > val && c2 > val) {
|
||||||
|
// If val is outside the curve values, no solution is possible.
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
var c = 3 * (c1 - p1),
|
||||||
b = 3 * (c2 - c1) - c,
|
b = 3 * (c2 - c1) - c,
|
||||||
a = p2 - p1 - c - b;
|
a = p2 - p1 - c - b;
|
||||||
return Numerical.solveCubic(a, b, c, p1 - val, roots, min, max);
|
return Numerical.solveCubic(a, b, c, p1 - val, roots, min, max);
|
||||||
|
|
Loading…
Reference in a new issue