mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-22 07:19:57 -05:00
Produce Path#getPointAt(), #getTangentAt(), #getNormalAt() & #getCurvature() in a loop, just like for Curve.
This commit is contained in:
parent
50c5c6736c
commit
73765e6654
1 changed files with 13 additions and 15 deletions
|
@ -414,7 +414,7 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
for (var i = index + amount, l = segments.length; i < l; i++)
|
for (var i = index + amount, l = segments.length; i < l; i++)
|
||||||
segments[i]._index = i;
|
segments[i]._index = i;
|
||||||
}
|
}
|
||||||
// Keep the curves list in sync all the time in case it as requested
|
// Keep the curves list in sync all the time in case it was requested
|
||||||
// already.
|
// already.
|
||||||
if (curves || segs._curves) {
|
if (curves || segs._curves) {
|
||||||
if (!curves)
|
if (!curves)
|
||||||
|
@ -1596,7 +1596,14 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
|
|
||||||
// TODO: intersects(item)
|
// TODO: intersects(item)
|
||||||
// TODO: contains(item)
|
// TODO: contains(item)
|
||||||
}, /** @lends Path# */{
|
}, Base.each(['getPoint', 'getTangent', 'getNormal', 'getCurvature'],
|
||||||
|
function(name, index) {
|
||||||
|
this[name + 'At'] = function(offset, isParameter) {
|
||||||
|
var loc = this.getLocationAt(offset, isParameter);
|
||||||
|
return loc && loc[name]();
|
||||||
|
};
|
||||||
|
},
|
||||||
|
/** @lends Path# */{
|
||||||
// Explicitly deactivate the creation of beans, as we have functions here
|
// Explicitly deactivate the creation of beans, as we have functions here
|
||||||
// that look like bean getters but actually read arguments.
|
// that look like bean getters but actually read arguments.
|
||||||
// See #getLocationOf(), #getNearestLocation(), #getNearestPoint()
|
// See #getLocationOf(), #getNearestLocation(), #getNearestPoint()
|
||||||
|
@ -1684,6 +1691,7 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
/**
|
/**
|
||||||
* Calculates the point on the path at the given offset.
|
* Calculates the point on the path at the given offset.
|
||||||
*
|
*
|
||||||
|
* @name Path#getPointAt
|
||||||
* @param {Number} offset the offset on the path, where {@code 0} is at
|
* @param {Number} offset the offset on the path, where {@code 0} is at
|
||||||
* the beginning of the path and {@link Path#length} at the end.
|
* the beginning of the path and {@link Path#length} at the end.
|
||||||
* @param {Boolean} [isParameter=false]
|
* @param {Boolean} [isParameter=false]
|
||||||
|
@ -1741,15 +1749,12 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
* });
|
* });
|
||||||
* }
|
* }
|
||||||
*/
|
*/
|
||||||
getPointAt: function(offset, isParameter) {
|
|
||||||
var loc = this.getLocationAt(offset, isParameter);
|
|
||||||
return loc && loc.getPoint();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Calculates the tangent to the path at the given offset as a vector
|
* Calculates the tangent to the path at the given offset as a vector
|
||||||
* point.
|
* point.
|
||||||
*
|
*
|
||||||
|
* @name Path#getTangentAt
|
||||||
* @param {Number} offset the offset on the path, where {@code 0} is at
|
* @param {Number} offset the offset on the path, where {@code 0} is at
|
||||||
* the beginning of the path and {@link Path#length} at the end.
|
* the beginning of the path and {@link Path#length} at the end.
|
||||||
* @param {Boolean} [isParameter=false]
|
* @param {Boolean} [isParameter=false]
|
||||||
|
@ -1815,14 +1820,11 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
* })
|
* })
|
||||||
* }
|
* }
|
||||||
*/
|
*/
|
||||||
getTangentAt: function(offset, isParameter) {
|
|
||||||
var loc = this.getLocationAt(offset, isParameter);
|
|
||||||
return loc && loc.getTangent();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Calculates the normal to the path at the given offset as a vector point.
|
* Calculates the normal to the path at the given offset as a vector point.
|
||||||
*
|
*
|
||||||
|
* @name Path#getNormalAt
|
||||||
* @param {Number} offset the offset on the path, where {@code 0} is at
|
* @param {Number} offset the offset on the path, where {@code 0} is at
|
||||||
* the beginning of the path and {@link Path#length} at the end.
|
* the beginning of the path and {@link Path#length} at the end.
|
||||||
* @param {Boolean} [isParameter=false]
|
* @param {Boolean} [isParameter=false]
|
||||||
|
@ -1888,10 +1890,6 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
* });
|
* });
|
||||||
* }
|
* }
|
||||||
*/
|
*/
|
||||||
getNormalAt: function(offset, isParameter) {
|
|
||||||
var loc = this.getLocationAt(offset, isParameter);
|
|
||||||
return loc && loc.getNormal();
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the nearest location on the path to the specified point.
|
* Returns the nearest location on the path to the specified point.
|
||||||
|
@ -1951,7 +1949,7 @@ var Path = PathItem.extend(/** @lends Path# */{
|
||||||
getNearestPoint: function(/* point */) {
|
getNearestPoint: function(/* point */) {
|
||||||
return this.getNearestLocation.apply(this, arguments).getPoint();
|
return this.getNearestLocation.apply(this, arguments).getPoint();
|
||||||
}
|
}
|
||||||
}, new function() { // Scope for drawing
|
}), new function() { // Scope for drawing
|
||||||
|
|
||||||
// Note that in the code below we're often accessing _x and _y on point
|
// Note that in the code below we're often accessing _x and _y on point
|
||||||
// objects that were read from segments. This is because the SegmentPoint
|
// objects that were read from segments. This is because the SegmentPoint
|
||||||
|
|
Loading…
Reference in a new issue