mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-19 14:10:14 -05:00
106 lines
3.1 KiB
JavaScript
106 lines
3.1 KiB
JavaScript
module('Symbol & Placed Symbol');
|
|
|
|
test('placedSymbol bounds', function() {
|
|
var path = new Path.Circle([50, 50], 50);
|
|
path.strokeColor = 'black';
|
|
path.strokeWidth = 1;
|
|
path.strokeCap = 'round';
|
|
path.strokeJoin = 'round';
|
|
compareRectangles(path.strokeBounds,
|
|
{ x: -0.5, y: -0.5, width: 101, height: 101 },
|
|
'Path initial bounds.');
|
|
var symbol = new Symbol(path);
|
|
var placedSymbol = new PlacedSymbol(symbol);
|
|
|
|
compareRectangles(placedSymbol.bounds,
|
|
new Rectangle(-50.5, -50.5, 101, 101),
|
|
'PlacedSymbol initial bounds.');
|
|
|
|
placedSymbol.scale(1, 0.5);
|
|
compareRectangles(placedSymbol.bounds,
|
|
{ x: -50.5, y: -25.25, width: 101, height: 50.5 },
|
|
'Bounds after scale.');
|
|
|
|
placedSymbol.rotate(40);
|
|
compareRectangles(placedSymbol.bounds,
|
|
{ x: -42.04736, y: -37.91846, width: 84.09473, height: 75.83691 },
|
|
'Bounds after rotation.');
|
|
});
|
|
|
|
test('bounds of group of symbol instances', function() {
|
|
var path = new Path.Circle(new Point(), 10);
|
|
var symbol = new Symbol(path);
|
|
var instances = [];
|
|
for (var i = 0; i < 10; i++) {
|
|
var instance = symbol.place(new Point(i * 20, 20));
|
|
instances.push(instance);
|
|
}
|
|
var group = new Group(instances);
|
|
compareRectangles(group.bounds,
|
|
{ x: -10, y: 10, width: 200, height: 20 },
|
|
'Group bounds');
|
|
});
|
|
|
|
test('bounds of a symbol that contains a group of items', function() {
|
|
var path = new Path.Circle(new Point(), 10);
|
|
var path2 = path.clone();
|
|
path2.position += [20, 0];
|
|
var group = new Group(path, path2);
|
|
var symbol = new Symbol(group);
|
|
var instance = symbol.place(new Point(0, 0));
|
|
compareRectangles(instance.bounds,
|
|
{ x: -20, y: -10, width: 40, height: 20 },
|
|
'Instance bounds');
|
|
});
|
|
|
|
test('Changing the definition of a symbol should change the bounds of all instances of it.', function() {
|
|
var path = new Path.Circle(new Point(), 10);
|
|
var path2 = new Path.Circle(new Point(), 20);
|
|
var symbol = new Symbol(path);
|
|
var instance = symbol.place(new Point(0, 0));
|
|
compareRectangles(instance.bounds,
|
|
{ x: -10, y: -10, width: 20, height: 20 },
|
|
'Initial bounds');
|
|
symbol.definition = path2;
|
|
compareRectangles(instance.bounds,
|
|
{ x: -20, y: -20, width: 40, height: 40 },
|
|
'Bounds after changing symbol definition');
|
|
});
|
|
|
|
test('Symbol definition selection', function() {
|
|
var path = new Path.Circle([50, 50], 50);
|
|
path.selected = true;
|
|
var symbol = new Symbol(path);
|
|
equals(function() {
|
|
return symbol.definition.selected == false;
|
|
}, true);
|
|
equals(function() {
|
|
return paper.project.selectedItems.length == 0;
|
|
}, true);
|
|
});
|
|
|
|
test('Symbol#place()', function() {
|
|
var path = new Path.Circle([50, 50], 50);
|
|
var symbol = new Symbol(path);
|
|
var placedSymbol = symbol.place();
|
|
equals(function() {
|
|
return placedSymbol.parent == paper.project.activeLayer;
|
|
}, true);
|
|
|
|
equals(function() {
|
|
return placedSymbol.symbol == symbol;
|
|
}, true);
|
|
|
|
equals(function() {
|
|
return placedSymbol.position.toString();
|
|
}, '{ x: 0, y: 0 }');
|
|
});
|
|
|
|
test('Symbol#place(position)', function() {
|
|
var path = new Path.Circle([50, 50], 50);
|
|
var symbol = new Symbol(path);
|
|
var placedSymbol = symbol.place(new Point(100, 100));
|
|
equals(function() {
|
|
return placedSymbol.position.toString();
|
|
}, '{ x: 100, y: 100 }');
|
|
});
|