mirror of
https://github.com/JustinSDK/dotSCAD.git
synced 2025-07-31 20:10:36 +02:00
refactor
This commit is contained in:
@@ -28,10 +28,14 @@ function _mz_mask(mask) =
|
|||||||
columns = len(mask[0][1])
|
columns = len(mask[0][1])
|
||||||
)
|
)
|
||||||
[
|
[
|
||||||
for(z = [0:layers - 1]) [
|
for(z = [0:layers - 1])
|
||||||
for(y = [0:rows - 1]) [
|
let(maze_z = mask[layers - z - 1])
|
||||||
|
[
|
||||||
|
for(y = [0:rows - 1])
|
||||||
|
let(maze_zy = maze_z[rows - y - 1])
|
||||||
|
[
|
||||||
for(x = [0:columns - 1])
|
for(x = [0:columns - 1])
|
||||||
mask[layers - z - 1][rows - y - 1][x] == 0 ?
|
maze_zy[x] == 0 ?
|
||||||
cell(
|
cell(
|
||||||
x, y, z,
|
x, y, z,
|
||||||
MASK,
|
MASK,
|
||||||
|
@@ -7,23 +7,27 @@ function tile_truchet(size, mask, seed) =
|
|||||||
y_range = [0:rows - 1],
|
y_range = [0:rows - 1],
|
||||||
x_range = [0:columns - 1],
|
x_range = [0:columns - 1],
|
||||||
nums = [0, 1, 2, 3],
|
nums = [0, 1, 2, 3],
|
||||||
|
ones = [for(x = x_range) 1],
|
||||||
m = is_undef(mask) ? [
|
m = is_undef(mask) ? [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
[for(x = x_range) 1]
|
ones
|
||||||
] : [
|
] : [
|
||||||
for(y = rows - 1; y > -1; y = y - 1)
|
for(y = rows - 1; y > -1; y = y - 1)
|
||||||
[for(x = x_range) mask[y][x]]
|
let(my = mask[y])
|
||||||
|
[for(x = x_range) my[x]]
|
||||||
]
|
]
|
||||||
)
|
)
|
||||||
is_undef(seed) ? [
|
is_undef(seed) ? [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
for(x = x_range)
|
let(my = m[y])
|
||||||
if(m[y][x] == 1)
|
for(x = x_range)
|
||||||
|
if(my[x] == 1)
|
||||||
[x, y, choose(nums)]
|
[x, y, choose(nums)]
|
||||||
|
|
||||||
] : [
|
] : [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
|
let(my = m[y])
|
||||||
for(x = x_range)
|
for(x = x_range)
|
||||||
if(m[y][x] == 1)
|
if(my[x] == 1)
|
||||||
[x, y, choose(nums, x + y * rows + seed)]
|
[x, y, choose(nums, x + y * rows + seed)]
|
||||||
];
|
];
|
@@ -19,12 +19,14 @@ function tile_w2c(size, mask, seed) =
|
|||||||
round(rands(0, 1, 1, seed + y * columns + x)[0])
|
round(rands(0, 1, 1, seed + y * columns + x)[0])
|
||||||
]
|
]
|
||||||
],
|
],
|
||||||
|
ones = [for(x = x_range) 1],
|
||||||
m = is_undef(mask) ? [
|
m = is_undef(mask) ? [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
[for(x = x_range) 1]
|
ones
|
||||||
] : [
|
] : [
|
||||||
for(y = rows - 1; y > -1; y = y - 1)
|
for(y = rows - 1; y > -1; y = y - 1)
|
||||||
[for(x = x_range) mask[y][x]]
|
let(my = mask[y])
|
||||||
|
[for(x = x_range) my[x]]
|
||||||
],
|
],
|
||||||
/*
|
/*
|
||||||
8 1
|
8 1
|
||||||
@@ -35,8 +37,9 @@ function tile_w2c(size, mask, seed) =
|
|||||||
*/
|
*/
|
||||||
tiles = [
|
tiles = [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
|
let(my = m[y])
|
||||||
for(x = x_range)
|
for(x = x_range)
|
||||||
if(m[y][x] == 1)
|
if(my[x] == 1)
|
||||||
[x, y,
|
[x, y,
|
||||||
(corners[(y + 1) % rows][(x + 1) % columns] == 1 ? 1 : 0) +
|
(corners[(y + 1) % rows][(x + 1) % columns] == 1 ? 1 : 0) +
|
||||||
(corners[y][(x + 1) % columns] == 1 ? 2 : 0) +
|
(corners[y][(x + 1) % columns] == 1 ? 2 : 0) +
|
||||||
|
@@ -26,12 +26,14 @@ function tile_w2e(size, mask, seed) =
|
|||||||
[round(rs[0]), round(rs[1])]
|
[round(rs[0]), round(rs[1])]
|
||||||
]
|
]
|
||||||
],
|
],
|
||||||
|
ones = [for(x = x_range) 1],
|
||||||
m = is_undef(mask) ? [
|
m = is_undef(mask) ? [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
[for(x = x_range) 1]
|
ones
|
||||||
] : [
|
] : [
|
||||||
for(y = rows - 1; y > -1; y = y - 1)
|
for(y = rows - 1; y > -1; y = y - 1)
|
||||||
[for(x = x_range) mask[y][x]]
|
let(my = mask[y])
|
||||||
|
[for(x = x_range) my[x]]
|
||||||
],
|
],
|
||||||
/*
|
/*
|
||||||
1
|
1
|
||||||
@@ -42,8 +44,9 @@ function tile_w2e(size, mask, seed) =
|
|||||||
*/
|
*/
|
||||||
tiles = [
|
tiles = [
|
||||||
for(y = y_range)
|
for(y = y_range)
|
||||||
|
let(my = m[y])
|
||||||
for(x = x_range)
|
for(x = x_range)
|
||||||
if(m[y][x] == 1)
|
if(my[x] == 1)
|
||||||
[x, y,
|
[x, y,
|
||||||
(edges[(y + 1) % rows][x][0] == 1 ? 1 : 0) +
|
(edges[(y + 1) % rows][x][0] == 1 ? 1 : 0) +
|
||||||
(edges[y][(x + 1) % columns][1] == 1 ? 2 : 0) +
|
(edges[y][(x + 1) % columns][1] == 1 ? 2 : 0) +
|
||||||
|
@@ -22,9 +22,11 @@ function _mz_mask(mask) =
|
|||||||
columns = len(mask[0])
|
columns = len(mask[0])
|
||||||
)
|
)
|
||||||
[
|
[
|
||||||
for(y = [0:rows - 1]) [
|
for(y = [0:rows - 1])
|
||||||
|
let(mask_y = mask[rows - y - 1])
|
||||||
|
[
|
||||||
for(x = [0:columns - 1])
|
for(x = [0:columns - 1])
|
||||||
mask[rows - y - 1][x] == 0 ?
|
mask_y[x] == 0 ?
|
||||||
cell(
|
cell(
|
||||||
x, y,
|
x, y,
|
||||||
MASK,
|
MASK,
|
||||||
|
Reference in New Issue
Block a user