1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-08-19 13:01:37 +02:00

add circle_maze

This commit is contained in:
Justin Lin
2020-03-11 09:39:01 +08:00
parent 56c2da387d
commit 5033c415db

View File

@@ -0,0 +1,41 @@
use <hull_polyline2d.scad>;
use <experimental/mz_blocks.scad>;
use <experimental/mz_walls.scad>;
function ptf_circle(point, offset) =
let(
p = [point[0] - offset, point[1] - offset],
n = max(abs(p[0]), abs(p[1])),
r = n * 1.414,
a = atan2(p[0], p[1])
)
[r * cos(a), r * sin(a)];
module circle_maze(start, r_blocks, block_width, wall_thickness, origin_offset) {
double_r_blocks = r_blocks * 2;
blocks = mz_blocks(
start,
double_r_blocks, double_r_blocks
);
width = double_r_blocks * block_width;
walls = mz_walls(blocks, double_r_blocks, double_r_blocks, block_width);
offset = is_undef(origin_offset) ? width / 2 : origin_offset;
for(wall = walls) {
for(i = [0:len(wall) - 2]) {
p0 = ptf_circle(wall[i], offset);
p1 = ptf_circle(wall[i + 1], offset);
hull_polyline2d([p0, p1], width = wall_thickness);
}
}
}
circle_maze(
start = [1, 1],
r_blocks = 10,
block_width = 2,
wall_thickness = .75
);