1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-01-17 14:18:13 +01:00
dotSCAD/examples/maze/sphere_maze.scad
2022-06-06 13:11:46 +08:00

81 lines
1.9 KiB
OpenSCAD

use <matrix/m_rotation.scad>
use <maze/mz_square.scad>
use <maze/mz_squarewalls.scad>
use <ptf/ptf_sphere.scad>
r = 10;
rows = 24;
columns = 18;
cell_width = .5;
wall_thickness = .5;
wall_height = 1.5;
pole_offset = cell_width * 2.5;
module sphere_maze() {
function _angles(p) =
let(
dx = p[0],
dy = p[1],
dz = p[2],
ya = atan2(dz, sqrt(dx * dx + dy * dy)),
za = atan2(dy, dx)
) [0, -ya, za];
module _polyline(points) {
leng = len(points);
module _line(index) {
point1 = points[index - 1];
point2 = points[index];
hull() {
rotate(_angles(point1))
translate([r, 0, 0])
cube([wall_height, wall_thickness, wall_thickness], center = true);
rotate(_angles(point2))
translate([r, 0, 0])
cube([wall_height, wall_thickness, wall_thickness], center = true);
}
}
module _polyline_inner(index) {
if(index < leng) {
_line(index);
_polyline_inner(index + 1);
}
}
_polyline_inner(1);
}
size = [rows * cell_width, columns * cell_width + pole_offset * 2];
cells = mz_square(rows, columns, y_wrapping = true);
p_offset = [cell_width * rows, pole_offset, 0];
mr = m_rotation(90);
walls = mz_squarewalls(cells, cell_width, bottom_border = false);
for(wall_pts = walls) {
rxpts = [
for(p = wall_pts)
ptf_sphere(size, mr * [p[0], p[1], 0, 0] + p_offset, r)
];
_polyline(rxpts);
}
}
function _angles(p) =
let(
dx = p[0],
dy = p[1],
dz = p[2],
ya = atan2(dz, sqrt(dx * dx + dy * dy)),
za = atan2(dy, dx)
) [0, -ya, za];
sphere_maze();
color("black")
rotate([0, 90, 0])
sphere(r);