1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-18 06:38:14 +01:00
dotSCAD/examples/taiwan/voronoi_taiwan.scad
2021-04-24 11:47:31 +08:00

40 lines
867 B
OpenSCAD

use <triangle/tri_delaunay.scad>;
use <hull_polyline2d.scad>;
use <shape_taiwan.scad>;
use <in_shape.scad>;
voronoi_taiwan();
module voronoi_taiwan() {
taiwan = shape_taiwan(120, distance = 1);
n = 40;
xs = rands(-15, 15, n);
ys = rands(-30, 40, n);
pts = [
for(i = [0:n - 1])
let(p = [xs[i], ys[i]])
if(in_shape(taiwan, p, true))
p
];
all = concat(taiwan, pts);
cells = tri_delaunay(all, ret = "VORONOI_CELLS");
for(i = [0:len(cells) - 1]) {
color(rands(0, 1, 3))
translate(all[i])
linear_extrude(2, scale = 0.8)
translate(-all[i])
intersection() {
polygon(taiwan);
polygon(cells[i]);
}
}
color("black")
linear_extrude(.75)
offset(1)
polygon(taiwan);
}