paper.js/test/tests/Segment.js

77 lines
2.6 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('Segment');
test('new Segment(point)', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment(new Point(10, 10));
equals(segment.toString(), '{ point: { x: 10, y: 10 } }');
2011-02-07 13:28:09 -05:00
});
test('new Segment(x, y)', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment(10, 10);
equals(segment.toString(), '{ point: { x: 10, y: 10 } }');
2011-02-07 13:28:09 -05:00
});
test('new Segment(object)', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment({ point: { x: 10, y: 10 }, handleIn: { x: 5, y: 5 }, handleOut: { x: 15, y: 15 } });
equals(segment.toString(), '{ point: { x: 10, y: 10 }, handleIn: { x: 5, y: 5 }, handleOut: { x: 15, y: 15 } }');
2011-02-07 13:28:09 -05:00
});
test('new Segment(point, handleIn, handleOut)', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment(new Point(10, 10), new Point(5, 5), new Point(15, 15));
equals(segment.toString(), '{ point: { x: 10, y: 10 }, handleIn: { x: 5, y: 5 }, handleOut: { x: 15, y: 15 } }');
2011-02-07 13:28:09 -05:00
});
test('new Segment(x, y, inX, inY, outX, outY)', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment(10, 10, 5, 5, 15, 15);
equals(segment.toString(), '{ point: { x: 10, y: 10 }, handleIn: { x: 5, y: 5 }, handleOut: { x: 15, y: 15 } }');
2011-02-07 13:28:09 -05:00
});
test('new Segment(size)', function() {
var segment = new Segment(new Size(10, 10));
equals(segment.toString(), '{ point: { x: 10, y: 10 } }');
});
test('segment.reverse()', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment(new Point(10, 10), new Point(5, 5), new Point(15, 15));
segment = segment.reverse();
equals(segment.toString(), '{ point: { x: 10, y: 10 }, handleIn: { x: 15, y: 15 }, handleOut: { x: 5, y: 5 } }');
2011-02-07 13:28:09 -05:00
});
test('segment.clone()', function() {
2011-02-07 13:28:09 -05:00
var segment = new Segment(new Point(10, 10), new Point(5, 5), new Point(15, 15));
var clone = segment.clone();
equals(function() {
return segment == clone;
}, false);
equals(function() {
return segment.toString();
}, clone.toString());
});
test('segment.remove()', function() {
var path = new Path([10, 10], [5, 5], [10, 10]);
path.segments[1].remove();
equals(path.segments.toString(), '{ point: { x: 10, y: 10 } },{ point: { x: 10, y: 10 } }');
});
test('segment.selected', function() {
var path = new Path([10, 20], [50, 100]);
path.segments[0].point.selected = true;
equals(function() {
return path.segments[0].point.selected;
}, true);
path.segments[0].point.selected = false;
equals(function() {
return path.segments[0].point.selected;
}, false);});