Fix error in single segment closed path flatten

This commit is contained in:
sapics 2018-10-15 16:27:50 +09:00 committed by Jürg Lehni
parent 623c554dfe
commit e3ed85e395
3 changed files with 10 additions and 2 deletions

View file

@ -17,8 +17,9 @@ solid fixes, as we are paving the way for the upcoming release of `1.0.0`. Here
- Prevent `paper` object from polluting the global scope (#1544). - Prevent `paper` object from polluting the global scope (#1544).
- Make sure `Path#arcTo()` always passes through the provide through point - Make sure `Path#arcTo()` always passes through the provide through point
(#1477). (#1477).
- Draw shadows on `Raster` images (#1437) - Draw shadows on `Raster` images (#1437).
- Fix boolean operation edge case (#1506, #1513, #1515). - Fix boolean operation edge case (#1506, #1513, #1515).
- Fix single segment closed path flatten error (#1338, #1569).
- Remove memory leak on gradient colors (#1499). - Remove memory leak on gradient colors (#1499).
- Support alpha channel in CSS colors (#1468, #1539, #1565). - Support alpha channel in CSS colors (#1468, #1539, #1565).
- Improve color CSS string parsing and documentation. - Improve color CSS string parsing and documentation.

View file

@ -95,7 +95,7 @@ var PathFlattener = Base.extend({
segment1 = segment2; segment1 = segment2;
} }
if (path._closed) if (path._closed)
addCurve(segment2, segments[0]); addCurve(segment2 || segment1, segments[0]);
this.curves = curves; this.curves = curves;
this.parts = parts; this.parts = parts;
this.length = length; this.length = length;

View file

@ -450,6 +450,13 @@ test('Path#flatten(maxDistance)', function() {
}, true, 'The points of the last and before last segments should not be so close, that calling toString on them returns the same string value.'); }, true, 'The points of the last and before last segments should not be so close, that calling toString on them returns the same string value.');
}); });
test('Path#single segment closed path flatten (#1338)', function() {
var p = PathItem.create("m445.26701,223.69688c6.1738,8.7566 -7.05172,14.0468 0,0z");
p.strokeColor = "red";
p.flatten();
expect(0);
});
test('Path#curves after removing a segment - 1', function() { test('Path#curves after removing a segment - 1', function() {
var path = new paper.Path([0, 0], [1, 1], [2, 2]); var path = new paper.Path([0, 0], [1, 1], [2, 2]);
var prevCurves = path.curves.slice(); var prevCurves = path.curves.slice();