2011-07-01 06:17:45 -04:00
/ *
2013-01-28 21:03:27 -05:00
* Paper . js - The Swiss Army Knife of Vector Graphics Scripting .
2011-07-01 06:17:45 -04:00
* http : //paperjs.org/
*
2014-01-03 19:47:16 -05:00
* Copyright ( c ) 2011 - 2014 , Juerg Lehni & Jonathan Puckey
* http : //scratchdisk.com/ & http://jonathanpuckey.com/
2011-07-01 06:17:45 -04:00
*
* Distributed under the MIT license . See LICENSE file for details .
*
* All rights reserved .
* /
2011-05-02 19:25:23 -04:00
module ( 'Path Curves' ) ;
2013-04-26 11:46:57 -04:00
test ( 'path.curves synchronisation' , function ( ) {
2014-08-16 13:24:54 -04:00
var path = new Path ( ) ;
path . add ( new Point ( 100 , 100 ) ) ;
equals ( path . segments . toString ( ) , "{ point: { x: 100, y: 100 } }" , "path.segments: path.add(new Point(100, 100));" ) ;
equals ( path . curves . toString ( ) , "" , "path.curves: path.add(new Point(100, 100));" ) ;
path . insert ( 0 , new Point ( 0 , 100 ) ) ;
equals ( path . segments . toString ( ) , "{ point: { x: 0, y: 100 } },{ point: { x: 100, y: 100 } }" , "path.segments: path.insert(0, new Point(0, 100));" ) ;
equals ( path . curves . toString ( ) , "{ point1: { x: 0, y: 100 }, point2: { x: 100, y: 100 } }" , "path.curves: path.insert(0, new Point(0, 100));" ) ;
path . insert ( 1 , { point : [ 50 , 0 ] , handleIn : [ - 25 , 0 ] , handleOut : [ 25 , 0 ] } ) ;
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]});" ) ;
path . closed = true ;
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;" ) ;
path . removeSegments ( 2 , 3 ) ;
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);" ) ;
path . add ( new Point ( 100 , 100 ) ) ;
path . removeSegments ( 1 , 2 ) ;
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);" ) ;
// Transform the path, and the curves length should be invalidated (first, force-cache the first segment's length by accessing it
var length = path . curves [ 0 ] . length ;
ok ( path . curves [ 0 ] . _length , 'Curve length does not appear to be cached' ) ;
path . scale ( 2 , [ 0 , 0 ] ) ;
2014-11-30 14:27:14 -05:00
equals ( path . curves [ 0 ] . length , 200 , 'Curve length should be updated when path is transformed' ) ;
2014-08-16 13:24:54 -04:00
var points = [ ] ;
for ( var i = 0 ; i < 40 ; i ++ )
points . push ( Point . random ( ) ) ;
var path = new Path ( points ) ;
equals ( path . segments . length , 40 , 'segments.length' ) ;
equals ( path . curves . length , 39 , 'curves.length' ) ;
path . removeSegments ( ) ;
equals ( path . segments . length , 0 , 'segments.length' ) ;
equals ( path . curves . length , 0 , 'curves.length' ) ;
2011-05-02 19:25:23 -04:00
} ) ;
2011-06-05 15:26:36 -04:00
2013-04-26 11:46:57 -04:00
test ( 'path.curves on closed paths' , function ( ) {
2014-08-16 13:24:54 -04:00
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 } }" ) ;
path . removeSegments ( 0 , 1 ) ;
equals ( path . curves . toString ( ) , "{ 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: -55.22847, y: 0 }, point2: { x: 100, y: 0 } }" ) ;
2012-12-31 16:21:50 -05:00
} ) ;
2011-06-20 13:17:07 -04:00
test ( 'path.flatten(maxDistance)' , function ( ) {
2014-08-16 13:24:54 -04:00
var path = new Path . Circle ( new Size ( 80 , 50 ) , 35 ) ;
2011-06-05 15:26:36 -04:00
2014-08-16 13:24:54 -04:00
// Convert its curves to points, with a max distance of 20:
path . flatten ( 20 ) ;
2011-06-05 15:26:36 -04:00
2014-08-16 13:24:54 -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
2014-08-16 13:24:54 -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
} ) ;
2012-11-23 11:47:42 -05:00
test ( 'Curve list after removing a segment - 1' , function ( ) {
2014-08-16 13:24:54 -04:00
var path = new paper . Path ( [ 0 , 0 ] , [ 1 , 1 ] , [ 2 , 2 ] ) ;
2012-11-23 11:47:42 -05:00
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
return path . curves . length ;
} , 2 , 'After creating a path with three segments, we should have two curves. By accessing path.curves we also make sure the curves are created internally.' ) ;
2012-11-23 11:47:42 -05:00
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
return path . segments [ 1 ] . remove ( ) ;
} , true , 'Removing the paths second segment should be succesfull.' ) ;
2012-11-23 16:58:13 -05:00
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
return path . curves . length ;
} , 1 , 'After removing the middle segment, we should be left with one curve' ) ;
2012-11-23 11:47:42 -05:00
} ) ;
test ( 'Curve list after removing a segment - 2' , function ( ) {
2014-08-16 13:24:54 -04:00
var path = new paper . Path ( [ 0 , 0 ] , [ 1 , 1 ] , [ 2 , 2 ] ) ;
2012-11-23 11:47:42 -05:00
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
return path . curves . length ;
} , 2 , 'After creating a path with three segments, we should have two curves. By accessing path.curves we also make sure the curves are created internally.' ) ;
2012-11-23 11:47:42 -05:00
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
return path . segments [ 2 ] . remove ( ) ;
2015-10-24 11:00:37 -04:00
} , true , 'Removing the paths last segment should be successful.' ) ;
2012-11-23 11:47:42 -05:00
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
return path . curves . length ;
2015-10-24 12:11:30 -04:00
} , 1 , 'After removing the last segment, we should be left with one curve.' ) ;
2015-10-24 11:00:37 -04:00
2015-10-24 12:11:30 -04:00
path . addSegment ( [ 3 , 3 ] ) ;
2015-10-24 11:00:37 -04:00
equals ( function ( ) {
return path . curves . length ;
2015-10-24 12:11:30 -04:00
} , 2 , 'After adding a new segment at the end, we should have two curves again.' ) ;
2015-10-24 11:42:36 -04:00
equals ( function ( ) {
return path . curves [ 1 ] . segment1 === path . curves [ 0 ] . segment2 ;
2015-10-24 12:11:30 -04:00
} , true , "The newly created curve's first segment needs to be the same as the previous curve's second segment." ) ;
path . addSegments ( [ [ 4 , 4 ] , [ 5 , 5 ] ] ) ;
equals ( function ( ) {
return path . curves . length ;
} , 4 , 'After adding tow new segments at the end, we should have four curves now.' ) ;
2013-03-16 13:08:31 -04:00
} ) ;
2015-09-06 06:47:35 -04:00
test ( 'Splitting a straight path should produce segments without handles' , function ( ) {
var path1 = new Path . Line ( [ 0 , 0 ] , [ 50 , 50 ] ) ;
var path2 = path1 . split ( 0 , 0.5 ) ;
2014-08-16 13:24:54 -04:00
equals ( function ( ) {
2015-09-06 06:47:35 -04:00
return ! path1 . lastSegment . hasHandles ( ) && ! path2 . firstSegment . hasHandles ( ) ;
2014-08-16 13:24:54 -04:00
} , true ) ;
2013-03-16 13:08:31 -04:00
} ) ;
2015-10-24 10:38:13 -04:00
test ( 'Splitting a path with one curve in the middle result in two paths of the same length with one curve each' , function ( ) {
var path1 = new Path . Line ( [ 0 , 0 ] , [ 100 , 100 ] ) ;
var path2 = path1 . split ( path1 . getLocationAt ( path1 . length / 2 ) ) ;
equals ( function ( ) {
return path1 . curves . length ;
} , 1 ) ;
equals ( function ( ) {
return path2 . curves . length ;
} , 1 ) ;
equals ( function ( ) {
return path1 . length === path2 . length ;
} , true ) ;
} ) ;