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 ( 100 , 100 ) ) ;
2012-12-31 15:56:17 -05:00
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));" ) ;
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
2012-12-31 16:21:50 -05:00
test ( 'path.curves on Closed Paths' , function ( ) {
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 } }" ) ;
} ) ;
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
} ) ;
2012-11-23 11:47:42 -05:00
test ( 'Curve list after removing a segment - 1' , function ( ) {
var path = new paper . Path ( [ 0 , 0 ] , [ 1 , 1 ] , [ 2 , 2 ] ) ;
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 16:58:13 -05:00
equals ( function ( ) {
return path . segments [ 1 ] . remove ( ) ;
} , true , 'Removing the paths second segment should be succesfull.' ) ;
2012-11-23 11:47:42 -05:00
equals ( function ( ) {
return path . curves . length ;
} , 1 , 'After removing the middle segment, we should be left with one curve' ) ;
} ) ;
test ( 'Curve list after removing a segment - 2' , function ( ) {
var path = new paper . Path ( [ 0 , 0 ] , [ 1 , 1 ] , [ 2 , 2 ] ) ;
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 16:58:13 -05:00
equals ( function ( ) {
return path . segments [ 2 ] . remove ( ) ;
} , true , 'Removing the paths last segment should be succesfull.' ) ;
2012-11-23 11:47:42 -05:00
equals ( function ( ) {
return path . curves . length ;
} , 1 , 'After removing the last segment, we should be left with one curve' ) ;
} ) ;