mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Throw errors when the graph cannot be traversed
This commit is contained in:
parent
0108f004f1
commit
43d3243179
2 changed files with 23 additions and 12 deletions
15
Boolean.js
15
Boolean.js
|
@ -128,6 +128,10 @@
|
||||||
this.linkIn = this.linkIn || this.linkBIn; // linkIn
|
this.linkIn = this.linkIn || this.linkBIn; // linkIn
|
||||||
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 ){
|
||||||
|
throw { name: 'Boolean Error', message: 'No matching link found at ixID: ' +
|
||||||
|
this._intersectionID + " point: " + this.point.toString() };
|
||||||
|
}
|
||||||
this.linkIn.nodeOut = this; // linkIn.nodeEnd
|
this.linkIn.nodeOut = this; // linkIn.nodeEnd
|
||||||
this.linkOut.nodeIn = this; // linkOut.nodeStart
|
this.linkOut.nodeIn = this; // linkOut.nodeStart
|
||||||
this.handleIn = this.handleIn || this.handleBIn;
|
this.handleIn = this.handleIn || this.handleBIn;
|
||||||
|
@ -482,13 +486,14 @@
|
||||||
firstNode = nextNode = null;
|
firstNode = nextNode = null;
|
||||||
len = graph.length;
|
len = graph.length;
|
||||||
while( len-- ){
|
while( len-- ){
|
||||||
if( !graph[len].INVALID && !graph[len].nodeIn.visited && !firstNode ){
|
lnk = graph[len];
|
||||||
if( !foundBasePath && graph[len].isBaseContour === 1 ){
|
if( !lnk.INVALID && !lnk.nodeIn.visited && !firstNode ){
|
||||||
firstNode = graph[len].nodeIn;
|
if( !foundBasePath && lnk.isBaseContour === 1 ){
|
||||||
|
firstNode = lnk.nodeIn;
|
||||||
foundBasePath = true;
|
foundBasePath = true;
|
||||||
break;
|
break;
|
||||||
} else if(foundBasePath){
|
} else if(foundBasePath){
|
||||||
firstNode = graph[len].nodeIn;
|
firstNode = lnk.nodeIn;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -510,7 +515,7 @@
|
||||||
}
|
}
|
||||||
boolResult = boolResult.reduce();
|
boolResult = boolResult.reduce();
|
||||||
|
|
||||||
// Remove duplicate paths
|
// Remove the paths we duplicated
|
||||||
path1.remove();
|
path1.remove();
|
||||||
path2.remove();
|
path2.remove();
|
||||||
|
|
||||||
|
|
|
@ -52,6 +52,7 @@ function runTests() {
|
||||||
// caption = prepareTest( 'Circles overlap exactly over each other', container );
|
// caption = prepareTest( 'Circles overlap exactly over each other', container );
|
||||||
// pathA = new Path.Circle(new Point(110, 110), 100);
|
// pathA = new Path.Circle(new Point(110, 110), 100);
|
||||||
// pathB = new Path.Circle(new Point(110, 110), 100 );
|
// pathB = new Path.Circle(new Point(110, 110), 100 );
|
||||||
|
// // pathB.translate([0.5,0])
|
||||||
// testBooleanStatic( pathA, pathB, caption );
|
// testBooleanStatic( pathA, pathB, caption );
|
||||||
|
|
||||||
caption = prepareTest( 'Maximum possible intersections between 2 cubic bezier curve segments - 9', container );
|
caption = prepareTest( 'Maximum possible intersections between 2 cubic bezier curve segments - 9', container );
|
||||||
|
@ -100,7 +101,9 @@ function runTests() {
|
||||||
group = paper.project.importSvg( document.getElementById( 'svggreenland' ) );
|
group = paper.project.importSvg( document.getElementById( 'svggreenland' ) );
|
||||||
pathA = group.children[0];
|
pathA = group.children[0];
|
||||||
pathB = group.children[1];
|
pathB = group.children[1];
|
||||||
pathB.scale( 0.75 ).translate( [25, 0] );
|
pathB.scale( 0.5, 1 ).translate( [25.5, 0] );
|
||||||
|
// pathA.scale( 2 );
|
||||||
|
// pathB.scale( 2 );
|
||||||
testBooleanStatic( pathA, pathB, caption );
|
testBooleanStatic( pathA, pathB, caption );
|
||||||
|
|
||||||
// window.p = pathB;
|
// window.p = pathB;
|
||||||
|
@ -139,12 +142,15 @@ var pathStyleBoolean = {
|
||||||
// Better if path1 and path2 fit nicely inside a 200x200 pixels rect
|
// Better if path1 and path2 fit nicely inside a 200x200 pixels rect
|
||||||
function testBooleanStatic( path1, path2, caption ) {
|
function testBooleanStatic( path1, path2, caption ) {
|
||||||
try{
|
try{
|
||||||
|
path1.style = path2.style = pathStyleNormal;
|
||||||
|
|
||||||
var _p1U = path1.clone().translate( [250, 0] );
|
var _p1U = path1.clone().translate( [250, 0] );
|
||||||
var _p2U = path2.clone().translate( [250, 0] );
|
var _p2U = path2.clone().translate( [250, 0] );
|
||||||
_p1U.style = _p2U.style = pathStyleBoolean;
|
_p1U.style = _p2U.style = pathStyleBoolean;
|
||||||
console.time( 'Union' );
|
console.time( 'Union' );
|
||||||
var boolPathU = boolUnion( _p1U, _p2U );
|
var boolPathU = boolUnion( _p1U, _p2U );
|
||||||
console.timeEnd( 'Union' );
|
console.timeEnd( 'Union' );
|
||||||
|
boolPathU.style = booleanStyle;
|
||||||
|
|
||||||
var _p1I = path1.clone().translate( [500, 0] );
|
var _p1I = path1.clone().translate( [500, 0] );
|
||||||
var _p2I = path2.clone().translate( [500, 0] );
|
var _p2I = path2.clone().translate( [500, 0] );
|
||||||
|
@ -152,6 +158,7 @@ function testBooleanStatic( path1, path2, caption ) {
|
||||||
console.time( 'Intersection' );
|
console.time( 'Intersection' );
|
||||||
var boolPathI = boolIntersection( _p1I, _p2I );
|
var boolPathI = boolIntersection( _p1I, _p2I );
|
||||||
console.timeEnd( 'Intersection' );
|
console.timeEnd( 'Intersection' );
|
||||||
|
boolPathI.style = booleanStyle;
|
||||||
|
|
||||||
var _p1S = path1.clone().translate( [750, 0] );
|
var _p1S = path1.clone().translate( [750, 0] );
|
||||||
var _p2S = path2.clone().translate( [750, 0] );
|
var _p2S = path2.clone().translate( [750, 0] );
|
||||||
|
@ -159,14 +166,12 @@ function testBooleanStatic( path1, path2, caption ) {
|
||||||
console.time( 'Subtraction' );
|
console.time( 'Subtraction' );
|
||||||
var boolPathS = boolSubtract( _p1S, _p2S );
|
var boolPathS = boolSubtract( _p1S, _p2S );
|
||||||
console.timeEnd( 'Subtraction' );
|
console.timeEnd( 'Subtraction' );
|
||||||
|
|
||||||
path1.style = path2.style = pathStyleNormal;
|
|
||||||
boolPathU.style = boolPathI.style = booleanStyle;
|
|
||||||
boolPathS.style = booleanStyle;
|
boolPathS.style = booleanStyle;
|
||||||
|
|
||||||
} catch( e ){
|
} catch( e ){
|
||||||
console.error( e.message );
|
console.error( e.name + ": " + e.message );
|
||||||
if( caption ) { caption.className += ' error'; }
|
if( caption ) { caption.className += ' error'; }
|
||||||
paper.project.view.element.className += ' hide';
|
// paper.project.view.element.className += ' hide';
|
||||||
} finally {
|
} finally {
|
||||||
console.timeEnd( 'Union' );
|
console.timeEnd( 'Union' );
|
||||||
console.timeEnd( 'Intersection' );
|
console.timeEnd( 'Intersection' );
|
||||||
|
@ -255,7 +260,8 @@ function annotateCurve( crv, t, c, tc, remove ) {
|
||||||
text.justification = 'center';
|
text.justification = 'center';
|
||||||
text.fillColor = tc;
|
text.fillColor = tc;
|
||||||
text.content = t;
|
text.content = t;
|
||||||
l.style.strokeColor = l2.style.strokeColor = cir.style.fillColor = c;
|
l.style.strokeColor = l2.style.strokeColor = c;
|
||||||
|
cir.style.fillColor = c;
|
||||||
if( remove ) {
|
if( remove ) {
|
||||||
l.removeOnMove();
|
l.removeOnMove();
|
||||||
l2.removeOnMove();
|
l2.removeOnMove();
|
||||||
|
|
Loading…
Reference in a new issue