2011-03-04 08:34:31 -05:00
|
|
|
var Segment = this.Segment = Base.extend({
|
2011-03-06 05:57:14 -05:00
|
|
|
beans: true,
|
|
|
|
|
2011-03-06 07:24:03 -05:00
|
|
|
initialize: function(arg0, arg1, arg2, arg3, arg4, arg5) {
|
2011-02-13 11:26:24 -05:00
|
|
|
if (arguments.length == 0) {
|
2011-03-06 05:57:14 -05:00
|
|
|
this._point = new Point();
|
2011-02-13 11:26:24 -05:00
|
|
|
} else if (arguments.length == 1) {
|
2011-03-06 05:57:14 -05:00
|
|
|
// TODO: If beans are not activated, this won't copy from
|
|
|
|
// an existing segment. OK?
|
2011-03-06 07:24:03 -05:00
|
|
|
if (arg0.point) {
|
|
|
|
this._point = new Point(arg0.point);
|
|
|
|
this._handleIn = new Point(arg0.handleIn);
|
|
|
|
this._handleOut = new Point(arg0.handleOut);
|
2011-02-07 13:28:09 -05:00
|
|
|
} else {
|
2011-03-06 07:24:03 -05:00
|
|
|
this._point = new Point(arg0);
|
2011-02-07 13:28:09 -05:00
|
|
|
}
|
2011-02-13 11:26:24 -05:00
|
|
|
} else if (arguments.length < 6) {
|
2011-03-06 07:24:03 -05:00
|
|
|
if (arguments.length == 2 && !arg1.x) {
|
|
|
|
this._point = new Point(arg0, arg1);
|
2011-02-07 13:28:09 -05:00
|
|
|
} else {
|
2011-03-06 07:24:03 -05:00
|
|
|
this._point = new Point(arg0);
|
2011-03-06 05:57:14 -05:00
|
|
|
// Doesn't matter if these arguments exist, it creates 0, 0
|
|
|
|
// points otherwise
|
2011-03-06 07:24:03 -05:00
|
|
|
this._handleIn = new Point(arg1);
|
|
|
|
this._handleOut = new Point(arg2);
|
2011-02-07 13:28:09 -05:00
|
|
|
}
|
2011-02-13 11:26:24 -05:00
|
|
|
} else if (arguments.length == 6) {
|
2011-03-06 07:24:03 -05:00
|
|
|
this._point = new Point(arg0, arg1);
|
|
|
|
this._handleIn = new Point(arg2, arg3);
|
|
|
|
this._handleOut = new Point(arg4, arg5);
|
2011-02-13 10:09:24 -05:00
|
|
|
}
|
2011-03-06 05:57:14 -05:00
|
|
|
if (!this._handleIn)
|
|
|
|
this._handleIn = new Point();
|
|
|
|
if (!this._handleOut)
|
|
|
|
this._handleOut = new Point();
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
getPoint: function() {
|
2011-03-06 05:57:14 -05:00
|
|
|
return this._point;
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
setPoint: function() {
|
2011-03-06 07:24:03 -05:00
|
|
|
// Do not replace the internal object but update it instead, so
|
|
|
|
// references to it are kept alive.
|
|
|
|
var point = Point.read(arguments);
|
|
|
|
this._point.set(point.x, point.y);
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
getHandleIn: function() {
|
2011-03-06 05:57:14 -05:00
|
|
|
return this._handleIn;
|
|
|
|
},
|
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
setHandleIn: function() {
|
2011-03-06 07:24:03 -05:00
|
|
|
// See #setPoint:
|
|
|
|
var point = Point.read(arguments);
|
|
|
|
this._handleIn.set(point.x, point.y);
|
2011-03-06 05:57:14 -05:00
|
|
|
// Update corner accordingly
|
|
|
|
// this.corner = !this._handleIn.isParallel(this._handleOut);
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
|
|
|
|
2011-03-06 06:18:35 -05:00
|
|
|
getHandleInIfSet: function() {
|
|
|
|
return this._handleIn.x == 0 && this._handleIn.y == 0
|
|
|
|
? null : this._handleIn;
|
2011-03-06 05:57:14 -05:00
|
|
|
},
|
|
|
|
|
2011-03-06 06:18:35 -05:00
|
|
|
getHandleOut: function() {
|
|
|
|
return this._handleOut;
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
setHandleOut: function() {
|
2011-03-06 07:24:03 -05:00
|
|
|
// See #setPoint:
|
|
|
|
var point = Point.read(arguments);
|
|
|
|
this._handleOut.set(point.x, point.y);
|
2011-03-06 05:57:14 -05:00
|
|
|
// Update corner accordingly
|
|
|
|
// this.corner = !this._handleIn.isParallel(this._handleOut);
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-03-06 06:18:35 -05:00
|
|
|
getHandleOutIfSet: function() {
|
|
|
|
return this._handleOut.x == 0 && this._handleOut.y == 0
|
|
|
|
? null : this._handleOut;
|
|
|
|
},
|
|
|
|
|
2011-03-06 07:24:03 -05:00
|
|
|
getPath: function() {
|
|
|
|
return this._path;
|
|
|
|
},
|
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
getIndex: function() {
|
2011-02-13 10:09:24 -05:00
|
|
|
// TODO: Cache and update indices instead of searching?
|
2011-03-06 07:24:03 -05:00
|
|
|
return this._path ? this._path._segments.indexOf(this) : -1;
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-14 05:35:40 -05:00
|
|
|
// TODO:
|
2011-02-07 13:28:09 -05:00
|
|
|
// getCurve: function() {
|
2011-02-13 11:26:24 -05:00
|
|
|
// if (this._segments && this._segments.path) {
|
2011-02-13 08:52:51 -05:00
|
|
|
// var curves = this._segments.path.getCurves();
|
2011-02-07 13:28:09 -05:00
|
|
|
// // The curves list handles closing curves, so the curves.size
|
|
|
|
// // is adjusted accordingly. just check to be in the boundaries here:
|
|
|
|
// return index < curves.length ? curves[index] : null;
|
|
|
|
// }
|
|
|
|
// },
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
getNext: function() {
|
2011-03-06 07:24:03 -05:00
|
|
|
return this._path && this._path._segments[this.getIndex() + 1] || null;
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
getPrevious: function() {
|
2011-03-06 07:24:03 -05:00
|
|
|
return this._path && this._path._segments[this.getIndex() - 1] || null;
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-14 05:35:40 -05:00
|
|
|
// TODO:
|
2011-02-07 13:28:09 -05:00
|
|
|
// isSelected: function() {
|
2011-03-03 17:45:17 -05:00
|
|
|
//
|
2011-02-07 13:28:09 -05:00
|
|
|
// }
|
|
|
|
//
|
|
|
|
// setSelected: function(pt, selected)
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
reverse: function() {
|
2011-03-06 05:57:14 -05:00
|
|
|
return new Segment(this._point, this._handleOut, this._handleIn);
|
2011-02-07 13:28:09 -05:00
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
clone: function() {
|
|
|
|
return new Segment(this);
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
remove: function() {
|
2011-03-06 07:24:03 -05:00
|
|
|
if (this._path && this._path._segments)
|
|
|
|
return !!this._path._segments.splice(this.getIndex(), 1).length;
|
2011-02-07 13:28:09 -05:00
|
|
|
return false;
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
toString: function() {
|
2011-03-06 05:57:14 -05:00
|
|
|
return '{ point: ' + this._point
|
2011-03-06 07:56:30 -05:00
|
|
|
+ (!this._handleIn.isZero()
|
|
|
|
? ', handleIn: ' + this._handleIn : '')
|
|
|
|
+ (this._handleOut.isZero()
|
|
|
|
? ', handleOut: ' + this._handleOut : '')
|
2011-02-07 13:28:09 -05:00
|
|
|
+ ' }';
|
|
|
|
}
|
2011-02-13 11:26:24 -05:00
|
|
|
});
|