2020-01-28 09:52:16 +08:00
|
|
|
use <trim_shape.scad>;
|
|
|
|
use <bezier_curve.scad>;
|
|
|
|
use <shape_taiwan.scad>;
|
2021-08-14 09:10:11 +08:00
|
|
|
use <rail_extruded_sections.scad>;
|
2020-05-23 16:57:12 +08:00
|
|
|
use <sweep.scad>;
|
2020-03-24 17:21:17 +08:00
|
|
|
use <ptf/ptf_rotate.scad>;
|
2020-01-28 09:52:16 +08:00
|
|
|
use <bijection_offset.scad>;
|
2019-07-13 18:21:04 +08:00
|
|
|
|
|
|
|
x1 = 4; // [-20:4]
|
|
|
|
x2 = 3; // [-20:4]
|
|
|
|
x3 = 4; // [-20:4]
|
|
|
|
y1 = 20;
|
|
|
|
y2 = 40;
|
|
|
|
y3 = 90;
|
|
|
|
twist = -90;
|
|
|
|
t_step = 0.1;
|
|
|
|
|
|
|
|
module dancing_formosan(x1, x2, x3, y1, y2, y3, twist, t_step) {
|
|
|
|
|
|
|
|
function cal_sections(shapt_pts, edge_path, twist) =
|
|
|
|
let(
|
2021-08-14 09:10:11 +08:00
|
|
|
sects = rail_extruded_sections(shapt_pts, edge_path),
|
2019-07-13 18:21:04 +08:00
|
|
|
leng = len(sects),
|
|
|
|
twist_step = twist / leng
|
|
|
|
)
|
|
|
|
[
|
|
|
|
for(i = [0:leng - 1])
|
|
|
|
[
|
|
|
|
for(p = sects[i])
|
2020-03-24 17:21:17 +08:00
|
|
|
ptf_rotate(p, twist_step * i)
|
2019-07-13 18:21:04 +08:00
|
|
|
]
|
|
|
|
];
|
|
|
|
|
|
|
|
taiwan = shape_taiwan(100, 0.6);
|
|
|
|
fst_pt = [13, 0, 0];
|
|
|
|
|
|
|
|
edge_path = bezier_curve(t_step, [
|
|
|
|
fst_pt,
|
|
|
|
fst_pt + [0, 0, 10],
|
|
|
|
fst_pt + [x1, 0, y1],
|
|
|
|
fst_pt + [x2, 0, 35],
|
|
|
|
fst_pt + [x3, 0, y2],
|
|
|
|
fst_pt + [0, 0, 55],
|
|
|
|
fst_pt + [0, 0, y3]
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
|
|
offseted = bijection_offset(taiwan, -2);
|
|
|
|
|
2019-07-14 10:15:27 +08:00
|
|
|
edge_path2 = [for(p = edge_path) p + [-2, 0, 0]];
|
2019-07-13 18:21:04 +08:00
|
|
|
taiwan2 = trim_shape(offseted, 1, len(offseted) - 4);
|
|
|
|
|
|
|
|
sections = cal_sections(taiwan, edge_path, twist);
|
2019-07-14 10:15:27 +08:00
|
|
|
sections2 = cal_sections(taiwan2, edge_path2, twist);
|
2019-07-13 18:21:04 +08:00
|
|
|
|
|
|
|
difference() {
|
2020-05-23 16:57:12 +08:00
|
|
|
sweep(sections);
|
|
|
|
sweep(sections2);
|
2019-07-13 18:21:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
translate([0, 0, -2])
|
2019-09-26 08:53:47 +08:00
|
|
|
linear_extrude(2)
|
|
|
|
rotate(twist - twist / len(sections))
|
|
|
|
polygon(taiwan);
|
2019-07-13 18:21:04 +08:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
dancing_formosan(x1, x2, x3, y1, y2, y3, twist, t_step);
|
|
|
|
|