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

103 lines
2.1 KiB
Markdown
Raw Normal View History

2017-04-23 11:16:34 +08:00
# along_with
Puts children along the given path. If there's only one child, it will put the child for each point.
## Parameters
- `points` : The points along the path.
2017-05-19 11:24:43 +08:00
- `angles` : Rotate before translate each child. If not given, `angles` will be calculated automatically according to `points`.
2017-04-23 11:16:34 +08:00
## Examples
include <along_with.scad>;
include <circle_path.scad>;
$fn = 24;
points = circle_path(radius = 50);
along_with(points)
sphere(5, center = true);
![along_with](images/lib-along_with-1.JPG)
include <along_with.scad>;
include <circle_path.scad>;
2017-05-19 11:30:20 +08:00
2017-04-23 11:16:34 +08:00
$fn = 24;
2017-05-19 11:30:20 +08:00
2017-04-23 11:16:34 +08:00
points = circle_path(radius = 50);
2017-05-19 11:30:20 +08:00
2017-04-23 11:16:34 +08:00
along_with(points) {
2017-05-19 11:30:20 +08:00
linear_extrude(10, center = true) text("A", valign = "center", halign = "center");
linear_extrude(5, center = true) circle(2);
sphere(1);
cube(5);
linear_extrude(10, center = true) text("A", valign = "center", halign = "center");
linear_extrude(5, center = true) circle(2);
sphere(1);
cube(5);
2017-04-23 11:16:34 +08:00
}
![along_with](images/lib-along_with-2.JPG)
2017-05-03 16:29:10 +08:00
include <along_with.scad>;
include <circle_path.scad>;
include <rotate_p.scad>;
include <golden_spiral.scad>;
pts_angles = golden_spiral(
from = 5,
to = 11,
point_distance = 4
);
points = [for(p_a = pts_angles) p_a[0]];
angles = [for(p_a = pts_angles) p_a[1]];
along_with(points, angles)
rotate([90, 0, 0])
linear_extrude(1, center = true)
text("A", valign = "center", halign = "center");
2017-05-19 11:24:43 +08:00
![along_with](images/lib-along_with-3.JPG)
include <bezier_curve.scad>;
include <along_with.scad>;
module scales() {
module one_scale() {
rotate([0, 60, 0])
linear_extrude(1, center = true)
scale([2, 1])
circle(1.25, $fn = 24);
}
2017-05-19 12:59:52 +08:00
for(a = [0:30:330]) {
2017-05-19 11:31:36 +08:00
rotate(a)
translate([5, 0, 0])
one_scale();
rotate(a + 15)
translate([5, 0, 1.75])
one_scale();
2017-05-19 11:24:43 +08:00
}
}
t_step = 0.01;
p0 = [0, 0, 0];
p1 = [0, 50, 35];
p2 = [-100, 70, 0];
p3 = [30, 120, -35];
p4 = [30, 150, -40];
p5 = [0, 200, -3];
path_pts = bezier_curve(t_step,
[p0, p1, p2, p3, p4, p5]
);
along_with(path_pts)
scales();
![along_with](images/lib-along_with-4.JPG)