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-02-17 10:00:20 -05:00
|
|
|
module('Compound Path');
|
|
|
|
|
|
|
|
test('moveTo / lineTo', function() {
|
|
|
|
var path = new CompoundPath();
|
|
|
|
|
|
|
|
var lists = [
|
|
|
|
[new Point(279, 151), new Point(149, 151), new Point(149, 281), new Point(279, 281)],
|
|
|
|
[new Point(319, 321), new Point(109, 321), new Point(109, 111), new Point(319, 111)]
|
|
|
|
];
|
|
|
|
|
|
|
|
for (var i = 0; i < lists.length; i++) {
|
|
|
|
var list = lists[i];
|
|
|
|
for (var j = 0; j < list.length; j++) {
|
2014-03-04 03:48:41 -05:00
|
|
|
path[j === 0 ? 'moveTo' : 'lineTo'](list[j]);
|
2011-02-17 10:00:20 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
path.fillColor = 'black';
|
2011-07-07 10:09:02 -04:00
|
|
|
|
2011-05-07 12:46:06 -04:00
|
|
|
equals(function() {
|
|
|
|
return path.children.length;
|
2011-05-15 14:09:34 -04:00
|
|
|
}, 2);
|
|
|
|
});
|
2011-05-15 14:10:12 -04:00
|
|
|
|
|
|
|
test('clockwise', function() {
|
|
|
|
var path1 = new Path.Rectangle([200, 200], [100, 100]);
|
|
|
|
var path2 = new Path.Rectangle([50, 50], [200, 200]);
|
|
|
|
var path3 = new Path.Rectangle([0, 0], [400, 400]);
|
|
|
|
|
|
|
|
equals(function() {
|
|
|
|
return path1.clockwise;
|
|
|
|
}, true);
|
|
|
|
equals(function() {
|
|
|
|
return path2.clockwise;
|
|
|
|
}, true);
|
|
|
|
equals(function() {
|
|
|
|
return path3.clockwise;
|
|
|
|
}, true);
|
|
|
|
|
2011-05-16 15:16:51 -04:00
|
|
|
var compound = new CompoundPath(path1, path2, path3);
|
2011-05-15 14:10:12 -04:00
|
|
|
|
2011-05-16 15:16:51 -04:00
|
|
|
equals(function() {
|
|
|
|
return compound.lastChild == path3;
|
|
|
|
}, true);
|
|
|
|
equals(function() {
|
|
|
|
return compound.firstChild == path1;
|
|
|
|
}, true);
|
2011-05-15 14:10:12 -04:00
|
|
|
equals(function() {
|
|
|
|
return path1.clockwise;
|
|
|
|
}, true);
|
|
|
|
equals(function() {
|
|
|
|
return path2.clockwise;
|
2011-07-28 06:06:29 -04:00
|
|
|
}, false);
|
2011-05-15 14:10:12 -04:00
|
|
|
equals(function() {
|
|
|
|
return path3.clockwise;
|
|
|
|
}, false);
|
2012-12-01 14:14:13 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
test('Cloning with non-standard clockwise settings', function() {
|
|
|
|
var path1 = new Path.Rectangle([200, 200], [100, 100]);
|
|
|
|
var path2 = new Path.Rectangle([50, 50], [200, 200]);
|
|
|
|
var path3 = new Path.Rectangle([0, 0], [400, 400]);
|
|
|
|
path1.clockwise = false;
|
|
|
|
path2.clockwise = true;
|
|
|
|
path3.clockwise = true;
|
|
|
|
var compound = new CompoundPath(path1, path2, path3);
|
|
|
|
equals(function() {
|
|
|
|
return path1.clockwise;
|
|
|
|
}, false);
|
|
|
|
equals(function() {
|
|
|
|
return path2.clockwise;
|
|
|
|
}, true);
|
|
|
|
equals(function() {
|
|
|
|
return path3.clockwise;
|
|
|
|
}, true);
|
2014-04-06 07:48:03 -04:00
|
|
|
});
|