mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
parent
10f464edfc
commit
7412939096
1 changed files with 20 additions and 15 deletions
|
@ -825,21 +825,25 @@ PathItem.inject(new function() {
|
|||
function collect(inter, end) {
|
||||
while (inter && inter !== end) {
|
||||
var other = inter._segment,
|
||||
path = other._path,
|
||||
next = other.getNext() || path && path.getFirstSegment(),
|
||||
nextInter = next && next._intersection;
|
||||
// See if this segment and the next are both not visited
|
||||
// yet, or are bringing us back to the beginning, and are
|
||||
// both valid, meaning they are part of the boolean result.
|
||||
if (other !== segment && (isStart(other) || isStart(next)
|
||||
|| next && (isValid(other) && (isValid(next)
|
||||
// If the next segment isn't valid, its intersection
|
||||
// to which we may switch might be, so check that.
|
||||
|| nextInter && isValid(nextInter._segment))))) {
|
||||
crossings.push(other);
|
||||
path = other && other._path;
|
||||
if (path) {
|
||||
var next = other.getNext() || path.getFirstSegment(),
|
||||
nextInter = next._intersection;
|
||||
// See if this segment and the next are not visited yet,
|
||||
// or are bringing us back to the start, and are both
|
||||
// valid, meaning they're part of the boolean result.
|
||||
if (other !== segment && (isStart(other)
|
||||
|| isStart(next)
|
||||
|| next && (isValid(other) && (isValid(next)
|
||||
// If next segment isn't valid, its intersection
|
||||
// to which we may switch may be, so check that.
|
||||
|| nextInter && isValid(nextInter._segment))))
|
||||
) {
|
||||
crossings.push(other);
|
||||
}
|
||||
if (collectStarts)
|
||||
starts.push(other);
|
||||
}
|
||||
if (collectStarts)
|
||||
starts.push(other);
|
||||
inter = inter._next;
|
||||
}
|
||||
}
|
||||
|
@ -970,7 +974,8 @@ PathItem.inject(new function() {
|
|||
// the list of crossings when the branch is created above.
|
||||
do {
|
||||
seg = branch && branch.crossings.shift();
|
||||
if (!seg) {
|
||||
if (!seg || !seg._path) {
|
||||
seg = null;
|
||||
// If there are no segments left, try previous
|
||||
// branches until we find one that works.
|
||||
branch = branches.pop();
|
||||
|
|
Loading…
Reference in a new issue