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/
|
|
|
|
*
|
2018-12-27 02:13:01 -05:00
|
|
|
* Copyright (c) 2011 - 2019, Juerg Lehni & Jonathan Puckey
|
2018-11-10 02:19:34 -05:00
|
|
|
* http://scratchdisk.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.
|
|
|
|
*/
|
|
|
|
|
2016-01-27 13:57:07 -05:00
|
|
|
QUnit.module('Group');
|
2011-02-12 13:12:23 -05:00
|
|
|
|
|
|
|
test('new Group()', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
var group = new Group();
|
|
|
|
equals(function() {
|
|
|
|
return paper.project.activeLayer.children[0] == group;
|
|
|
|
}, true);
|
2011-02-12 13:12:23 -05:00
|
|
|
});
|
|
|
|
|
2012-11-06 12:07:11 -05:00
|
|
|
test('new Group([])', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
var group = new Group([]);
|
|
|
|
equals(function() {
|
|
|
|
return paper.project.activeLayer.children[0] == group;
|
|
|
|
}, true);
|
|
|
|
equals(function() {
|
|
|
|
return group.children.length;
|
|
|
|
}, 0);
|
2012-11-06 12:07:11 -05:00
|
|
|
});
|
|
|
|
|
2011-02-12 13:12:23 -05:00
|
|
|
test('new Group([item])', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
var path = new Path();
|
|
|
|
var group = new Group([path]);
|
|
|
|
equals(function() {
|
|
|
|
return paper.project.activeLayer.children.length;
|
|
|
|
}, 1);
|
|
|
|
equals(function() {
|
|
|
|
return group.children[0] == path;
|
|
|
|
}, true);
|
2011-02-16 18:34:16 -05:00
|
|
|
});
|
|
|
|
|
2013-03-03 08:20:45 -05:00
|
|
|
test('new Group({children:[item]})', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
var path = new Path();
|
|
|
|
var group = new Group({
|
|
|
|
children: [path]
|
|
|
|
});
|
|
|
|
equals(function() {
|
|
|
|
return paper.project.activeLayer.children.length;
|
|
|
|
}, 1);
|
2016-07-25 17:17:45 -04:00
|
|
|
equals(function() {
|
|
|
|
return path.parent == group;
|
|
|
|
}, true);
|
2014-08-16 13:24:54 -04:00
|
|
|
equals(function() {
|
|
|
|
return group.children[0] == path;
|
|
|
|
}, true);
|
2013-03-03 08:20:45 -05:00
|
|
|
});
|
|
|
|
|
2011-02-16 18:34:16 -05:00
|
|
|
test('Group bounds', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
paper.project.currentStyle = {
|
|
|
|
strokeWidth: 5,
|
|
|
|
strokeColor: 'black'
|
|
|
|
};
|
2011-05-16 14:21:44 -04:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
var path = new Path.Circle([150, 150], 60);
|
|
|
|
var secondPath = new Path.Circle([175, 175], 85);
|
|
|
|
var group = new Group([path, secondPath]);
|
2014-12-28 08:59:48 -05:00
|
|
|
equals(group.bounds, new Rectangle(90, 90, 170, 170), 'group.bounds');
|
|
|
|
equals(group.strokeBounds, new Rectangle(87.5, 87.5, 175, 175), 'group.strokeBounds');
|
2011-07-07 10:09:02 -04:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
group.rotate(20);
|
2014-12-28 08:59:48 -05:00
|
|
|
equals(group.bounds, new Rectangle(89.97687, 82.94085, 170.04627, 177.08228), 'rotated group.bounds');
|
|
|
|
equals(group.strokeBounds, new Rectangle(87.47687, 80.44085, 175.04627, 182.08228), 'rotated group.strokeBounds');
|
2014-08-16 13:24:54 -04:00
|
|
|
group.rotate(20, new Point(50, 50));
|
2014-12-28 08:59:48 -05:00
|
|
|
equals(group.bounds, new Rectangle(39.70708, 114.9919, 170.00396, 180.22418), 'rotated group.bounds');
|
|
|
|
equals(group.strokeBounds, new Rectangle(37.20708, 112.4919, 175.00396, 185.22418), 'rotated group.strokeBounds');
|
2012-10-06 05:15:52 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
test('group.addChildren(otherGroup.children)', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
var group = new Group();
|
|
|
|
group.addChild(new Path());
|
|
|
|
group.addChild(new Path());
|
|
|
|
equals(function() {
|
|
|
|
return group.children.length;
|
|
|
|
}, 2);
|
2012-10-06 05:15:52 -04:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
var secondGroup = new Group();
|
|
|
|
secondGroup.addChildren(group.children);
|
|
|
|
equals(function() {
|
|
|
|
return secondGroup.children.length;
|
|
|
|
}, 2);
|
|
|
|
equals(function() {
|
|
|
|
return group.children.length;
|
|
|
|
}, 0);
|
2012-10-06 07:08:07 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
test('group.insertChildren(0, otherGroup.children)', function() {
|
2014-08-16 13:24:54 -04:00
|
|
|
var group = new Group();
|
|
|
|
group.addChild(new Path());
|
|
|
|
group.addChild(new Path());
|
|
|
|
equals(function() {
|
|
|
|
return group.children.length;
|
|
|
|
}, 2);
|
2012-10-06 07:08:07 -04:00
|
|
|
|
2014-08-16 13:24:54 -04:00
|
|
|
var secondGroup = new Group();
|
|
|
|
secondGroup.insertChildren(0, group.children);
|
|
|
|
equals(function() {
|
|
|
|
return secondGroup.children.length;
|
|
|
|
}, 2);
|
|
|
|
equals(function() {
|
|
|
|
return group.children.length;
|
|
|
|
}, 0);
|
2014-04-06 07:48:03 -04:00
|
|
|
});
|
2016-06-13 08:16:25 -04:00
|
|
|
|
|
|
|
test('group.addChildren()', function() {
|
|
|
|
var group = new Group();
|
2017-03-21 06:55:42 -04:00
|
|
|
var path1 = new Path();
|
|
|
|
var path2 = new Path();
|
|
|
|
var children = [path1, path2];
|
2016-06-13 08:16:25 -04:00
|
|
|
group.addChildren(children);
|
|
|
|
equals(group.children.length, 2,
|
|
|
|
'group.children.length after adding 2 children');
|
|
|
|
group.removeChildren();
|
|
|
|
equals(group.children.length, 0,
|
|
|
|
'group.children.length after removing all children');
|
|
|
|
children.splice(1, 0, null);
|
|
|
|
equals(children.length, 3,
|
|
|
|
'children array length after inserting null at index 1');
|
|
|
|
group.addChildren(children);
|
|
|
|
equals(group.children.length, 2,
|
|
|
|
'calling group.addChildren() with an array with 3 entries, ' +
|
|
|
|
'of which 2 are valid, group.children.length should be 2');
|
2017-03-21 06:55:42 -04:00
|
|
|
children = [path1, path1, path2];
|
|
|
|
group.addChildren(children);
|
|
|
|
equals(group.children.length, 2,
|
|
|
|
'adding the same item twice should only add it once.');
|
2018-10-16 11:47:26 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
test('group.setSelectedColor() with selected bound and position', function() {
|
2019-06-05 12:16:56 -04:00
|
|
|
// Working: Set selected color first then add child.
|
|
|
|
var group1 = new Group();
|
|
|
|
group1.bounds.selected = true;
|
|
|
|
group1.position.selected = true;
|
|
|
|
group1.selectedColor = 'black';
|
|
|
|
group1.addChild(new Path.Circle([50, 50], 40));
|
|
|
|
// Failing: Add child first then set selected color.
|
|
|
|
var group2 = new Group();
|
|
|
|
group2.bounds.selected = true;
|
|
|
|
group2.position.selected = true;
|
|
|
|
group2.addChild(new Path.Circle([50, 50], 40));
|
|
|
|
group2.selectedColor = 'black';
|
|
|
|
comparePixels(group1, group2);
|
2018-10-16 11:47:26 -04:00
|
|
|
});
|
2018-10-06 09:37:44 -04:00
|
|
|
|
|
|
|
test('Group#isEmpty(recursively)', function() {
|
|
|
|
var group = new Group();
|
|
|
|
equals(true, group.isEmpty());
|
|
|
|
equals(true, group.isEmpty(true));
|
|
|
|
var group = new Group(new Group());
|
|
|
|
equals(false, group.isEmpty());
|
|
|
|
equals(true, group.isEmpty(true));
|
|
|
|
var group = new Group(new Path());
|
|
|
|
equals(false, group.isEmpty());
|
|
|
|
equals(true, group.isEmpty(true));
|
|
|
|
var group = new Group(new PointText());
|
|
|
|
equals(false, group.isEmpty());
|
|
|
|
equals(true, group.isEmpty(true));
|
|
|
|
});
|
2018-10-17 04:11:35 -04:00
|
|
|
|
2019-06-09 17:35:33 -04:00
|
|
|
test(
|
|
|
|
'group.internalBounds with clip item without clip.applyMatrix = false',
|
|
|
|
function() {
|
|
|
|
var point = new Point(100, 100);
|
|
|
|
var translation = new Point(100, 100);
|
|
|
|
var item = new Path.Circle({
|
|
|
|
center: point,
|
|
|
|
radius: 50,
|
|
|
|
fillColor: 'orange'
|
|
|
|
});
|
|
|
|
var clip = new Path.Rectangle({
|
|
|
|
from: point.subtract(translation),
|
|
|
|
to: point.add(translation)
|
|
|
|
});
|
|
|
|
clip.applyMatrix = false;
|
|
|
|
clip.translate(translation);
|
|
|
|
var group = new Group(clip, item);
|
|
|
|
group.clipped = true;
|
|
|
|
var expected = new Rectangle(point, point.add(translation.multiply(2)));
|
|
|
|
equals(group.internalBounds, expected);
|
|
|
|
}
|
|
|
|
);
|