Remove stray lines and segments in the result

This commit is contained in:
hkrish 2013-04-25 15:28:49 +02:00
parent 59a540a71b
commit 019693d144

View file

@ -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