2013-06-17 11:54:42 -04:00
|
|
|
/*
|
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
|
|
|
* http://paperjs.org/
|
|
|
|
*
|
|
|
|
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
|
|
*
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
module('Curve');
|
|
|
|
|
|
|
|
test('Curve#getPointAt()', function() {
|
|
|
|
var curve = new Path.Circle({
|
|
|
|
center: [100, 100],
|
|
|
|
radius: 100
|
|
|
|
}).getFirstCurve();
|
|
|
|
|
|
|
|
var points = [
|
|
|
|
[0, new Point(0, 100)],
|
|
|
|
[0.25, new Point(7.8585, 61.07549)],
|
|
|
|
[0.5, new Point(29.28932, 29.28932)],
|
|
|
|
[0.75, new Point(61.07549, 7.8585)],
|
|
|
|
[1, new Point(100, 0)]
|
|
|
|
];
|
|
|
|
|
|
|
|
for (var i = 0; i < points.length; i++) {
|
|
|
|
var entry = points[i];
|
|
|
|
comparePoints(curve.getPointAt(entry[0], true), entry[1],
|
|
|
|
'curve.getPointAt(' + entry[0] + ', true);');
|
|
|
|
}
|
|
|
|
});
|
2013-06-18 21:23:48 -04:00
|
|
|
|
|
|
|
test('Curve#getTangentAt()', function() {
|
|
|
|
var curve = new Path.Circle({
|
|
|
|
center: [100, 100],
|
|
|
|
radius: 100
|
|
|
|
}).getFirstCurve();
|
|
|
|
|
|
|
|
var points = [
|
|
|
|
[0, new Point(0, -165.68542 )],
|
|
|
|
[0.25, new Point(60.7233, -143.56602)],
|
|
|
|
[0.5, new Point(108.57864, -108.57864)],
|
|
|
|
[0.75, new Point(143.56602, -60.7233)],
|
|
|
|
[1, new Point(165.68542, 0)]
|
|
|
|
];
|
|
|
|
|
|
|
|
for (var i = 0; i < points.length; i++) {
|
|
|
|
var entry = points[i];
|
|
|
|
comparePoints(curve.getTangentAt(entry[0], true), entry[1],
|
|
|
|
'curve.getPointAt(' + entry[0] + ', true);');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Curve#getNormalAt()', function() {
|
|
|
|
var curve = new Path.Circle({
|
|
|
|
center: [100, 100],
|
|
|
|
radius: 100
|
|
|
|
}).getFirstCurve();
|
|
|
|
|
|
|
|
var points = [
|
|
|
|
[0, new Point(-165.68542, 0)],
|
|
|
|
[0.25, new Point(-143.56602, -60.7233)],
|
|
|
|
[0.5, new Point(-108.57864, -108.57864)],
|
|
|
|
[0.75, new Point(-60.7233, -143.56602)],
|
|
|
|
[1, new Point(0, -165.68542)]
|
|
|
|
];
|
|
|
|
|
|
|
|
for (var i = 0; i < points.length; i++) {
|
|
|
|
var entry = points[i];
|
|
|
|
comparePoints(curve.getNormalAt(entry[0], true), entry[1],
|
|
|
|
'curve.getPointAt(' + entry[0] + ', true);');
|
|
|
|
}
|
|
|
|
});
|