mirror of
https://github.com/JustinSDK/dotSCAD.git
synced 2025-01-17 22:28:16 +01:00
37 lines
900 B
OpenSCAD
37 lines
900 B
OpenSCAD
use <experimental/tile_truchet.scad>
|
|
use <polyline_join.scad>
|
|
use <ptf/ptf_ring.scad>
|
|
|
|
size = [20, 100];
|
|
line_diameter = 1;
|
|
twist = 180;
|
|
$fn = 8;
|
|
|
|
module tiled_line_mobius(size, twist, line_diameter = 1) {
|
|
lines = concat(
|
|
[
|
|
for(tile = tile_truchet(size))
|
|
let(
|
|
x = tile.x,
|
|
y = tile.y
|
|
)
|
|
tile[2] <= 1 ? [[x, y], [x + 1, y + 1]] : [[x + 1, y], [x, y + 1]]
|
|
],
|
|
[
|
|
for(i = [0:size[1] - 1])
|
|
[[0, i], [0, i + 1]]
|
|
],
|
|
[
|
|
for(i = [0:size[1] - 1])
|
|
[[size[0], i], [size[0], i + 1]]
|
|
]
|
|
);
|
|
|
|
half_line_diameter = line_diameter / 2;
|
|
for(line = lines) {
|
|
pts = [for(p = line) ptf_ring(size, p, size[0], twist = twist)];
|
|
polyline_join(pts) sphere(half_line_diameter);
|
|
}
|
|
}
|
|
|
|
tiled_line_mobius(size, twist, line_diameter); |