1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-08-15 03:05:41 +02:00

refactor: extract draw_3dmaze

This commit is contained in:
Justin Lin
2022-04-10 11:07:59 +08:00
parent f5e24e2239
commit c59025b432
2 changed files with 25 additions and 70 deletions

View File

@@ -14,29 +14,38 @@ maze3d();
module maze3d() {
cells = mz_cube(layers, rows, columns);
draw_3dmaze(cells, cell_width, road_width);
}
module draw_3dmaze(cells, cell_width, road_width) {
layers = len(cells);
rows = len(cells[0]);
columns = len(cells[0][0]);
for(z = [0:layers - 1], y = [0:rows - 1], x = [0:columns - 1]) {
cell = cells[z][y][x];
type = mz_cube_get(cell, "t");
channels = [
z_road(type),
z != 0 && z_road(mz_cube_get(cells[z - 1][y][x], "t")),
y_road(type),
x_road(type),
y != 0 && y_road(mz_cube_get(cells[z][y - 1][x], "t")),
x != 0 && x_road(mz_cube_get(cells[z][y][x - 1], "t"))
];
translate([x, y, z] * cell_width)
drawCell(cell_width, road_width, channels);
if(type != "MASK") {
channels = [
z_road(type) ,
z != 0 && z_road(mz_cube_get(cells[z - 1][y][x], "t")),
y_road(type),
x_road(type),
y != 0 && y_road(mz_cube_get(cells[z][y - 1][x], "t")),
x != 0 && x_road(mz_cube_get(cells[z][y][x - 1], "t"))
];
translate([x, y, z] * cell_width)
drawCell(cell_width, road_width, channels);
}
}
function z_road(type) = !has(["Z_WALL", "Z_Y_WALL", "Z_X_WALL", "Z_Y_X_WALL"], type);
function z_road(type) = !has(["Z_WALL", "Z_Y_WALL", "Z_X_WALL", "Z_Y_X_WALL", "MASK"], type);
function y_road(type) = !has(["Y_WALL", "Y_X_WALL", "Z_Y_WALL", "Z_Y_X_WALL"], type);
function y_road(type) = !has(["Y_WALL", "Y_X_WALL", "Z_Y_WALL", "Z_Y_X_WALL", "MASK"], type);
function x_road(type) = !has(["X_WALL", "Y_X_WALL", "Z_X_WALL", "Z_Y_X_WALL"], type);
function x_road(type) = !has(["X_WALL", "Y_X_WALL", "Z_X_WALL", "Z_Y_X_WALL", "MASK"], type);
module drawCell(cell_width, road_width, channels) {
half_cw = cell_width / 2;

View File

@@ -1,8 +1,6 @@
use <experimental/mz_cube.scad>;
use <experimental/mz_cube_initialize.scad>;
use <experimental/mz_cube_get.scad>;
use <util/has.scad>;
use <crystal_ball.scad>;
use <maze3d.scad>;
radius = 6;
cell_width = 15;
@@ -30,57 +28,5 @@ module maze3d_sphere() {
mz = mz_cube_initialize(mask = mask_sphere(radius));
cells = mz_cube(start = [radius, radius, radius] / 2, init_cells = mz);
layers = len(cells);
rows = len(cells[0]);
columns = len(cells[0][0]);
for(z = [0:layers - 1], y = [0:rows - 1], x = [0:columns - 1]) {
cell = cells[z][y][x];
type = mz_cube_get(cell, "t");
if(type != "MASK") {
channels = [
z_road(type) ,
z != 0 && z_road(mz_cube_get(cells[z - 1][y][x], "t")),
y_road(type),
x_road(type),
y != 0 && y_road(mz_cube_get(cells[z][y - 1][x], "t")),
x != 0 && x_road(mz_cube_get(cells[z][y][x - 1], "t"))
];
translate([x, y, z] * cell_width)
drawCell(cell_width, road_width, channels);
}
}
function z_road(type) = !has(["Z_WALL", "Z_Y_WALL", "Z_X_WALL", "Z_Y_X_WALL", "MASK"], type);
function y_road(type) = !has(["Y_WALL", "Y_X_WALL", "Z_Y_WALL", "Z_Y_X_WALL", "MASK"], type);
function x_road(type) = !has(["X_WALL", "Y_X_WALL", "Z_X_WALL", "Z_Y_X_WALL", "MASK"], type);
module drawCell(cell_width, road_width, channels) {
half_cw = cell_width / 2;
half_rw = road_width / 2;
crystal_ball(half_rw);
rots = [
[0, 0, 0],
[180, 0, 0],
[-90, 0, 0],
[0, 90, 0],
[90, 0, 0],
[0, -90, 0]
];
for(i = [0:5]) {
if(channels[i]) {
rotate(rots[i])
linear_extrude(half_cw)
circle(half_rw);
}
}
}
draw_3dmaze(cells, cell_width, road_width);
}