paper.js/test/tests/CompoundPath.js

72 lines
1.8 KiB
JavaScript
Raw Permalink Normal View History

2011-07-01 06:17:45 -04:00
/*
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
2011-07-01 06:17:45 -04:00
* http://paperjs.org/
*
* Copyright (c) 2011 - 2020, Jürg Lehni & Jonathan Puckey
* http://juerglehni.com/ & https://puckey.studio/
2011-07-01 06:17:45 -04:00
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
QUnit.module('Compound Path');
2011-02-17 10:00:20 -05:00
test('moveTo() / lineTo()', function() {
2014-08-16 13:24:54 -04:00
var path = new CompoundPath();
2011-02-17 10:00:20 -05:00
2014-08-16 13:24:54 -04:00
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)]
];
2011-02-17 10:00:20 -05:00
2014-08-16 13:24:54 -04:00
for (var i = 0; i < lists.length; i++) {
var list = lists[i];
for (var j = 0; j < list.length; j++) {
path[!j ? 'moveTo' : 'lineTo'](list[j]);
2014-08-16 13:24:54 -04:00
}
}
2011-02-17 10:00:20 -05:00
2014-08-16 13:24:54 -04:00
path.fillColor = 'black';
2011-07-07 10:09:02 -04:00
2014-08-16 13:24:54 -04:00
equals(function() {
return path.children.length;
}, 2);
});
test('CompoundPath#reorient()', function() {
var path1 = new Path.Rectangle([300, 300], [100, 100]);
2014-08-16 13:24:54 -04:00
var path2 = new Path.Rectangle([50, 50], [200, 200]);
var path3 = new Path.Rectangle([0, 0], [500, 500]);
2014-08-16 13:24:54 -04:00
equals(function() {
return path1.clockwise;
}, true);
equals(function() {
return path2.clockwise;
}, true);
equals(function() {
return path3.clockwise;
}, true);
var compound = new CompoundPath({
children: [path1, path2, path3],
}).reorient();
2014-08-16 13:24:54 -04:00
equals(function() {
return compound.lastChild == path3;
}, true);
equals(function() {
return compound.firstChild == path1;
}, true);
equals(function() {
return path1.clockwise;
}, false);
equals(function() {
return path2.clockwise;
}, false);
2014-08-16 13:24:54 -04:00
equals(function() {
return path3.clockwise;
}, true);
});