2011-03-04 08:34:31 -05:00
|
|
|
var Segment = this.Segment = Base.extend({
|
2011-02-07 13:28:09 -05:00
|
|
|
initialize: function() {
|
2011-02-13 11:26:24 -05:00
|
|
|
if (arguments.length == 0) {
|
2011-02-07 13:28:09 -05:00
|
|
|
this.point = new Point();
|
2011-02-13 11:26:24 -05:00
|
|
|
} else if (arguments.length == 1) {
|
|
|
|
if (arguments[0].point) {
|
2011-02-07 13:28:09 -05:00
|
|
|
var segment = arguments[0];
|
|
|
|
this.point = new Point(segment.point);
|
2011-02-13 11:26:24 -05:00
|
|
|
if (segment.handleIn)
|
2011-02-07 13:28:09 -05:00
|
|
|
this.handleIn = new Point(segment.handleIn);
|
2011-02-13 11:26:24 -05:00
|
|
|
if (segment.handleOut)
|
2011-02-07 13:28:09 -05:00
|
|
|
this.handleOut = new Point(segment.handleOut);
|
|
|
|
} else {
|
|
|
|
this.point = new Point(arguments[0]);
|
|
|
|
}
|
2011-02-13 11:26:24 -05:00
|
|
|
} else if (arguments.length < 6) {
|
|
|
|
if (arguments.length == 2 && !arguments[1].x) {
|
2011-02-07 13:28:09 -05:00
|
|
|
this.point = new Point(arguments[0], arguments[1]);
|
|
|
|
} else {
|
|
|
|
this.point = new Point(arguments[0]);
|
2011-02-13 11:26:24 -05:00
|
|
|
if (arguments[1])
|
2011-02-07 13:28:09 -05:00
|
|
|
this.handleIn = new Point(arguments[1]);
|
2011-02-13 11:26:24 -05:00
|
|
|
if (arguments[2])
|
2011-02-07 13:28:09 -05:00
|
|
|
this.handleOut = new Point(arguments[2]);
|
|
|
|
}
|
2011-02-13 11:26:24 -05:00
|
|
|
} else if (arguments.length == 6) {
|
2011-02-07 13:28:09 -05:00
|
|
|
this.point = new Point(arguments[0], arguments[1]);
|
|
|
|
this.handleIn = new Point(arguments[2], arguments[3]);
|
|
|
|
this.handleOut = new Point(arguments[4], arguments[5]);
|
2011-02-13 10:09:24 -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() {
|
|
|
|
return this.point;
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
setPoint: function() {
|
|
|
|
var point = Point.read(arguments);
|
|
|
|
this.point = point;
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
getHandleIn: function() {
|
|
|
|
return this.handleIn;
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
setHandleIn: function() {
|
|
|
|
var point = Point.read(arguments);
|
|
|
|
this.handleIn = point;
|
|
|
|
},
|
|
|
|
|
|
|
|
getHandleOut: function() {
|
|
|
|
return this.handleOut;
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
2011-02-07 13:28:09 -05:00
|
|
|
setHandleOut: function() {
|
|
|
|
var point = Point.read(arguments);
|
|
|
|
this.handleOut = point;
|
|
|
|
this.corner = !handleIn.isParallel(handleOut);
|
|
|
|
},
|
2011-03-03 17:45:17 -05:00
|
|
|
|
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-04 16:34:31 -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-04 16:34:31 -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-04 16:34:31 -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() {
|
|
|
|
return new Segment(this.point, this.handleOut, this.handleIn);
|
|
|
|
},
|
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-02-13 11:26:24 -05:00
|
|
|
if (this.path && this.path._segments)
|
2011-03-04 16:34:31 -05:00
|
|
|
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-03 08:03:57 -05:00
|
|
|
return '{ point: ' + this.point
|
|
|
|
+ (this.handleIn ? ', handleIn '+ this.handleIn : '')
|
|
|
|
+ (this.handleOut ? ', handleOut ' + this.handleOut : '')
|
2011-02-07 13:28:09 -05:00
|
|
|
+ ' }';
|
|
|
|
}
|
2011-02-13 11:26:24 -05:00
|
|
|
});
|