|  root
				
				3bf41bf355
				update | 2 سال پیش | |
|---|---|---|
| .. | ||
| demo | 2 سال پیش | |
| lib | 2 سال پیش | |
| script | 2 سال پیش | |
| src | 2 سال پیش | |
| test | 2 سال پیش | |
| .babelrc | 2 سال پیش | |
| .bowerrc | 2 سال پیش | |
| LICENSE | 2 سال پیش | |
| README.md | 2 سال پیش | |
| bower.json | 2 سال پیش | |
| demo-screenshot.png | 2 سال پیش | |
| fit-curve.d.ts | 2 سال پیش | |
| package.json | 2 سال پیش | |
JavaScript implementation of Philip J. Schneider's "Algorithm for Automatically Fitting Digitized Curves" from the book "Graphics Gems". Converted from Python implementation.
Fit one or more cubic Bezier curves to a polyline. Works with 2D and 3D curves (and should work for higher dimensions too).
This is a JS implementation of Philip J. Schneider's C code. The original C code is available on http://graphicsgems.org/ as well as in https://github.com/erich666/GraphicsGems
npm install --save fit-curve
var fitCurve = require('fit-curve');
var points = [[0, 0], [10, 10], [10, 0], [20, 0]];
var error = 50; // The smaller the number - the much closer spline should be
var bezierCurves = fitCurve(points, error);
// bezierCurves[0] === [[0, 0], [20.27317402, 20.27317402], [-1.24665147, 0], [20, 0]]
// where each element is [x, y] and elements are [first-point, control-point-1, control-point-2, second-point]
You can play around with that in this demo.
npm install - builds transpiled and minified versions into /lib
npm test - runs tests