paper.js/src/path/CurveLocation.js

198 lines
4.8 KiB
JavaScript
Raw Normal View History

2011-04-11 13:27:11 -04:00
/*
* Paper.js
*
2011-04-11 13:27:11 -04:00
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
* based on Scriptographer.org and designed to be largely API compatible.
* http://paperjs.org/
* http://scriptographer.org/
*
2011-04-11 13:27:11 -04:00
* Distributed under the MIT license. See LICENSE file for details.
*
2011-04-11 13:27:11 -04:00
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
* http://lehni.org/ & http://jonathanpuckey.com/
*
2011-04-11 13:27:11 -04:00
* All rights reserved.
*/
/**
* @name CurveLocation
*
* @class CurveLocation objects describe a location on {@link Curve}
* objects, as defined by the curve {@link #parameter}, a value between
* {@code 0} (beginning of the curve) and {@code 1} (end of the curve). If
* the curve is part of a {@link Path} item, its {@link #index} inside the
* {@link Path#curves} array is also provided.
*/
CurveLocation = Base.extend(/** @lends CurveLocation# */{
// DOCS: CurveLocation class description: add this comment back when the
// mentioned functioned have been added:
// The class is in use in many places, such as {@link Path#getLocationAt(offset)},
// {@link Path#getLength(CurveLocation)}, {@link Path#getPoint(length)},
// {@link Path#split(CurveLocation)},
// {@link PathItem#getIntersections(PathItem)}, etc.
2011-05-23 11:39:26 -04:00
/**
* Creates a new CurveLocation object.
*
2011-05-23 11:39:26 -04:00
* @param {Curve} curve
* @param {Number} parameter
2011-05-23 11:39:26 -04:00
* @param {Point} point
*/
2011-04-11 13:27:11 -04:00
initialize: function(curve, parameter, point) {
this._curve = curve;
this._parameter = parameter;
this._point = point;
},
/**
* The segment of the curve which is closer to the described location.
*
2011-05-23 11:39:26 -04:00
* @type Segment
* @bean
2011-04-11 13:27:11 -04:00
*/
getSegment: function() {
if (!this._segment) {
var parameter = this.getParameter();
if (parameter == 0) {
this._segment = curve._segment1;
2011-04-11 13:27:11 -04:00
} else if (parameter == 1) {
this._segment = curve._segment2;
2011-05-01 08:16:25 -04:00
} else if (parameter == null) {
2011-04-11 13:27:11 -04:00
return null;
} else {
// Determine the closest segment by comparing curve lengths
this._segment = curve.getLength(0, parameter)
< curve.getLength(parameter, 1)
? curve._segment1
: curve._segment2;
2011-04-11 13:27:11 -04:00
}
}
return this._segment;
},
/**
* The curve by which the location is defined.
*
2011-05-23 11:39:26 -04:00
* @type Curve
* @bean
2011-04-11 13:27:11 -04:00
*/
getCurve: function() {
return this._curve;
},
/**
* The item this curve belongs to, if any.
*
2011-05-23 11:39:26 -04:00
* @type Item
* @bean
*/
getItem: function() {
return this._curve && this._curve._path;
},
2011-04-11 13:27:11 -04:00
/**
* The index of the curve within the {@link Path#curves} list, if the
2011-04-11 13:27:11 -04:00
* curve is part of a {@link Path} item.
*
2011-05-23 11:39:26 -04:00
* @type Index
* @bean
2011-04-11 13:27:11 -04:00
*/
getIndex: function() {
return this._curve && this._curve.getIndex();
2011-04-11 13:27:11 -04:00
},
/**
* The length of the path from its beginning up to the location described
* by this object.
*
* @type Number
2011-05-23 11:39:26 -04:00
* @bean
2011-04-11 13:27:11 -04:00
*/
getOffset: function() {
var path = this._curve && this._curve._path;
return path && path._getOffset(this);
2011-04-11 13:27:11 -04:00
},
/**
* The length of the curve from its beginning up to the location described
* by this object.
*
* @type Number
2011-05-23 11:39:26 -04:00
* @bean
2011-04-11 13:27:11 -04:00
*/
getCurveOffset: function() {
var parameter = this._curve && this.getParameter();
return parameter != null ? this._curve.getLength(0, parameter) : null;
2011-04-11 13:27:11 -04:00
},
/**
* The curve parameter, as used by various bezier curve calculations. It is
* value between {@code 0} (beginning of the curve) and {@code 1} (end of
* the curve).
*
* @type Number
2011-05-23 11:39:26 -04:00
* @bean
2011-04-11 13:27:11 -04:00
*/
getParameter: function() {
if (this._parameter == null && this._point)
2011-05-01 08:16:25 -04:00
this._parameter = this._curve.getParameter(this._point);
return this._parameter;
2011-04-11 13:27:11 -04:00
},
/**
2011-05-23 11:39:26 -04:00
* The point which is defined by the {@link #curve} and
* {@link #parameter}.
*
2011-05-23 11:39:26 -04:00
* @type Point
* @bean
2011-04-11 13:27:11 -04:00
*/
getPoint: function() {
if (!this._point && this._curve) {
var parameter = this.getParameter();
if (parameter != null)
this._point = this._curve.getPoint(parameter);
}
2011-04-11 13:27:11 -04:00
return this._point;
},
/**
2011-05-23 11:39:26 -04:00
* The tangential vector to the {@link #curve} at the given location.
*
2011-05-23 11:39:26 -04:00
* @type Point
* @bean
*/
getTangent: function() {
var parameter = this.getParameter();
return parameter != null && this._curve
&& this._curve.getTangent(parameter);
},
/**
2011-05-23 11:39:26 -04:00
* The normal vector to the {@link #curve} at the given location.
*
2011-05-23 11:39:26 -04:00
* @type Point
* @bean
*/
getNormal: function() {
var parameter = this.getParameter();
return parameter != null && this._curve
&& this._curve.getNormal(parameter);
},
2011-05-23 11:39:26 -04:00
/**
* @return {String} A string representation of the curve location.
2011-05-23 11:39:26 -04:00
*/
2011-04-11 13:27:11 -04:00
toString: function() {
var parts = [],
point = this.getPoint();
if (point)
parts.push('point: ' + point);
2011-04-11 13:27:11 -04:00
var index = this.getIndex();
if (index != null)
parts.push('index: ' + index);
2011-04-11 13:27:11 -04:00
var parameter = this.getParameter();
if (parameter != null)
parts.push('parameter: ' + Base.formatNumber(parameter));
2011-05-02 06:23:42 -04:00
return '{ ' + parts.join(', ') + ' }';
2011-04-11 13:27:11 -04:00
}
});