mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
Fix issue in Path#removeSegments() where curves are removed wrongly when start index is 0.
Closes #200.
This commit is contained in:
parent
24443c548a
commit
06ffd8089d
2 changed files with 6 additions and 4 deletions
|
@ -684,7 +684,9 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
|
||||||
// one to the left of the segment, not to the right, as normally).
|
// one to the left of the segment, not to the right, as normally).
|
||||||
// Also take into account closed paths, which have one curve more
|
// Also take into account closed paths, which have one curve more
|
||||||
// than segments.
|
// than segments.
|
||||||
var index = to == count + (this._closed ? 1 : 0) ? from - 1 : from,
|
var index = from > 0 && to === count + (this._closed ? 1 : 0)
|
||||||
|
? from - 1
|
||||||
|
: from,
|
||||||
curves = curves.splice(index, amount);
|
curves = curves.splice(index, amount);
|
||||||
// Return the removed curves as well, if we're asked to include
|
// Return the removed curves as well, if we're asked to include
|
||||||
// them, but exclude the first curve, since that's shared with the
|
// them, but exclude the first curve, since that's shared with the
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
|
|
||||||
module('Path Curves');
|
module('Path Curves');
|
||||||
|
|
||||||
test('path.curves Synchronisation', function() {
|
test('path.curves synchronisation', function() {
|
||||||
var path = new Path();
|
var path = new Path();
|
||||||
|
|
||||||
path.add(new Point(100, 100));
|
path.add(new Point(100, 100));
|
||||||
|
@ -52,7 +52,7 @@ test('path.curves Synchronisation', function() {
|
||||||
equals(path.curves.length, 0, 'curves.length');
|
equals(path.curves.length, 0, 'curves.length');
|
||||||
});
|
});
|
||||||
|
|
||||||
test('path.curves on Closed Paths', function() {
|
test('path.curves on closed paths', function() {
|
||||||
var path = new Path.Circle(new Point(100, 100) , 100);
|
var path = new Path.Circle(new Point(100, 100) , 100);
|
||||||
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, handle1: { x: 0, y: -55.22847 }, handle2: { x: -55.22847, y: 0 }, point2: { x: 100, y: 0 } },{ point1: { x: 100, y: 0 }, handle1: { x: 55.22847, y: 0 }, handle2: { x: 0, y: -55.22847 }, point2: { x: 200, y: 100 } },{ point1: { x: 200, y: 100 }, handle1: { x: 0, y: 55.22847 }, handle2: { x: 55.22847, y: 0 }, point2: { x: 100, y: 200 } },{ point1: { x: 100, y: 200 }, handle1: { x: -55.22847, y: 0 }, handle2: { x: 0, y: 55.22847 }, point2: { x: 0, y: 100 } }");
|
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, handle1: { x: 0, y: -55.22847 }, handle2: { x: -55.22847, y: 0 }, point2: { x: 100, y: 0 } },{ point1: { x: 100, y: 0 }, handle1: { x: 55.22847, y: 0 }, handle2: { x: 0, y: -55.22847 }, point2: { x: 200, y: 100 } },{ point1: { x: 200, y: 100 }, handle1: { x: 0, y: 55.22847 }, handle2: { x: 55.22847, y: 0 }, point2: { x: 100, y: 200 } },{ point1: { x: 100, y: 200 }, handle1: { x: -55.22847, y: 0 }, handle2: { x: 0, y: 55.22847 }, point2: { x: 0, y: 100 } }");
|
||||||
path.removeSegments(0, 1);
|
path.removeSegments(0, 1);
|
||||||
|
@ -111,6 +111,6 @@ test('Splitting a straight path should produce linear segments', function() {
|
||||||
var path = new Path.Line([0, 0], [50, 50]);
|
var path = new Path.Line([0, 0], [50, 50]);
|
||||||
var path2 = path.split(0, 0.5);
|
var path2 = path.split(0, 0.5);
|
||||||
equals(function() {
|
equals(function() {
|
||||||
return path2.firstSegment.linear
|
return path2.firstSegment.linear;
|
||||||
}, true);
|
}, true);
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue