mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Remove stray lines and segments in the result
This commit is contained in:
parent
59a540a71b
commit
019693d144
1 changed files with 7 additions and 7 deletions
12
Boolean.js
12
Boolean.js
|
@ -125,8 +125,7 @@
|
||||||
this.linkOut = this.linkOut || this.linkBOut; // linkOut
|
this.linkOut = this.linkOut || this.linkBOut; // linkOut
|
||||||
// Also update the references in links to point to "this" Node
|
// Also update the references in links to point to "this" Node
|
||||||
if( !this.linkIn || !this.linkOut ){
|
if( !this.linkIn || !this.linkOut ){
|
||||||
markPoint( this.point, this._intersectionID )
|
// markPoint( this.point, this._intersectionID );
|
||||||
console.log( this )
|
|
||||||
throw { name: 'Boolean Error', message: 'No matching link found at ixID: ' +
|
throw { name: 'Boolean Error', message: 'No matching link found at ixID: ' +
|
||||||
this._intersectionID + " point: " + this.point.toString() };
|
this._intersectionID + " point: " + this.point.toString() };
|
||||||
}
|
}
|
||||||
|
@ -348,8 +347,6 @@
|
||||||
|
|
||||||
window.g = graph;
|
window.g = graph;
|
||||||
|
|
||||||
// console.log( path1Clockwise, path2Clockwise );
|
|
||||||
|
|
||||||
// Sort function to sort intersections according to the 'parameter'(t) in a link (curve)
|
// Sort function to sort intersections according to the 'parameter'(t) in a link (curve)
|
||||||
function ixSort( a, b ){ return a.parameter - b.parameter; }
|
function ixSort( a, b ){ return a.parameter - b.parameter; }
|
||||||
|
|
||||||
|
@ -426,7 +423,6 @@
|
||||||
rightLink = null;
|
rightLink = null;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// parts = Curve.subdivide(crv.getValues(), param);
|
|
||||||
parts = Curve.subdivide(values, param);
|
parts = Curve.subdivide(values, param);
|
||||||
left = parts[0];
|
left = parts[0];
|
||||||
right = parts[1];
|
right = parts[1];
|
||||||
|
@ -445,10 +441,10 @@
|
||||||
nuNode._intersectionID = ix[j]._id;
|
nuNode._intersectionID = ix[j]._id;
|
||||||
// clear the cached Segment on original end nodes and Update their handles
|
// clear the cached Segment on original end nodes and Update their handles
|
||||||
lnk.nodeIn._segment = null;
|
lnk.nodeIn._segment = null;
|
||||||
|
lnk.nodeOut._segment = null;
|
||||||
if( !isLinear ){
|
if( !isLinear ){
|
||||||
var tmppnt = lnk.nodeIn.point;
|
var tmppnt = lnk.nodeIn.point;
|
||||||
lnk.nodeIn.handleOut = new Point( left[2] - tmppnt.x, left[3] - tmppnt.y );
|
lnk.nodeIn.handleOut = new Point( left[2] - tmppnt.x, left[3] - tmppnt.y );
|
||||||
lnk.nodeOut._segment = null;
|
|
||||||
tmppnt = lnk.nodeOut.point;
|
tmppnt = lnk.nodeOut.point;
|
||||||
lnk.nodeOut.handleIn = new Point( right[4] - tmppnt.x, right[5] - tmppnt.y );
|
lnk.nodeOut.handleIn = new Point( right[4] - tmppnt.x, right[5] - tmppnt.y );
|
||||||
}
|
}
|
||||||
|
@ -615,10 +611,14 @@
|
||||||
path.closed = true;
|
path.closed = true;
|
||||||
// path.clockwise = true;
|
// path.clockwise = true;
|
||||||
if( path.segments.length > 1 && linkCount > 0 ){ // avoid stray segments and incomplete paths
|
if( path.segments.length > 1 && linkCount > 0 ){ // avoid stray segments and incomplete paths
|
||||||
|
if( path.segments.length === 2 ){
|
||||||
|
}
|
||||||
|
if( path.segments.length > 2 || !path.curves[0].isLinear() ){
|
||||||
boolResult.addChild( path );
|
boolResult.addChild( path );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
boolResult = boolResult.reduce();
|
boolResult = boolResult.reduce();
|
||||||
|
|
||||||
// Remove the paths we duplicated
|
// Remove the paths we duplicated
|
||||||
|
|
Loading…
Reference in a new issue