2011-05-08 04:59:37 -04:00
|
|
|
/*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
|
2011-05-08 04:59:37 -04:00
|
|
|
* http://paperjs.org/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2013-01-28 21:03:27 -05:00
|
|
|
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
|
2011-05-08 04:59:37 -04:00
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-07-01 06:17:45 -04:00
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
2011-05-08 04:59:37 -04:00
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2011-04-21 08:21:56 -04:00
|
|
|
/**
|
2011-06-22 18:56:05 -04:00
|
|
|
* @name SegmentPoint
|
|
|
|
* @class An internal version of Point that notifies its segment of each change
|
2011-04-21 08:21:56 -04:00
|
|
|
* Note: This prototype is not exported.
|
2011-06-30 06:01:51 -04:00
|
|
|
*
|
2011-06-22 18:56:05 -04:00
|
|
|
* @private
|
2011-04-21 08:21:56 -04:00
|
|
|
*/
|
|
|
|
var SegmentPoint = Point.extend({
|
2013-10-18 15:12:25 -04:00
|
|
|
initialize: function SegmentPoint(point, owner, key) {
|
2013-06-25 12:48:51 -04:00
|
|
|
var x, y, selected;
|
|
|
|
if (!point) {
|
|
|
|
x = y = 0;
|
|
|
|
} else if ((x = point[0]) !== undefined) { // Array-like
|
|
|
|
y = point[1];
|
|
|
|
} else {
|
|
|
|
// If not Point-like already, read Point from arguments
|
|
|
|
if ((x = point.x) === undefined) {
|
|
|
|
point = Point.read(arguments);
|
|
|
|
x = point.x;
|
|
|
|
}
|
|
|
|
y = point.y;
|
|
|
|
selected = point.selected;
|
|
|
|
}
|
|
|
|
this._x = x;
|
|
|
|
this._y = y;
|
|
|
|
this._owner = owner;
|
2013-10-18 15:12:25 -04:00
|
|
|
// We have to set the owner's property that points to this point already
|
|
|
|
// now, so #setSelected(true) can work.
|
|
|
|
owner[key] = this;
|
2013-06-25 12:48:51 -04:00
|
|
|
if (selected)
|
|
|
|
this.setSelected(true);
|
|
|
|
},
|
|
|
|
|
2011-04-21 08:21:56 -04:00
|
|
|
set: function(x, y) {
|
|
|
|
this._x = x;
|
|
|
|
this._y = y;
|
2011-05-08 08:38:09 -04:00
|
|
|
this._owner._changed(this);
|
2011-04-21 08:21:56 -04:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2013-10-17 06:04:11 -04:00
|
|
|
_serialize: function(options) {
|
|
|
|
var f = options.formatter,
|
2013-10-18 15:12:25 -04:00
|
|
|
x = f.number(this._x),
|
|
|
|
y = f.number(this._y);
|
|
|
|
return this.isSelected()
|
|
|
|
? { x: x, y: y, selected: true }
|
|
|
|
: [x, y];
|
2013-10-17 06:04:11 -04:00
|
|
|
},
|
|
|
|
|
2011-04-21 08:21:56 -04:00
|
|
|
getX: function() {
|
|
|
|
return this._x;
|
|
|
|
},
|
|
|
|
|
|
|
|
setX: function(x) {
|
|
|
|
this._x = x;
|
2011-05-08 08:38:09 -04:00
|
|
|
this._owner._changed(this);
|
2011-04-21 08:21:56 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
getY: function() {
|
|
|
|
return this._y;
|
|
|
|
},
|
|
|
|
|
|
|
|
setY: function(y) {
|
|
|
|
this._y = y;
|
2011-05-08 08:38:09 -04:00
|
|
|
this._owner._changed(this);
|
2011-04-21 08:21:56 -04:00
|
|
|
},
|
2011-06-30 06:01:51 -04:00
|
|
|
|
2011-08-16 07:38:52 -04:00
|
|
|
isZero: function() {
|
|
|
|
// Provide our own version of Point#isZero() that does not use the x / y
|
|
|
|
// accessors but the internal properties directly, for performance
|
|
|
|
// reasons, since it is used a lot internally.
|
2012-11-06 00:06:13 -05:00
|
|
|
return Numerical.isZero(this._x) && Numerical.isZero(this._y);
|
2011-08-16 07:38:52 -04:00
|
|
|
},
|
|
|
|
|
2011-04-21 12:06:06 -04:00
|
|
|
setSelected: function(selected) {
|
2013-12-08 12:06:31 -05:00
|
|
|
this._owner.setSelected(selected, this);
|
2011-04-21 12:06:06 -04:00
|
|
|
},
|
2011-06-30 06:01:51 -04:00
|
|
|
|
2011-04-21 13:51:49 -04:00
|
|
|
isSelected: function() {
|
2013-12-08 12:06:31 -05:00
|
|
|
return this._owner.isSelected(this);
|
2011-04-21 08:21:56 -04:00
|
|
|
}
|
|
|
|
});
|