mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-23 07:49:48 -05:00
Merge upstream
This commit is contained in:
commit
a52c030f37
1 changed files with 20 additions and 10 deletions
|
@ -716,7 +716,9 @@ statics: {
|
||||||
// We need to provide the original left curve reference to the
|
// We need to provide the original left curve reference to the
|
||||||
// #getIntersections() calls as it is required to create the resulting
|
// #getIntersections() calls as it is required to create the resulting
|
||||||
// CurveLocation objects.
|
// CurveLocation objects.
|
||||||
getIntersections: function(v1, v2, curve1, curve2, locations) {
|
getIntersections: function(v1, v2, curve1, curve2, locations,
|
||||||
|
// Pass on isFlat1 / isFlat2 parameters in iterative calls
|
||||||
|
isFlat1, isFlat2) {
|
||||||
var bounds1 = this.getBounds(v1),
|
var bounds1 = this.getBounds(v1),
|
||||||
bounds2 = this.getBounds(v2);
|
bounds2 = this.getBounds(v2);
|
||||||
/*#*/ if (options.debug) {
|
/*#*/ if (options.debug) {
|
||||||
|
@ -734,10 +736,15 @@ statics: {
|
||||||
if (bounds1.touches(bounds2)) {
|
if (bounds1.touches(bounds2)) {
|
||||||
// See if both curves are flat enough to be treated as lines, either
|
// See if both curves are flat enough to be treated as lines, either
|
||||||
// because they have no control points at all, or are "flat enough"
|
// because they have no control points at all, or are "flat enough"
|
||||||
if ((this.isLinear(v1)
|
// If the curve was flat in a previous iteration, we don't need to
|
||||||
|| this.isFlatEnough(v1, /*#=*/ Numerical.TOLERANCE))
|
// recalculate since it does not need further subdivision then.
|
||||||
&& (this.isLinear(v2)
|
if (!isFlat1)
|
||||||
|| this.isFlatEnough(v2, /*#=*/ Numerical.TOLERANCE))) {
|
isFlat1 = this.isLinear(v1)
|
||||||
|
|| this.isFlatEnough(v1, /*#=*/ Numerical.TOLERANCE);
|
||||||
|
if (!isFlat2)
|
||||||
|
isFlat2 = this.isLinear(v2)
|
||||||
|
|| this.isFlatEnough(v2, /*#=*/ Numerical.TOLERANCE);
|
||||||
|
if (isFlat1 && isFlat2) {
|
||||||
/*#*/ if (options.debug) {
|
/*#*/ if (options.debug) {
|
||||||
new Path.Line({
|
new Path.Line({
|
||||||
from: [v1[0], v1[1]],
|
from: [v1[0], v1[1]],
|
||||||
|
@ -769,11 +776,14 @@ statics: {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Subdivide both curves, and see if they intersect.
|
// Subdivide both curves, and see if they intersect.
|
||||||
var v1s = this.subdivide(v1),
|
// If one of the curves is flat already, no further subdivion
|
||||||
v2s = this.subdivide(v2);
|
// is required.
|
||||||
for (var i = 0; i < 2; i++)
|
var v1s = isFlat1 ? [v1] : this.subdivide(v1),
|
||||||
for (var j = 0; j < 2; j++)
|
v2s = isFlat2 ? [v2] : this.subdivide(v2);
|
||||||
this.getIntersections(v1s[i], v2s[j], curve1, curve2, locations);
|
for (var i = 0, l = v1s.length; i < l; i++)
|
||||||
|
for (var j = 0, k = v2s.length; j < k; j++)
|
||||||
|
this.getIntersections(v1s[i], v2s[j], curve1, curve2,
|
||||||
|
locations, isFlat1, isFlat2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return locations;
|
return locations;
|
||||||
|
|
Loading…
Reference in a new issue