2011-07-01 06:17:45 -04:00
|
|
|
/*
|
|
|
|
* Paper.js
|
|
|
|
*
|
|
|
|
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
|
|
|
|
* based on Scriptographer.org and designed to be largely API compatible.
|
|
|
|
* http://paperjs.org/
|
|
|
|
* http://scriptographer.org/
|
|
|
|
*
|
|
|
|
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
|
|
*
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2011-05-02 19:25:23 -04:00
|
|
|
module('Path Curves');
|
|
|
|
|
|
|
|
test('path.curves Synchronisation', function() {
|
|
|
|
var path = new Path();
|
|
|
|
|
|
|
|
path.add(new Point(0, 100));
|
2011-05-04 14:40:52 -04:00
|
|
|
equals(path.segments.toString(), "{ point: { x: 0, y: 100 } }", "path.segments: path.add(new Point(0, 100));");
|
|
|
|
equals(path.curves.toString(), "", "path.curves: path.add(new Point(0, 100));");
|
2011-05-02 19:25:23 -04:00
|
|
|
path.add(new Point(100, 100));
|
2011-05-04 14:40:52 -04:00
|
|
|
equals(path.segments.toString(), "{ point: { x: 0, y: 100 } },{ point: { x: 100, y: 100 } }", "path.segments: path.add(new Point(100, 100));");
|
|
|
|
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, point2: { x: 100, y: 100 } }", "path.curves: path.add(new Point(100, 100));");
|
2011-05-04 13:42:40 -04:00
|
|
|
path.insert(1, {point:[50, 0], handleIn:[-25, 0], handleOut:[25, 0]});
|
2011-05-04 14:40:52 -04:00
|
|
|
equals(path.segments.toString(), "{ point: { x: 0, y: 100 } },{ point: { x: 50, y: 0 }, handleIn: { x: -25, y: 0 }, handleOut: { x: 25, y: 0 } },{ point: { x: 100, y: 100 } }", "path.segments: path.insert(1, {point:[50, 0], handleIn:[-25, 0], handleOut:[25, 0]});");
|
|
|
|
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, handle2: { x: -25, y: 0 }, point2: { x: 50, y: 0 } },{ point1: { x: 50, y: 0 }, handle1: { x: 25, y: 0 }, point2: { x: 100, y: 100 } }", "path.curves: path.insert(1, {point:[50, 0], handleIn:[-25, 0], handleOut:[25, 0]});");
|
2011-05-02 19:25:23 -04:00
|
|
|
path.closed = true;
|
2011-05-04 14:40:52 -04:00
|
|
|
equals(path.segments.toString(), "{ point: { x: 0, y: 100 } },{ point: { x: 50, y: 0 }, handleIn: { x: -25, y: 0 }, handleOut: { x: 25, y: 0 } },{ point: { x: 100, y: 100 } }", "path.segments: path.closed = true;");
|
|
|
|
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, handle2: { x: -25, y: 0 }, point2: { x: 50, y: 0 } },{ point1: { x: 50, y: 0 }, handle1: { x: 25, y: 0 }, point2: { x: 100, y: 100 } },{ point1: { x: 100, y: 100 }, point2: { x: 0, y: 100 } }", "path.curves: path.closed = true;");
|
2011-05-02 19:25:23 -04:00
|
|
|
path.removeSegments(2, 3);
|
2011-05-04 14:40:52 -04:00
|
|
|
equals(path.segments.toString(), "{ point: { x: 0, y: 100 } },{ point: { x: 50, y: 0 }, handleIn: { x: -25, y: 0 }, handleOut: { x: 25, y: 0 } }", "path.segments: path.removeSegments(2, 3);");
|
|
|
|
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, handle2: { x: -25, y: 0 }, point2: { x: 50, y: 0 } },{ point1: { x: 50, y: 0 }, handle1: { x: 25, y: 0 }, point2: { x: 0, y: 100 } }", "path.curves: path.removeSegments(2, 3);");
|
2011-05-02 19:25:23 -04:00
|
|
|
path.add(new Point(100, 100));
|
|
|
|
path.removeSegments(1, 2);
|
2011-05-04 14:40:52 -04:00
|
|
|
equals(path.segments.toString(), "{ point: { x: 0, y: 100 } },{ point: { x: 100, y: 100 } }", "path.segments: path.add(new Point(100, 100));\npath.removeSegments(1, 2);");
|
|
|
|
equals(path.curves.toString(), "{ point1: { x: 0, y: 100 }, point2: { x: 100, y: 100 } },{ point1: { x: 100, y: 100 }, point2: { x: 0, y: 100 } }", "path.curves: path.add(new Point(100, 100));\npath.removeSegments(1, 2);");
|
2012-03-17 13:08:06 -04:00
|
|
|
|
|
|
|
// Transform the path, and the curves length should be invalidated (first, force-cache the first segment's length by accessing it
|
|
|
|
path.curves[0].length;
|
2012-03-17 15:54:18 -04:00
|
|
|
ok(path.curves[0]._length, 'Curve length does not appear to be cached');
|
2012-03-17 13:08:06 -04:00
|
|
|
path.scale(2, [0, 0]);
|
2012-04-25 14:47:53 -04:00
|
|
|
equals(path.curves[0].length, 200, 'Curve length should be updated when path is transformed');
|
2011-05-02 19:25:23 -04:00
|
|
|
});
|
2011-06-05 15:26:36 -04:00
|
|
|
|
2011-06-20 13:17:07 -04:00
|
|
|
test('path.flatten(maxDistance)', function() {
|
2011-06-05 15:26:36 -04:00
|
|
|
var path = new Path.Circle(new Size(80, 50), 35);
|
|
|
|
|
|
|
|
// Convert its curves to points, with a max distance of 20:
|
2011-06-20 13:17:07 -04:00
|
|
|
path.flatten(20);
|
2011-06-05 15:26:36 -04:00
|
|
|
|
|
|
|
equals(function() {
|
|
|
|
return path.lastSegment.point.equals(path.firstSegment.point);
|
|
|
|
}, false, 'The points of the last and first segments should not be the same.');
|
2011-07-07 10:09:02 -04:00
|
|
|
|
2011-06-05 15:26:36 -04:00
|
|
|
equals(function() {
|
|
|
|
return path.lastSegment.point.toString() != path.segments[path.segments.length - 2].point.toString();
|
|
|
|
}, 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.');
|
2012-03-17 13:08:06 -04:00
|
|
|
});
|