mirror of
https://github.com/JustinSDK/dotSCAD.git
synced 2025-01-17 22:28:16 +01:00
143 lines
2.6 KiB
OpenSCAD
143 lines
2.6 KiB
OpenSCAD
use <experimental/tile_w2e.scad>;
|
|
use <box_extrude.scad>;
|
|
|
|
rows = 8;
|
|
columns = 15;
|
|
tile_width = 10;
|
|
$fn = 12;
|
|
|
|
tube_box(rows, columns, tile_width);
|
|
|
|
module tube_box(rows, columns, tile_width) {
|
|
half_w = tile_width / 2;
|
|
quarter_w = tile_width / 4;
|
|
eighth_w = tile_width / 8;
|
|
|
|
translate([eighth_w, eighth_w, -eighth_w] + [tile_width, tile_width] / 2)
|
|
for(tile = tile_w2e(rows, columns)) {
|
|
x = tile[0];
|
|
y = tile[1];
|
|
i = tile[2];
|
|
translate([x, y] * tile_width)
|
|
tube_tile(i, tile_width);
|
|
}
|
|
|
|
box_extrude(height = tile_width, shell_thickness = eighth_w)
|
|
square([columns * tile_width + quarter_w, rows * tile_width + quarter_w]);
|
|
}
|
|
|
|
module tube_tile(n, width) {
|
|
half_w = width / 2;
|
|
quarter_w = width / 4;
|
|
sixteenth_w = width / 16;
|
|
module tile1() {
|
|
translate([0, half_w])
|
|
rotate([90, 0, -90]) {
|
|
rotate_extrude(angle = 90)
|
|
translate([half_w, 0])
|
|
circle(quarter_w);
|
|
|
|
translate([half_w, 0])
|
|
rotate([90, 0, 0])
|
|
linear_extrude(sixteenth_w, center = true)
|
|
circle(quarter_w * 1.2);
|
|
|
|
translate([0, half_w])
|
|
rotate([0, 90, 0])
|
|
linear_extrude(sixteenth_w, center = true)
|
|
circle(quarter_w * 1.2);
|
|
}
|
|
}
|
|
|
|
module tile3() {
|
|
mirror([1, 0, 0])
|
|
translate([-half_w, 0, half_w])
|
|
rotate([0, 90, 0])
|
|
tile1();
|
|
}
|
|
|
|
module tile5() {
|
|
translate([0, 0, half_w])
|
|
rotate([90, 0, 0]) {
|
|
linear_extrude(width, center = true)
|
|
circle(quarter_w);
|
|
|
|
translate([0, 0, half_w])
|
|
linear_extrude(sixteenth_w, center = true)
|
|
circle(quarter_w * 1.2);
|
|
|
|
translate([0, 0, -half_w])
|
|
linear_extrude(sixteenth_w, center = true)
|
|
circle(quarter_w * 1.2);
|
|
}
|
|
}
|
|
|
|
module tile7() {
|
|
tile5();
|
|
|
|
translate([0, 0, half_w])
|
|
rotate([0, 90, 0]) {
|
|
linear_extrude(half_w)
|
|
circle(quarter_w);
|
|
|
|
translate([0, 0, half_w])
|
|
linear_extrude(sixteenth_w, center = true)
|
|
circle(quarter_w * 1.2);
|
|
}
|
|
}
|
|
|
|
module tile15() {
|
|
tile5();
|
|
rotate(90)
|
|
tile5();
|
|
}
|
|
|
|
if(n == 0) {
|
|
// no tube
|
|
}
|
|
else if(n == 1) {
|
|
tile1();
|
|
}
|
|
else if(n == 2) {
|
|
rotate(-90) tile1();
|
|
}
|
|
else if(n == 3) {
|
|
tile3();
|
|
}
|
|
else if(n == 4) {
|
|
rotate(-180) tile1();
|
|
}
|
|
else if(n == 5) {
|
|
tile5();
|
|
}
|
|
else if(n == 6) {
|
|
rotate(-90) tile3();
|
|
}
|
|
else if(n == 7) {
|
|
tile7();
|
|
}
|
|
else if(n == 8) {
|
|
rotate(90) tile1();
|
|
}
|
|
else if(n == 9) {
|
|
rotate(90) tile3();
|
|
}
|
|
else if(n == 10) {
|
|
rotate(90) tile5();
|
|
}
|
|
else if(n == 11) {
|
|
rotate(90) tile7();
|
|
}
|
|
else if(n == 12) {
|
|
rotate(-180) tile3();
|
|
}
|
|
else if(n == 13) {
|
|
rotate(180) tile7();
|
|
}
|
|
else if(n == 14) {
|
|
rotate(270) tile7();
|
|
}
|
|
else if(n == 15) {
|
|
tile15();
|
|
}
|
|
} |