mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-24 16:29:59 -05:00
75 lines
3.1 KiB
JavaScript
75 lines
3.1 KiB
JavaScript
/*
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
|
* http://paperjs.org/
|
|
*
|
|
* Copyright (c) 2011 - 2014, Juerg Lehni & Jonathan Puckey
|
|
* http://scratchdisk.com/ & http://jonathanpuckey.com/
|
|
*
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
*
|
|
* All rights reserved.
|
|
*/
|
|
|
|
module('Item Bounds');
|
|
|
|
test('item.bounds caching', function() {
|
|
var circle = new Path.Circle(new Point(100, 100), 50);
|
|
var rectangle = new Path.Rectangle(new Point(75, 75), new Point(175, 175));
|
|
var group = new Group([circle, rectangle]);
|
|
compareRectangles(group.bounds, { x: 50, y: 50, width: 125, height: 125 }, 'group.bounds');
|
|
rectangle.remove();
|
|
equals(function() {
|
|
return group.children.length;
|
|
}, 1);
|
|
compareRectangles(group.bounds, { x: 50, y: 50, width: 100, height: 100 }, 'group.bounds without rectangle');
|
|
group.addChild(rectangle);
|
|
equals(function() {
|
|
return group.children.length;
|
|
}, 2);
|
|
compareRectangles(group.bounds, { x: 50, y: 50, width: 125, height: 125 }, 'group.bounds with rectangle');
|
|
circle.remove();
|
|
equals(function() {
|
|
return group.children.length;
|
|
}, 1);
|
|
compareRectangles(group.bounds, { x: 75, y: 75, width: 100, height: 100 }, 'group.bounds without circle');
|
|
group.addChild(circle);
|
|
equals(function() {
|
|
return group.children.length;
|
|
}, 2);
|
|
compareRectangles(group.bounds, { x: 50, y: 50, width: 125, height: 125 }, 'group.bounds with circle');
|
|
});
|
|
|
|
test('group.bounds when group contains empty group', function() {
|
|
var group = new Group();
|
|
var rectangle = new Path.Rectangle(new Point(75, 75), new Point(175, 175));
|
|
group.addChild(rectangle);
|
|
compareRectangles(group.bounds, { x: 75, y: 75, width: 100, height: 100 }, 'group.bounds without empty group');
|
|
group.addChild(new Group());
|
|
compareRectangles(group.bounds, { x: 75, y: 75, width: 100, height: 100 }, 'group.bounds with empty group');
|
|
});
|
|
|
|
test('group.bounds and position after children were modified', function() {
|
|
var group = new Group();
|
|
var rectangle = new Path.Rectangle(new Point(100, 100), new Point(200, 200));
|
|
group.addChild(rectangle);
|
|
compareRectangles(group.bounds, { x: 100, y: 100, width: 100, height: 100 }, 'group.bounds before change');
|
|
comparePoints(group.position, { x: 150, y: 150 }, 'group.position before change');
|
|
rectangle.firstSegment.point = [0, 0];
|
|
compareRectangles(group.bounds, { x: 0, y: 0, width: 200, height: 200 }, 'group.bounds after change');
|
|
comparePoints(group.position, { x: 100, y: 100 }, 'group.position after change');
|
|
});
|
|
|
|
test('path.bounds when contained in a transformed group', function() {
|
|
var path = new Path([10, 10], [60, 60]);
|
|
var group = new Group([path]);
|
|
compareRectangles(path.bounds, { x: 10, y: 10, width: 50, height: 50 }, 'path.bounds before group translation');
|
|
group.translate(100, 100);
|
|
compareRectangles(path.bounds, { x: 110, y: 110, width: 50, height: 50 }, 'path.bounds after group translation');
|
|
});
|
|
|
|
test('text.bounds', function() {
|
|
var text = new PointText(new Point(50, 100));
|
|
text.fillColor = 'black';
|
|
text.content = 'This is a test';
|
|
compareRectangles(text.bounds, { x: 50, y: 89.2, width: 67, height: 14.4 } , 'text.bounds');
|
|
});
|