2011-04-11 13:27:11 -04:00
|
|
|
/*
|
|
|
|
* Paper.js
|
|
|
|
*
|
|
|
|
* 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/
|
|
|
|
*
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
|
|
*
|
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
CurveLocation = Base.extend({
|
|
|
|
beans: true,
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
getSegment: function() {
|
|
|
|
if (!this._segment) {
|
|
|
|
var parameter = this.getParameter();
|
|
|
|
if (parameter == 0) {
|
2011-04-27 15:48:41 -04:00
|
|
|
this._segment = curve._segment1;
|
2011-04-11 13:27:11 -04:00
|
|
|
} else if (parameter == 1) {
|
2011-04-27 15:48:41 -04:00
|
|
|
this._segment = curve._segment2;
|
2011-04-11 13:27:11 -04:00
|
|
|
} else if (parameter == -1) {
|
|
|
|
return null;
|
|
|
|
} else {
|
|
|
|
// Determine the closest segment by comparing curve lengths
|
|
|
|
var rightCurve = curve.clone().divide(parameter);
|
|
|
|
this._segment = rightCurve.getLength() > curve.getLength() / 2
|
2011-04-27 15:48:41 -04:00
|
|
|
? curve._segment1
|
|
|
|
: curve._segment2;
|
2011-04-11 13:27:11 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return this._segment;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The curve by which the location is defined.
|
|
|
|
*/
|
|
|
|
getCurve: function() {
|
|
|
|
return this._curve;
|
|
|
|
},
|
|
|
|
|
2011-04-26 12:49:54 -04:00
|
|
|
/**
|
2011-04-27 14:22:57 -04:00
|
|
|
* The item this curve belongs to, if any.
|
2011-04-26 12:49:54 -04:00
|
|
|
*/
|
2011-04-27 14:22:57 -04:00
|
|
|
getItem: function() {
|
2011-04-27 15:48:41 -04:00
|
|
|
return this._curve && this._curve._path;
|
2011-04-26 12:49:54 -04:00
|
|
|
},
|
|
|
|
|
2011-04-11 13:27:11 -04:00
|
|
|
/**
|
|
|
|
* The index of the curve within the {@link Path#getCurves()} list, if the
|
|
|
|
* curve is part of a {@link Path} item.
|
|
|
|
*/
|
|
|
|
getIndex: function() {
|
2011-04-26 12:49:54 -04:00
|
|
|
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.
|
|
|
|
*/
|
2011-04-27 15:08:57 -04:00
|
|
|
getOffset: function() {
|
2011-04-27 15:48:41 -04:00
|
|
|
var path = this._curve && this._curve._path;
|
2011-04-27 15:08:57 -04:00
|
|
|
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.
|
|
|
|
*/
|
2011-04-27 15:08:57 -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).
|
|
|
|
*/
|
|
|
|
getParameter: function() {
|
2011-04-27 14:24:40 -04:00
|
|
|
if (this._parameter == null && this._point)
|
2011-04-11 13:27:11 -04:00
|
|
|
this._parameter = this._curve.getParameter(point);
|
2011-04-26 12:49:54 -04:00
|
|
|
return this._parameter;
|
2011-04-11 13:27:11 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The point which is defined by the {@link #getCurve()} and
|
|
|
|
* {@link #getParameter()}.
|
|
|
|
*/
|
|
|
|
getPoint: function() {
|
2011-04-27 14:24:40 -04:00
|
|
|
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-04-27 14:26:03 -04:00
|
|
|
/**
|
|
|
|
* The tangential vector to the {@link #getCurve()} at the given location.
|
|
|
|
*/
|
|
|
|
getTangent: function() {
|
|
|
|
var parameter = this.getParameter();
|
|
|
|
return parameter != null && this._curve
|
|
|
|
&& this._curve.getTangent(parameter);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The normal vector to the {@link #getCurve()} at the given location.
|
|
|
|
*/
|
|
|
|
getNormal: function() {
|
|
|
|
var parameter = this.getParameter();
|
|
|
|
return parameter != null && this._curve
|
|
|
|
&& this._curve.getNormal(parameter);
|
|
|
|
},
|
|
|
|
|
2011-04-11 13:27:11 -04:00
|
|
|
toString: function() {
|
2011-04-26 12:49:54 -04:00
|
|
|
var parts = [];
|
2011-04-27 14:24:40 -04:00
|
|
|
var point = this.getPoint();
|
|
|
|
if (point)
|
|
|
|
parts.push('point: ' + point);
|
2011-04-11 13:27:11 -04:00
|
|
|
var index = this.getIndex();
|
|
|
|
if (index >= 0)
|
2011-04-26 12:49:54 -04:00
|
|
|
parts.push('index: ' + index);
|
2011-04-11 13:27:11 -04:00
|
|
|
var parameter = this.getParameter();
|
|
|
|
if (parameter != -1)
|
2011-04-26 12:49:54 -04:00
|
|
|
parts.push('parameter: ' + parameter);
|
|
|
|
return '{ ' + parts.join(', ') + ' }'
|
2011-04-11 13:27:11 -04:00
|
|
|
}
|
2011-04-11 13:33:34 -04:00
|
|
|
});
|