mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Partly revert 09785a504b
To make the edge-case in #1239 work again. Also add unit tests for edge-case.
This commit is contained in:
parent
fa43e28b7a
commit
cf2ebbaaf8
3 changed files with 50 additions and 46 deletions
|
@ -161,7 +161,7 @@ var Numerical = new function() {
|
||||||
* The epsilon to be used when comparing curve-time parameters in the
|
* The epsilon to be used when comparing curve-time parameters in the
|
||||||
* fat-line clipping code.
|
* fat-line clipping code.
|
||||||
*/
|
*/
|
||||||
CLIPPING_EPSILON: 1e-10,
|
CLIPPING_EPSILON: 1e-9,
|
||||||
/**
|
/**
|
||||||
* Kappa is the value which which to scale the curve handles when
|
* Kappa is the value which which to scale the curve handles when
|
||||||
* drawing a circle with bezier curves.
|
* drawing a circle with bezier curves.
|
||||||
|
|
|
@ -786,6 +786,14 @@ test('#1123', function() {
|
||||||
'M100,200v-100h100v100zM180,180v-60h-60v60z');
|
'M100,200v-100h100v100zM180,180v-60h-60v60z');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('#1239', function() {
|
||||||
|
var p1 = new Path([[890.91, 7.52, 0, 0, 85.40999999999997, 94.02], [1024, 351.78, 0, -127.03999999999996, 0, 127.14999999999998], [890.69, 696.28, 85.54999999999995, -94.03999999999996, 0, 0], [843.44, 653.28, 0, 0, 75.20000000000005, -82.66999999999996], [960, 351.78, 0, 111.75, 0, -111.63], [843.65, 50.51999999999998, 75.07000000000005, 82.63999999999999, 0, 0], true]);
|
||||||
|
var p2 = new Path([[960, 352, -0.05999999999994543, 111.67999999999995, 0, 0], [1024, 352, 0, 0, -0.05999999999994543, 127.07], [890.69, 696.28, 85.5, -93.98000000000002, 0, 0], [843.44, 653.28, 0, 0, 75.14999999999998, -82.61000000000001], true]);
|
||||||
|
project.activeLayer.scale(0.25);
|
||||||
|
compareBoolean(function() { return p1.unite(p2); },
|
||||||
|
'M923.0175,265.805c21.3525,23.505 33.2725,54.305 33.2725,86.065c0,0.01833 0,0.03667 -0.00001,0.055h0.00001c-0.00005,0.10258 -0.00022,0.20515 -0.00052,0.3077c-0.06338,22.18242 -5.9393,43.88534 -16.78017,62.94682c-4.63138,8.14369 -10.16899,15.8051 -16.54682,22.81548l-11.8125,-10.75c8.97181,-9.86302 16.01692,-21.11585 20.93099,-33.22212c5.34364,-13.16533 8.16725,-27.34044 8.20856,-41.83592c0.0003,-0.10564 0.00044,-0.21129 0.00044,-0.31697c0,-27.9075 -10.32,-54.655 -29.0875,-75.315z');
|
||||||
|
});
|
||||||
|
|
||||||
test('frame.intersect(rect);', function() {
|
test('frame.intersect(rect);', function() {
|
||||||
var frame = new CompoundPath();
|
var frame = new CompoundPath();
|
||||||
frame.addChild(new Path.Rectangle(new Point(140, 10), [100, 300]));
|
frame.addChild(new Path.Rectangle(new Point(140, 10), [100, 300]));
|
||||||
|
|
|
@ -107,18 +107,14 @@ test('circle and square (existing segments overlaps on curves)', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
test('#904', function() {
|
test('#904', function() {
|
||||||
var path1 = new Path({
|
var path1 = new Path([
|
||||||
segments: [
|
|
||||||
[347.65684372173973, 270.4315945523045, 0, 0, 22.844385382059784, -25.115215946843847],
|
[347.65684372173973, 270.4315945523045, 0, 0, 22.844385382059784, -25.115215946843847],
|
||||||
[383.0588370772214, 178.9392357483178, -0.025514950166041217, 33.94338870431889, 0, 0],
|
[383.0588370772214, 178.9392357483178, -0.025514950166041217, 33.94338870431889, 0, 0],
|
||||||
]
|
]);
|
||||||
});
|
var path2 = new Path([
|
||||||
var path2 = new Path({
|
|
||||||
segments: [
|
|
||||||
[347.65684372173973, 270.4315945523045, 0, 0, 22.869900332225882, -25.136478405315614],
|
[347.65684372173973, 270.4315945523045, 0, 0, 22.869900332225882, -25.136478405315614],
|
||||||
[383.0588370772214, 178.84568093104204, 0, 33.97740863787374, 0, -33.93913621262462],
|
[383.0588370772214, 178.84568093104204, 0, 33.97740863787374, 0, -33.93913621262462],
|
||||||
]
|
]);
|
||||||
});
|
|
||||||
|
|
||||||
testIntersection(path1.getIntersections(path2), [
|
testIntersection(path1.getIntersections(path2), [
|
||||||
{ point: { x: 347.65684, y: 270.43159 }, index: 0, time: 0, crossing: false },
|
{ point: { x: 347.65684, y: 270.43159 }, index: 0, time: 0, crossing: false },
|
||||||
|
@ -127,18 +123,14 @@ test('#904', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
test('#1066', function() {
|
test('#1066', function() {
|
||||||
var path1 = new Path({
|
var path1 = new Path([
|
||||||
segments: [
|
|
||||||
[230.4447915660904, 300],
|
[230.4447915660904, 300],
|
||||||
[230.4447915660904, 180]
|
[230.4447915660904, 180]
|
||||||
]
|
]);
|
||||||
});
|
var path2 = new Path([
|
||||||
var path2 = new Path({
|
|
||||||
segments: [
|
|
||||||
[221.5842044289023, 189.47264666691018, 0, 0, 9.363067822501023, 28.089207003036847],
|
[221.5842044289023, 189.47264666691018, 0, 0, 9.363067822501023, 28.089207003036847],
|
||||||
[249.67341143193917, 273.74026767602066, -9.363067822501023, -28.08920700303679, 0, 0]
|
[249.67341143193917, 273.74026767602066, -9.363067822501023, -28.08920700303679, 0, 0]
|
||||||
]
|
]);
|
||||||
});
|
|
||||||
testIntersection(path1.getIntersections(path2), [
|
testIntersection(path1.getIntersections(path2), [
|
||||||
{ point: { x: 230.44479, y: 216.05441 }, index: 0, time: 0.63642, crossing: true }
|
{ point: { x: 230.44479, y: 216.05441 }, index: 0, time: 0.63642, crossing: true }
|
||||||
]);
|
]);
|
||||||
|
@ -178,43 +170,47 @@ test('#1165', function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
test('#1174', function() {
|
test('#1174', function() {
|
||||||
var path1 = new paper.Path({
|
var path1 = new Path([
|
||||||
segments: [
|
|
||||||
[20, 60],
|
[20, 60],
|
||||||
[20, 100],
|
[20, 100],
|
||||||
[150, 100]
|
[150, 100]
|
||||||
]
|
]);
|
||||||
});
|
var path2 = new Path([
|
||||||
var path2 = new paper.Path({
|
|
||||||
segments: [
|
|
||||||
[20, 140],
|
[20, 140],
|
||||||
[20, 100.00000001],
|
[20, 100.00000001],
|
||||||
[150, 98]
|
[150, 98]
|
||||||
]
|
]);
|
||||||
});
|
|
||||||
testIntersection(path1.getIntersections(path2), [
|
testIntersection(path1.getIntersections(path2), [
|
||||||
{ point: { x: 20, y: 100 }, index: 1, time: 0.00004, crossing: true }
|
{ point: { x: 20, y: 100 }, index: 1, time: 0.00004, crossing: true }
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('#1197', function() {
|
test('#1197', function() {
|
||||||
var path1 = new Path({
|
var path1 = new Path([
|
||||||
segments: [
|
|
||||||
[99, 106],
|
[99, 106],
|
||||||
[99, 200]
|
[99, 200]
|
||||||
],
|
]);
|
||||||
strokeColor: 'green'
|
var path2 = new Path([
|
||||||
});
|
|
||||||
|
|
||||||
var path2 = new Path({
|
|
||||||
segments: [
|
|
||||||
[100, 193, 0, 0, 0, -28],
|
[100, 193, 0, 0, 0, -28],
|
||||||
[140, 106, -52, -12, 0, 0]
|
[140, 106, -52, -12, 0, 0]
|
||||||
],
|
]);
|
||||||
strokeColor: 'red'
|
|
||||||
});
|
|
||||||
testIntersection(path1.getIntersections(path2), [
|
testIntersection(path1.getIntersections(path2), [
|
||||||
{ point: { x: 99, y: 148.74959 }, index: 0, time: 0.46982, crossing: true },
|
{ point: { x: 99, y: 148.74959 }, index: 0, time: 0.46982, crossing: true },
|
||||||
{ point: { x: 99, y: 167.82203 }, index: 0, time: 0.60674, crossing: true }
|
{ point: { x: 99, y: 167.82203 }, index: 0, time: 0.60674, crossing: true }
|
||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('#1239', function() {
|
||||||
|
var p1 = new Path([[890.91, 7.52, 0, 0, 85.40999999999997, 94.02], [1024, 351.78, 0, -127.03999999999996, 0, 127.14999999999998], [890.69, 696.28, 85.54999999999995, -94.03999999999996, 0, 0], [843.44, 653.28, 0, 0, 75.20000000000005, -82.66999999999996], [960, 351.78, 0, 111.75, 0, -111.63], [843.65, 50.51999999999998, 75.07000000000005, 82.63999999999999, 0, 0], true]);
|
||||||
|
var p2 = new Path([[960, 352, -0.05999999999994543, 111.67999999999995, 0, 0], [1024, 352, 0, 0, -0.05999999999994543, 127.07], [890.69, 696.28, 85.5, -93.98000000000002, 0, 0], [843.44, 653.28, 0, 0, 75.14999999999998, -82.61000000000001], true]);
|
||||||
|
project.activeLayer.scale(0.25);
|
||||||
|
testIntersection(p1.getIntersections(p2), [
|
||||||
|
{ point: { x: 956.28999, y: 351.925 }, index: 1, time: 0.000577, crossing: true},
|
||||||
|
{ point: { x: 956.28948, y: 352.2327 }, index: 1, time: 0.003804, crossing: true},
|
||||||
|
{ point: { x: 939.50932, y: 415.17952 }, index: 1, time: 0.701801, crossing: true},
|
||||||
|
{ point: { x: 922.9625, y: 437.995 }, index: 2, time: 0, crossing: false},
|
||||||
|
{ point: { x: 911.15, y: 427.245 }, index: 3, time: 0, crossing: false},
|
||||||
|
{ point: { x: 932.08099, y: 394.02288 }, index: 3, time: 0.477224, crossing: true},
|
||||||
|
{ point: { x: 940.28956, y: 352.18697 }, index: 3, time: 0.996218, crossing: true}
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
Loading…
Reference in a new issue