1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-18 06:38:14 +01:00
dotSCAD/docs/lib-voronoi2d.md
Justin Lin 810a1d3ece rename
2019-06-07 17:46:17 +08:00

1.4 KiB

voronoi2d

Creats a Voronoi diagram. The initial region for each cell is calculated automatically from the given points by the following code:

xs = [for(p = points) p[0]];
ys = [for(p = points) abs(p[1])];
region_size = max([(max(xs) -  min(xs) / 2), (max(ys) -  min(ys)) / 2]);    

Since: 1.3.

Parameters

  • points : Points for each cell.
  • spacing : Distance between cells. Default to 1.
  • r, delta, chamfer : The outlines of each cell can be moved outward or inward. These parameters have the same effect as offset.
  • region_type : The initial shape for each cell can be "square" or "circle". Default to "square".

Examples

include <voronoi2d.scad>;

xs = rands(-20, 20, 50);
ys = rands(-20, 20, 50);

points = [for(i = [0:len(xs) - 1]) [xs[i], ys[i]]];

voronoi2d(points);
translate([60, 0, 0]) 
    voronoi(points, region_type = "circle");

voronoi2d

include <voronoi2d.scad>;
include <hollow_out.scad>;

xs = rands(0, 40, 50);
ys = rands(0, 20, 50);

points = [for(i = [0:len(xs) - 1]) [xs[i], ys[i]]];

difference() {
    square([40, 20]);
    voronoi2d(points);
}
hollow_out(shell_thickness = 1) square([40, 20]);

voronoi2d