Package Exports
- d3-interpolate-path
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (d3-interpolate-path) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
d3-interpolate-path
Demo: http://peterbeshai.com/vis/d3-interpolate-path/
Example Usage
var line = d3.line()
.curve(d3.curveLinear)
.x(function (d) { return x(d.x); })
.y(function (d) { return y(d.y); });
d3.select('path.my-path')
.transition()
.duration(2000)
.attrTween('d', function (d) {
var previous = d3.select(this).attr('d');
var current = line(d);
return d3.interpolatePath(previous, current);
});
Development
Get rollup watching for changes and rebuilding
npm run watch
Run a web server in the example directory
cd example
php -S localhost:8000
Go to http://localhost:8000
Installing
If you use NPM, npm install d3-interpolate-path
. Otherwise, download the latest release.
API Reference
# interpolatePath(a, b)
Returns an interpolator between two path attribute d
strings a and b. The interpolator extends a and b to have the same number of points before using d3.interpolateString on them.
var pathInterpolator = interpolatePath('M0,0 L10,10', 'M10,10 L20,20 L30,30')
pathInterpolator(0) // 'M0,0 L10,10 L10,10'
pathInterpolator(0.5) // 'M5,5 L15,15 L20,20'
pathInterpolator(1) // 'M10,10 L20,20 L30,30'