1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-17 22:28:16 +01:00
dotSCAD/examples/spiral/string_tetrahedrons.scad

109 lines
3.2 KiB
OpenSCAD
Raw Normal View History

2020-09-22 13:40:26 +08:00
use <hull_polyline3d.scad>;
level = 1;
leng = 50;
2021-02-18 10:45:44 +08:00
diameter = 5;
2020-09-22 13:40:26 +08:00
segs_per_side = 10;
center = false;
2021-02-18 10:45:44 +08:00
module string_tetrahedron(leng, diameter, segs_per_side, line_fn) {
module lines_between(side1, side2, diameter, segs) {
2020-09-22 13:40:26 +08:00
function pts(p1, p2, segs) =
let(
p = p2 - p1,
dx = p[0] / segs,
dy = p[1] / segs,
dz = p[2] / segs
) [for(i = [0:segs]) p1 + [dx, dy, dz] * i];
pts1 = pts(side1[0], side1[1], segs);
pts2 = pts(side2[0], side2[1], segs);
leng = len(pts1);
2021-02-18 10:45:44 +08:00
hull_polyline3d(points = [pts1[0], pts2[0]], diameter = diameter);
2020-09-22 13:40:26 +08:00
for(i = [1:leng - 2]) {
2021-02-18 10:45:44 +08:00
hull_polyline3d(points = [pts1[i], pts2[i]], diameter = diameter);
2020-09-22 13:40:26 +08:00
}
end = leng - 1;
2021-02-18 10:45:44 +08:00
hull_polyline3d(points = [pts1[end], pts2[end]], diameter = diameter);
2020-09-22 13:40:26 +08:00
}
function height(leng) =
leng * sqrt(1 - 4 / 9 * pow(sin(60), 2));
function vts(leng) =
let(
half_leng = leng / 2,
center_y = half_leng * tan(30),
vt1 = [half_leng, - center_y, 0],
vt2 = [0, leng * sin(60) - center_y, 0],
vt3 = [-half_leng, -center_y, 0],
vt4 = [0, 0, height(leng)]
) [vt1, vt2, vt3, vt4];
$fn = line_fn;
half_leng = leng / 2;
vts = vts(leng);
vt1 = vts[0];
vt2 = vts[1];
vt3 = vts[2];
vt4 = vts[3];
2021-02-18 10:45:44 +08:00
lines_between([vt1, vt2], [vt3, vt4], diameter, segs_per_side);
lines_between([vt2, vt3], [vt1, vt4], diameter, segs_per_side);
lines_between([vt3, vt1], [vt2, vt4], diameter, segs_per_side);
2020-09-22 13:40:26 +08:00
}
2021-02-18 10:45:44 +08:00
module string_tetrahedrons(level, leng, diameter, segs_per_side, center) {
2020-09-22 13:40:26 +08:00
function height(leng) =
leng * sqrt(1 - 4 / 9 * pow(sin(60), 2));
if(level == 0) {
2021-02-18 10:45:44 +08:00
string_tetrahedron(leng * 2, diameter, segs_per_side, 6);
2020-09-22 13:40:26 +08:00
}
else {
half_leng = leng / 2;
center_y = half_leng * tan(30);
translate([0, center_y * 2])
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level - 1, half_leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00
translate([half_leng, -center_y])
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level - 1, half_leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00
translate([-half_leng, -center_y])
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level - 1, half_leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00
translate([0, 0, height(leng)])
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level - 1, half_leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00
if(center) {
rotate(60)
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level - 1, half_leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00
a = atan(height(leng * 2) / (2 * center_y));
for(i = [0:120:240]) {
rotate(i)
translate([0, -center_y * 2])
rotate([a, 0, 0])
translate([0, center_y * 2])
rotate([180, 0, 0])
scale(0.9427)
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level - 1, half_leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00
}
}
}
}
2021-02-18 10:45:44 +08:00
string_tetrahedrons(level, leng, diameter, segs_per_side, center);
2020-09-22 13:40:26 +08:00