1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-17 22:28:16 +01:00
dotSCAD/examples/maze/maze_masking.scad

94 lines
3.3 KiB
OpenSCAD
Raw Normal View History

2020-12-20 10:49:16 +08:00
use <maze/mz_square_cells.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]
];
2020-12-20 10:49:16 +08:00
cell_width = 3;
2020-11-19 09:05:06 +08:00
wall_thickness = 1;
wall_height = 2;
base_height = 1;
contour = true;
base = true;
2020-12-20 10:49:16 +08:00
module maze_masking(start, mask, cell_width, wall_thickness, wall_height, base_height, contour, base) {
2020-11-19 09:05:06 +08:00
rows = len(mask);
columns = len(mask[0]);
2020-12-20 10:49:16 +08:00
cells = mz_square_cells(
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
2020-12-20 10:49:16 +08:00
walls = mz_square_walls(cells, rows, columns, cell_width);
2020-11-19 09:05:06 +08:00
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) {
2020-12-20 10:49:16 +08:00
translate([x * cell_width + wall_thickness, y * cell_width + wall_thickness])
square(cell_width);
2020-11-19 09:05:06 +08:00
}
}
}
}
if(contour) {
translate([wall_thickness * 2, wall_thickness * 2])
2020-12-20 10:49:16 +08:00
polygon(pts * cell_width);
2020-11-19 09:05:06 +08:00
}
}
if(base) {
if(contour) {
translate([0, 0, -base_height])
linear_extrude(base_height)
translate([wall_thickness * 2, wall_thickness * 2])
2020-12-20 10:49:16 +08:00
polygon(pts * cell_width);
2020-11-19 09:05:06 +08:00
}
else {
translate([0, 0, -base_height])
linear_extrude(base_height)
translate([wall_thickness, wall_thickness])
2020-12-20 10:49:16 +08:00
square([columns, rows] * cell_width);
2020-11-19 09:05:06 +08:00
}
}
}
2020-12-20 10:49:16 +08:00
maze_masking(start, mask, cell_width, wall_thickness, wall_height, base_height, contour, base);