2020-03-30 09:24:15 +08:00
# ptf_torus
Transforms a point inside a rectangle to a point of a torus. It can create things such as [torus maze ](https://github.com/JustinSDK/dotSCAD/blob/master/examples/maze/torus_maze.scad ).
2021-02-24 21:09:54 +08:00
![ptf_torus ](images/lib3x-ptf_torus-1.JPG )
2020-03-30 09:24:15 +08:00
**Since:** 2.3
## Parameters
- `size` : 2 value array `[x, y]` , rectangle with dimensions `x` and `y` .
- `point` : The point to be transformed.
- `radius` : Torus `[R, r]` .
- `angle` : Torus `[A, a]` .
- `twist` : The number of degrees of through which the rectangle is twisted.
## Examples
2022-06-06 13:11:46 +08:00
use < polyline_join.scad >
use < ptf / ptf_torus . scad >
2020-03-30 09:24:15 +08:00
size = [20, 10];
radius = [10, 5];
angle = [180, 180];
twist = 90;
rows = [
2021-12-04 12:16:20 +08:00
for(y = [0:size.y])
[for(x = [0:size.x]) [x, y]]
2020-03-30 09:24:15 +08:00
];
columns = [
2021-12-04 12:16:20 +08:00
for(x = [0:size.x])
[for(y = [0:size.y]) [x, y]]
2020-03-30 09:24:15 +08:00
];
for(line = rows) {
2020-04-09 14:54:37 +08:00
transformed = [for(p = line) ptf_torus(size, p, radius, angle, twist)];
2021-12-04 10:57:29 +08:00
polyline_join(transformed)
sphere(.25);
2020-03-30 09:24:15 +08:00
}
for(line = columns) {
2020-04-09 14:54:37 +08:00
transformed = [for(p = line) ptf_torus(size, p, radius, angle, twist)];
2021-12-04 10:57:29 +08:00
polyline_join(transformed)
sphere(.25);
2020-03-30 09:24:15 +08:00
}
2021-02-24 21:09:54 +08:00
![ptf_torus ](images/lib3x-ptf_torus-2.JPG )