2020-12-08 17:59:28 +08:00
|
|
|
use <maze/mz_square_blocks.scad>;
|
2020-11-19 09:05:06 +08:00
|
|
|
use <maze/mz_square_walls.scad>;
|
2020-12-08 18:07:19 +08:00
|
|
|
use <maze/mz_square_initialize.scad>;
|
2020-11-19 09:05:06 +08:00
|
|
|
use <voxel/vx_contour.scad>;
|
|
|
|
|
2020-12-19 11:14:47 +08:00
|
|
|
start = [1, 1];
|
2020-11-19 09:05:06 +08:00
|
|
|
mask = [
|
|
|
|
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
|
|
|
|
[0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0],
|
|
|
|
[0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0],
|
|
|
|
[0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0],
|
|
|
|
[0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0],
|
|
|
|
[0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 0, 0],
|
|
|
|
[0, 1, 1, 1, 1, 0, 1, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0],
|
|
|
|
[0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0],
|
|
|
|
[0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0],
|
|
|
|
[0, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0],
|
|
|
|
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
|
|
|
|
];
|
|
|
|
|
|
|
|
block_width = 3;
|
|
|
|
wall_thickness = 1;
|
|
|
|
wall_height = 2;
|
|
|
|
base_height = 1;
|
|
|
|
contour = true;
|
|
|
|
base = true;
|
|
|
|
|
|
|
|
module maze_masking(start, mask, block_width, wall_thickness, wall_height, base_height, contour, base) {
|
|
|
|
rows = len(mask);
|
|
|
|
columns = len(mask[0]);
|
|
|
|
|
2020-12-08 17:59:28 +08:00
|
|
|
blocks = mz_square_blocks(
|
2020-12-18 15:19:38 +08:00
|
|
|
rows, columns, start,
|
2020-12-08 18:07:19 +08:00
|
|
|
mz_square_initialize(mask = mask)
|
2020-11-19 09:05:06 +08:00
|
|
|
);
|
2020-11-19 10:46:39 +08:00
|
|
|
|
2020-11-19 10:01:35 +08:00
|
|
|
pts = contour ? vx_contour([
|
2020-11-19 09:05:06 +08:00
|
|
|
for(y = [0:rows - 1])
|
|
|
|
for(x = [0:columns - 1])
|
2020-11-19 10:46:39 +08:00
|
|
|
if(mask[rows - y - 1][x] == 1)
|
|
|
|
[x, y]
|
|
|
|
], sorted = true) : [];
|
2020-11-19 09:05:06 +08:00
|
|
|
|
|
|
|
walls = mz_square_walls(blocks, rows, columns, block_width);
|
|
|
|
|
|
|
|
color("gray")
|
|
|
|
linear_extrude(wall_height)
|
|
|
|
intersection() {
|
|
|
|
union() {
|
|
|
|
for(wall = walls) {
|
|
|
|
for(i = [0:len(wall) - 2]) {
|
|
|
|
if(wall[i][0] != 0 && wall[i][1] != 0) {
|
|
|
|
hull() {
|
|
|
|
translate(wall[i])
|
|
|
|
square(wall_thickness);
|
|
|
|
translate(wall[i + 1])
|
|
|
|
square(wall_thickness);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for(y = [0:rows - 1]) {
|
|
|
|
for(x = [0:columns - 1]) {
|
|
|
|
if(mask[rows - y - 1][x] == 0) {
|
|
|
|
translate([x * block_width + wall_thickness, y * block_width + wall_thickness])
|
|
|
|
square(block_width);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(contour) {
|
|
|
|
translate([wall_thickness * 2, wall_thickness * 2])
|
|
|
|
polygon(pts * block_width);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(base) {
|
|
|
|
if(contour) {
|
|
|
|
translate([0, 0, -base_height])
|
|
|
|
linear_extrude(base_height)
|
|
|
|
translate([wall_thickness * 2, wall_thickness * 2])
|
|
|
|
polygon(pts * block_width);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
translate([0, 0, -base_height])
|
|
|
|
linear_extrude(base_height)
|
|
|
|
translate([wall_thickness, wall_thickness])
|
|
|
|
square([columns, rows] * block_width);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
maze_masking(start, mask, block_width, wall_thickness, wall_height, base_height, contour, base);
|