2021-08-08 14:57:52 +08:00
|
|
|
use <ptf/ptf_rotate.scad>;
|
2021-10-08 09:36:01 +08:00
|
|
|
use <polyline_join.scad>;
|
2021-08-08 14:57:52 +08:00
|
|
|
use <shape_superformula.scad>;
|
|
|
|
|
|
|
|
function shape2wire(shape, r) =
|
|
|
|
let(
|
|
|
|
leng_shape = len(shape),
|
|
|
|
a = 360 / leng_shape
|
|
|
|
)
|
|
|
|
[
|
|
|
|
for(i = [0:len(shape) - 1])
|
|
|
|
let(p = shape[i])
|
|
|
|
ptf_rotate(
|
|
|
|
ptf_rotate([p[0], p[1], 0], [90, 0, 0]) + [r, 0, 0],
|
|
|
|
a * i
|
|
|
|
)
|
|
|
|
];
|
|
|
|
|
|
|
|
phi_step = 0.05;
|
|
|
|
m = 16;
|
|
|
|
n = 0.5;
|
|
|
|
n3 = 16;
|
|
|
|
shape = shape_superformula(phi_step, m, m, n, n, n3) * 30;
|
|
|
|
|
|
|
|
translate([150, 0])
|
|
|
|
rotate([90, 0, 0])
|
|
|
|
linear_extrude(1, center = true)
|
|
|
|
difference() {
|
|
|
|
square(120, center = true);
|
2021-10-08 09:36:01 +08:00
|
|
|
polyline_join(concat(shape, [shape[0]]))
|
|
|
|
circle(2.5);
|
2021-08-08 14:57:52 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
wire = shape2wire(shape, 150);
|
|
|
|
rotate(-$t * 360)
|
2021-10-08 09:36:01 +08:00
|
|
|
polyline_join(concat(wire, [wire[0]]))
|
|
|
|
sphere(1.5);
|