Add documentation for PathItem#smooth() and Segment#smooth()

Closes #338
This commit is contained in:
Jürg Lehni 2016-01-15 18:14:22 +01:00
parent 96c50abce2
commit 56e0048186
3 changed files with 100 additions and 29 deletions

@ -1 +1 @@
Subproject commit 7e4f5ce24f6e88130f8a87261d6491f0c036757a Subproject commit f2224b7437812263c2fb071c71fb1d0a59c2e15b

View file

@ -317,25 +317,71 @@ var PathItem = Item.extend(/** @lends PathItem# */{
/*#*/ } // !__options.nativeContains && __options.booleanOperations /*#*/ } // !__options.nativeContains && __options.booleanOperations
} }
/** // TODO: Write about negative indices, and add an example for ranges.
* TODO: continuous:
* Smooths the path item by adjusting its curve handles so that the first
* and second derivatives of all involved curves are continuous across their
* boundaries.
*/
/** /**
* Smooths the path item without changing the amount of segments in the path * Smooths the path item without changing the amount of segments in the path
* or moving their locations, by only smoothing and adjusting the angle and * or moving the segments' locations, by smoothing and adjusting the angle
* length of their handles. * and length of the segments' handles based on the position and distance of
* This works for open paths as well as closed paths. * neighboring segments.
*
* Smoothing works both for open paths and closed paths, and can be applied
* to the full path, as well as a sub-range of it. If a range is defined
* using the `options.from` and `options.to` properties, only the curve
* handles inside that range are touched.
*
* Four different smoothing methods are available:
*
* - `'continuous'` smooths the path item by adjusting its curve handles so
* that the first and second derivatives of all involved curves are
* continuous across their boundaries.
*
* This method tends to result in the smoothest results, but does not
* allow for further parametrization of the handles.
*
* - `'asymmetric'` is based on the same principle as `'continuous'` but
* uses different factors so that the result is asymmetric. This used to
* the only method available until v0.10.0, and is currently still the
* default when no method is specified, for reasons of backward
* compatibility. It will eventually be removed.
*
* - `'catmull-rom'` uses the Catmull-Rom spline to smooth the segment.
*
* The optionally passed factor controls the knot parametrization of the
* algorithm:
*
* - `0.0`: the standard, uniform Catmull-Rom spline
* - `0.5`: the centripetal Catmull-Rom spline, guaranteeing no
* self-intersections
* - `1.0`: the chordal Catmull-Rom spline
*
* - `'geometric'` use a simple heuristic and empiric geometric method to
* smooth the segment's handles. The handles were weighted, meaning that
* big differences in distances between the segments will lead to
* probably undesired results.
*
* The optionally passed factor defines the tension parameter (`0...1`),
* controlling the amount of smoothing as a factor by which to scale
* each handle.
* *
* @name PathItem#smooth * @name PathItem#smooth
* @function * @function
* @param {Object} [options] TODO
* TODO: controls the amount of smoothing as a factor by which to scale each
* handle.
* *
* @see Segment#smooth(options) * @option [options.type='asymmetric'] {String} the type of smoothing
* method: {@values 'continuous', 'asymmetric', 'catmull-rom',
* 'geometric'}
* @option options.factor {Number} the factor parameterizing the smoothing
* method default: `0.5` for `'catmull-rom'`, `0.4` for `'geometric'`
* @option options.from {Number|Segment|Curve} the segment or curve at which
* to start smoothing, if not the full path shall be smoothed
* (inclusive). This can either be a segment index, or a segment or
* curve object that is part of the path.
* @option options.to {Number|Segment|Curve} the segment or curve to which
* the handles of the path shall be processed (inclusive). This can
* either be a segment index, or a segment or curve object that is part
* of the path.
*
* @param {Object} [options] the smoothing options
* @see Segment#smooth([options])
* *
* @example {@paperscript} * @example {@paperscript}
* // Smoothing a closed shape: * // Smoothing a closed shape:
@ -353,7 +399,7 @@ var PathItem = Item.extend(/** @lends PathItem# */{
* copy.position.x += 100; * copy.position.x += 100;
* *
* // Smooth the segments of the copy: * // Smooth the segments of the copy:
* copy.smooth(); * copy.smooth({ type: 'continuous' });
* *
* @example {@paperscript height=220} * @example {@paperscript height=220}
* var path = new Path(); * var path = new Path();
@ -374,11 +420,11 @@ var PathItem = Item.extend(/** @lends PathItem# */{
* var copy = path.clone(); * var copy = path.clone();
* copy.position.y += 120; * copy.position.y += 120;
* *
* // Set its stroke color to red: * // Select the path, so we can see its handles:
* copy.strokeColor = 'red'; * copy.fullySelected = true;
* *
* // Smooth the segments of the copy: * // Smooth the segments of the copy:
* copy.smooth(); * copy.smooth({ type: 'catmull-rom', factor: 0.5 });
*/ */
/** /**

View file

@ -32,11 +32,11 @@ var Segment = Base.extend(/** @lends Segment# */{
* @name Segment#initialize * @name Segment#initialize
* @param {Point} [point={x: 0, y: 0}] the anchor point of the segment * @param {Point} [point={x: 0, y: 0}] the anchor point of the segment
* @param {Point} [handleIn={x: 0, y: 0}] the handle point relative to the * @param {Point} [handleIn={x: 0, y: 0}] the handle point relative to the
* anchor point of the segment that describes the in tangent of the * anchor point of the segment that describes the in tangent of the
* segment * segment
* @param {Point} [handleOut={x: 0, y: 0}] the handle point relative to the * @param {Point} [handleOut={x: 0, y: 0}] the handle point relative to the
* anchor point of the segment that describes the out tangent of the * anchor point of the segment that describes the out tangent of the
* segment * segment
* *
* @example {@paperscript} * @example {@paperscript}
* var handleIn = new Point(-80, -100); * var handleIn = new Point(-80, -100);
@ -381,15 +381,40 @@ var Segment = Base.extend(/** @lends Segment# */{
}, },
/** /**
* Smooths the bezier curves that pass through this segment without moving * Smooths the bezier curves that pass through this segment by taking into
* its point, by taking into its distance to the neighboring segments and * account the segment's position and distance to the neighboring segments
* changing the direction and length of the segment's handles accordingly. * and changing the direction and length of the segment's handles
* accordingly without moving the segment itself.
* *
* @param {Object} [options] TODO * Two different smoothing methods are available:
* TODO: controls the amount of smoothing as a factor by which to scale each
* handle.
* *
* @see PathItem#smooth(options) * - `'catmull-rom'` uses the Catmull-Rom spline to smooth the segment.
*
* The optionally passed factor controls the knot parametrization of the
* algorithm:
*
* - `0.0`: the standard, uniform Catmull-Rom spline
* - `0.5`: the centripetal Catmull-Rom spline, guaranteeing no
* self-intersections
* - `1.0`: the chordal Catmull-Rom spline
*
* - `'geometric'` use a simple heuristic and empiric geometric method to
* smooth the segment's handles. The handles were weighted, meaning that
* big differences in distances between the segments will lead to
* probably undesired results.
*
* The optionally passed factor defines the tension parameter (`0...1`),
* controlling the amount of smoothing as a factor by which to scale
* each handle.
*
* @option [options.type='catmull-rom'] {String} the type of smoothing
* method: {@values 'catmull-rom', 'geometric'}
* @option options.factor {Number} the factor parameterizing the smoothing
* method default: `0.5` for `'catmull-rom'`, `0.4` for `'geometric'`
*
* @param {Object} [options] the smoothing options
*
* @see PathItem#smooth([options])
*/ */
smooth: function(options, _first, _last) { smooth: function(options, _first, _last) {
// _first = _last = false; // _first = _last = false;