1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-02-19 15:14:40 +01:00
dotSCAD/examples/spiral_polygons/stick_tower.scad

83 lines
2.0 KiB
OpenSCAD
Raw Normal View History

2022-06-06 13:11:46 +08:00
use <line3d.scad>
2019-09-23 08:26:54 +08:00
/* [Basic] */
stick_leng = 80;
2021-02-19 11:24:34 +08:00
stick_diameter = 5;
2019-09-23 08:26:54 +08:00
inner_square_leng = 60;
leng_diff = 1.75;
min_leng = 13;
stick_fn = 24;
/* [Advanced] */
cap_style = "CAP_CIRCLE"; // [CAP_BUTT, CAP_CIRCLE, CAP_SPHERE]
angle_offset = 5;
layer_offset = 1.2;
2021-02-19 11:24:34 +08:00
module stick_square(inner_square_leng, stick_leng, stick_diameter, cap_style) {
2019-09-23 08:26:54 +08:00
diff_leng = stick_leng - inner_square_leng;
half_inner_square_leng = inner_square_leng / 2;
half_stick_leng = stick_leng / 2;
module stick() {
line3d(
[0, -half_stick_leng, 0],
[0, half_stick_leng, 0],
2021-02-19 11:24:34 +08:00
stick_diameter,
2019-09-23 08:26:54 +08:00
cap_style,
cap_style
);
}
module sticks() {
translate([-half_inner_square_leng, 0, 0])
stick();
translate([half_inner_square_leng, 0, 0])
stick();
}
sticks();
2021-02-19 11:24:34 +08:00
translate([0, 0, stick_diameter])
2019-09-26 08:53:47 +08:00
rotate(90)
sticks();
2019-09-23 08:26:54 +08:00
}
module spiral_stack(orig_leng, orig_height, current_leng, leng_diff, min_leng, angle_offset, pre_height = 0, i = 0) {
if(current_leng > min_leng) {
angle = atan2(leng_diff, current_leng - leng_diff);
factor = current_leng / orig_leng;
translate([0, 0, pre_height])
2019-09-26 08:53:47 +08:00
scale(factor)
children();
2019-09-23 08:26:54 +08:00
next_square_leng = sqrt(pow(leng_diff, 2) + pow(current_leng - leng_diff, 2));
height = factor * orig_height + pre_height;
rotate(angle + angle_offset)
spiral_stack(
orig_leng,
orig_height,
next_square_leng,
leng_diff,
min_leng,
angle_offset,
height,
i + 1
) children();
}
}
2021-02-19 11:24:34 +08:00
height = stick_diameter * layer_offset;
2019-09-23 08:26:54 +08:00
$fn = stick_fn;
2021-02-19 11:24:34 +08:00
spiral_stack(inner_square_leng, stick_diameter * 2, inner_square_leng, leng_diff, min_leng, angle_offset)
2019-09-23 08:26:54 +08:00
stick_square(
inner_square_leng,
stick_leng,
height,
cap_style
);