paper.js/test/tests/Item_Bounds.js

103 lines
3.9 KiB
JavaScript
Raw Normal View History

2011-11-28 16:59:34 -05:00
/*
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
2011-11-28 16:59:34 -05:00
* http://paperjs.org/
*
* Copyright (c) 2011 - 2016, Juerg Lehni & Jonathan Puckey
2014-01-03 19:47:16 -05:00
* http://scratchdisk.com/ & http://jonathanpuckey.com/
2011-11-28 16:59:34 -05:00
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
QUnit.module('Item Bounds');
2011-11-28 16:59:34 -05:00
test('item.bounds caching', function() {
2014-08-16 13:24:54 -04:00
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]);
equals(group.bounds, new Rectangle(50, 50, 125, 125), 'group.bounds');
2014-08-16 13:24:54 -04:00
rectangle.remove();
equals(function() {
return group.children.length;
}, 1);
equals(group.bounds, new Rectangle(50, 50, 100, 100), 'group.bounds without rectangle');
2014-08-16 13:24:54 -04:00
group.addChild(rectangle);
equals(function() {
return group.children.length;
}, 2);
equals(group.bounds, new Rectangle(50, 50, 125, 125), 'group.bounds with rectangle');
2014-08-16 13:24:54 -04:00
circle.remove();
equals(function() {
return group.children.length;
}, 1);
equals(group.bounds, new Rectangle(75, 75, 100, 100), 'group.bounds without circle');
2014-08-16 13:24:54 -04:00
group.addChild(circle);
equals(function() {
return group.children.length;
}, 2);
equals(group.bounds, new Rectangle(50, 50, 125, 125), 'group.bounds with circle');
2011-11-28 16:59:34 -05:00
});
test('group.bounds when group contains empty group', function() {
2014-08-16 13:24:54 -04:00
var group = new Group();
var rectangle = new Path.Rectangle(new Point(75, 75), new Point(175, 175));
group.addChild(rectangle);
equals(group.bounds, new Rectangle(75, 75, 100, 100), 'group.bounds without empty group');
2014-08-16 13:24:54 -04:00
group.addChild(new Group());
equals(group.bounds, new Rectangle(75, 75, 100, 100), 'group.bounds with empty group');
});
test('group.bounds and position after children were modified', function() {
2014-08-16 13:24:54 -04:00
var group = new Group();
var rectangle = new Path.Rectangle(new Point(100, 100), new Point(200, 200));
group.addChild(rectangle);
equals(group.bounds, new Rectangle(100, 100, 100, 100), 'group.bounds before change');
equals(group.position, new Point(150, 150), 'group.position before change');
2014-08-16 13:24:54 -04:00
rectangle.firstSegment.point = [0, 0];
equals(group.bounds, new Rectangle(0, 0, 200, 200), 'group.bounds after change');
equals(group.position, new Point(100, 100), 'group.position after change');
});
test('group.bounds when containing empty path first', function() {
var group = new Group();
var path = new Path();
group.addChild(path);
equals(group.bounds, new Rectangle(0, 0, 0, 0), 'group.bounds with empty path');
path.moveTo([75, 75]);
path.lineTo([175, 175]);
equals(group.bounds, new Rectangle(75, 75, 100, 100), 'group.bounds after adding segments to path');
});
test('path.bounds when contained in a transformed group', function() {
2014-08-16 13:24:54 -04:00
var path = new Path([10, 10], [60, 60]);
var group = new Group([path]);
equals(path.bounds, new Rectangle(10, 10, 50, 50), 'path.bounds before group translation');
2014-08-16 13:24:54 -04:00
group.translate(100, 100);
equals(path.bounds, new Rectangle(110, 110, 50, 50), 'path.bounds after group translation');
});
2015-12-27 14:21:02 -05:00
test('shape.strokeBounds when scaled with strokeScaling set to false', function(){
var shape = new Shape.Rectangle({
point: [5, 5],
size: [20, 20],
strokeScaling: false,
strokeColor: 'black',
strokeWidth: 10
});
2015-12-27 14:21:02 -05:00
equals(shape.strokeBounds, new Rectangle(0, 0, 30, 30), 'shape.strokeBounds before scaling');
shape.scale(2, 2, [5, 5]);
2015-12-27 14:21:02 -05:00
equals(shape.strokeBounds, new Rectangle(0, 0, 50, 50), 'shape.strokeBounds after scaling');
});
test('text.bounds', function() {
var text = new PointText({
fontFamily: 'Arial, Helvetica',
fontSize: 14,
fillColor: 'black',
point: [50, 100],
content: 'Hello World!'
});
equals(text.bounds, new Rectangle(50, 87.4, 76.25, 16.8), 'text.bounds', { tolerance: 1.0 });
});