paper.js/test/tests/Point.js

121 lines
2.8 KiB
JavaScript
Raw 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 - 2013, Juerg Lehni & Jonathan Puckey
2011-07-01 06:17:45 -04:00
* http://lehni.org/ & http://jonathanpuckey.com/
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
2011-02-07 13:28:09 -05:00
module('Point');
test('new Point(10, 20)', function() {
2011-02-07 13:28:09 -05:00
var point = new Point(10, 20);
comparePoints(point, { x: 10, y: 20 });
2011-02-07 13:28:09 -05:00
});
test('new Point([10, 20])', function() {
2011-02-07 13:28:09 -05:00
var point = new Point([10, 20]);
comparePoints(point, { x: 10, y: 20 });
2011-02-07 13:28:09 -05:00
});
test('new Point({x: 10, y: 20})', function() {
2011-02-07 13:28:09 -05:00
var point = new Point({x: 10, y: 20});
comparePoints(point, { x: 10, y: 20 });
2011-02-07 13:28:09 -05:00
});
test('new Point(new Size(10, 20))', function() {
2011-02-07 13:28:09 -05:00
var point = new Point(new Size(10, 20));
comparePoints(point, { x: 10, y: 20 });
2011-02-07 13:28:09 -05:00
});
test('new Point({ width: 10, height: 20})', function() {
2011-02-07 13:28:09 -05:00
var point = new Point({width: 10, height: 20});
comparePoints(point, { x: 10, y: 20 });
2011-02-07 13:28:09 -05:00
});
2011-05-21 15:01:01 -04:00
test('new Point({ angle: 45, length: 20})', function() {
var point = new Point({ angle: 40, length: 20 });
comparePoints(point, new Point(15.32089, 12.85575));
2011-05-21 15:01:01 -04:00
});
2011-02-07 13:28:09 -05:00
module('Point vector operations');
test('normalize(length)', function() {
var point = new Point(0, 10).normalize(20);
comparePoints(point, { x: 0, y: 20 });
2011-02-07 13:28:09 -05:00
});
test('set length', function() {
2011-02-07 13:28:09 -05:00
var point = new Point(0, 10);
point.length = 20;
comparePoints(point, { x: 0, y: 20 });
2011-02-07 13:28:09 -05:00
});
test('get angle', function() {
var angle = new Point(0, 10).angle;
2011-02-07 13:28:09 -05:00
equals(angle, 90);
});
test('getAngle(point)', function() {
2011-02-07 13:28:09 -05:00
var angle = new Point(0, 10).getAngle([10, 10]);
equals(Math.round(angle), 45);
});
test('rotate(degrees)', function() {
2011-02-07 13:28:09 -05:00
var point = new Point(100, 50).rotate(90);
comparePoints(point, { x: -50, y: 100 });
2011-02-07 13:28:09 -05:00
});
test('set angle', function() {
2011-02-07 13:28:09 -05:00
var point = new Point(10, 20);
point.angle = 92;
equals(point.angle, 92);
comparePoints(point, new Point({
angle: 92,
length: Math.sqrt(10 * 10 + 20 * 20)
}));
2011-02-07 13:28:09 -05:00
});
2013-06-23 19:55:14 -04:00
test('set angle & length', function() {
var point1 = new Point();
point1.length = Math.sqrt(2);
point1.angle = -45;
2013-06-23 19:55:14 -04:00
var point2 = new Point();
point2.angle = -45;
point2.length = Math.sqrt(2);
2013-06-23 19:55:14 -04:00
comparePoints(point2, point1);
2013-06-23 19:55:14 -04:00
});
test('getDirectedAngle(point)', function() {
var angle = new Point(10, 10).getDirectedAngle(new Point(1, 0));
2011-02-07 13:28:09 -05:00
equals(angle, -45);
var angle = new Point(-10, 10).getDirectedAngle(new Point(1, 0));
equals(angle, -135);
var angle = new Point(-10, -10).getDirectedAngle(new Point(1, 0));
equals(angle, 135);
var angle = new Point(10, -10).getDirectedAngle(new Point(1, 0));
equals(angle, 45);
});
test('equals()', function() {
equals(function() {
return new Point(10, 10).equals([10, 10]);
}, true);
equals(function() {
return new Point(0, 0).equals({});
}, false);
equals(function() {
return new Point(0, 0).equals(null);
}, false);
});