1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-17 14:18:13 +01:00
dotSCAD/docs/lib3x-curve.md

45 lines
1.2 KiB
Markdown
Raw Normal View History

2020-12-13 10:53:24 +08:00
# curve
Draws a curved line from control points. The curve is drawn only from the 2nd control point to the second-last control point. It's an implementation of [Centripetal Catmull-Rom spline](https://en.wikipedia.org/wiki/Centripetal_Catmull%E2%80%93Rom_spline).
**Since:** 2.5
## Parameters
2022-03-09 10:32:44 +08:00
- `t_step` : 0 ~ 1. Control the distance between two points of the generated curve.
2020-12-13 10:53:24 +08:00
- `points` : A list of `[x, y]` or `[x, y, z]` control points.
- `tightness` : You can view it as the curve tigntness if you provide a value between 0.0 and 1.0. The default value is 0.0. The value 1.0 connects all the points with straight lines. The value greater than 1.0 or less than 0.0 is also acceptable because it defines how to generate a bezier curve every four control points.
2021-02-24 21:09:54 +08:00
![curve](images/lib3x-curve-1.JPG)
2020-12-13 10:53:24 +08:00
2021-02-24 21:09:54 +08:00
![curve](images/lib3x-curve-2.JPG)
2020-12-13 10:53:24 +08:00
## Examples
use <curve.scad>;
2021-11-18 08:08:50 +08:00
use <polyline_join.scad>;
2020-12-13 10:53:24 +08:00
pts = [
[28, 2, 1],
[15, 8, -10],
[2, 14, 5],
[28, 14, 2],
[15, 21, 9],
[2, 28, 0]
];
t_step = 0.05;
tightness = 0;
points = curve(t_step, pts, tightness);
2021-11-18 08:08:50 +08:00
polyline_join(points)
sphere(.5);
2020-12-13 10:53:24 +08:00
#for(pt = pts) {
translate(pt)
sphere(1);
}
2021-11-18 08:08:50 +08:00
#polyline_join(pts)
sphere(.05);
2020-12-13 10:53:24 +08:00
2021-02-24 21:09:54 +08:00
![curve](images/lib3x-curve-3.JPG)