paper.js/src/path/Segment.js

116 lines
2.9 KiB
JavaScript
Raw Normal View History

var Segment = this.Segment = Base.extend({
2011-02-07 13:28:09 -05:00
initialize: function() {
if (arguments.length == 0) {
2011-02-07 13:28:09 -05:00
this.point = new Point();
} 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);
if (segment.handleIn)
2011-02-07 13:28:09 -05:00
this.handleIn = new Point(segment.handleIn);
if (segment.handleOut)
2011-02-07 13:28:09 -05:00
this.handleOut = new Point(segment.handleOut);
} else {
this.point = new Point(arguments[0]);
}
} 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]);
if (arguments[1])
2011-02-07 13:28:09 -05:00
this.handleIn = new Point(arguments[1]);
if (arguments[2])
2011-02-07 13:28:09 -05:00
this.handleOut = new Point(arguments[2]);
}
} 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]);
}
if (!this.handleIn)
this.handleIn = new Point();
if (!this.handleOut)
this.handleOut = new Point();
2011-02-07 13:28:09 -05:00
},
2011-02-07 13:28:09 -05:00
getPoint: function() {
return this.point;
},
2011-02-07 13:28:09 -05:00
setPoint: function() {
var point = Point.read(arguments);
this.point = point;
},
2011-02-07 13:28:09 -05:00
getHandleIn: function() {
return this.handleIn;
},
2011-02-07 13:28:09 -05:00
setHandleIn: function() {
var point = Point.read(arguments);
this.handleIn = point;
},
getHandleOut: function() {
return this.handleOut;
},
2011-02-07 13:28:09 -05:00
setHandleOut: function() {
var point = Point.read(arguments);
this.handleOut = point;
this.corner = !handleIn.isParallel(handleOut);
},
2011-02-07 13:28:09 -05:00
getIndex: function() {
// TODO: Cache and update indices instead of searching?
return this.path ? this.path._segments.indexOf(this) : -1;
2011-02-07 13:28:09 -05:00
},
// TODO:
2011-02-07 13:28:09 -05:00
// getCurve: function() {
// if (this._segments && this._segments.path) {
// 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-02-07 13:28:09 -05:00
getNext: function() {
return this.path && this.path._segments[this.getIndex() + 1] || null;
2011-02-07 13:28:09 -05:00
},
2011-02-07 13:28:09 -05:00
getPrevious: function() {
return this.path && this.path._segments[this.getIndex() - 1] || null;
2011-02-07 13:28:09 -05:00
},
// TODO:
2011-02-07 13:28:09 -05:00
// isSelected: function() {
//
2011-02-07 13:28:09 -05:00
// }
//
// setSelected: function(pt, selected)
2011-02-07 13:28:09 -05:00
reverse: function() {
return new Segment(this.point, this.handleOut, this.handleIn);
},
2011-02-07 13:28:09 -05:00
clone: function() {
return new Segment(this);
},
2011-02-07 13:28:09 -05:00
remove: function() {
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-02-07 13:28:09 -05:00
toString: function() {
return '{ point: ' + this.point
+ (this.handleIn ? ', handleIn '+ this.handleIn : '')
+ (this.handleOut ? ', handleOut ' + this.handleOut : '')
2011-02-07 13:28:09 -05:00
+ ' }';
}
});