Restructure code a bit.

This commit is contained in:
Jürg Lehni 2013-01-22 14:58:34 -08:00
parent a5bfa9e5d3
commit e75ee18de1

View file

@ -149,7 +149,7 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
var curves = this._curves, var curves = this._curves,
segments = this._segments; segments = this._segments;
if (!curves) { if (!curves) {
var length = this._getCurveCount(); var length = this._countCurves();
curves = this._curves = new Array(length); curves = this._curves = new Array(length);
for (var i = 0; i < length; i++) for (var i = 0; i < length; i++)
curves[i] = Curve.create(this, segments[i], curves[i] = Curve.create(this, segments[i],
@ -169,12 +169,6 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
return curves; return curves;
}, },
_getCurveCount: function() {
var length = this._segments.length;
// Reduce length by one if it's an open path:
return !this._closed && length > 0 ? length - 1 : length;
},
/** /**
* The first Curve contained within the path. * The first Curve contained within the path.
* *
@ -223,7 +217,7 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
this._closed = closed; this._closed = closed;
// Update _curves length // Update _curves length
if (this._curves) { if (this._curves) {
var length = this._curves.length = this._getCurveCount(); var length = this._curves.length = this._countCurves();
// If we were closing this path, we need to add a new curve now // If we were closing this path, we need to add a new curve now
if (closed) if (closed)
this._curves[length - 1] = Curve.create(this, this._curves[length - 1] = Curve.create(this,
@ -321,7 +315,7 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
// get its curve, except for the first segment. // get its curve, except for the first segment.
var from = index > 0 ? index - 1 : index, var from = index > 0 ? index - 1 : index,
start = from, start = from,
to = Math.min(from + amount, this._getCurveCount()); to = Math.min(from + amount, this._countCurves());
if (segs._curves) { if (segs._curves) {
// Reuse removed curves. // Reuse removed curves.
curves.splice.apply(curves, [from, 0].concat(segs._curves)); curves.splice.apply(curves, [from, 0].concat(segs._curves));
@ -338,6 +332,39 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
return segs; return segs;
}, },
/**
* Adjusts segments of curves before and after inserted / removed segments.
*/
_adjustCurves: function(from, to) {
var segments = this._segments,
curves = this._curves,
curve;
for (var i = from; i < to; i++) {
curve = curves[i];
curve._path = this;
curve._segment1 = segments[i];
curve._segment2 = segments[i + 1] || segments[0];
}
// If it's the first segment, correct the last segment of closed
// paths too:
if (curve = curves[this._closed && from === 0 ? segments.length - 1
: from - 1])
curve._segment2 = segments[from] || segments[0];
// Fix the segment after the modified range, if it exists
if (curve = curves[to])
curve._segment1 = segments[to];
},
/**
* Returns the amount of curves this path item is supposed to have, based
* on its amount of #segments and #closed state.
*/
_countCurves: function() {
var length = this._segments.length;
// Reduce length by one if it's an open path:
return !this._closed && length > 0 ? length - 1 : length;
},
// DOCS: find a way to document the variable segment parameters of Path#add // DOCS: find a way to document the variable segment parameters of Path#add
/** /**
* Adds one or more segments to the end of the {@link #segments} array of * Adds one or more segments to the end of the {@link #segments} array of
@ -615,29 +642,6 @@ var Path = this.Path = PathItem.extend(/** @lends Path# */{
return removed; return removed;
}, },
/**
* Adjusts segments of curves before and after inserted / removed segments.
*/
_adjustCurves: function(from, to) {
var segments = this._segments,
curves = this._curves,
curve;
for (var i = from; i < to; i++) {
curve = curves[i];
curve._path = this;
curve._segment1 = segments[i];
curve._segment2 = segments[i + 1] || segments[0];
}
// If it's the first segment, correct the last segment of closed
// paths too:
if (curve = curves[this._closed && from === 0 ? segments.length - 1
: from - 1])
curve._segment2 = segments[from] || segments[0];
// Fix the segment after the modified range, if it exists
if (curve = curves[to])
curve._segment1 = segments[to];
},
/** /**
* Specifies whether an path is selected and will also return {@code true} * Specifies whether an path is selected and will also return {@code true}
* if the path is partially selected, i.e. one or more of its segments is * if the path is partially selected, i.e. one or more of its segments is