mirror of
https://github.com/JustinSDK/dotSCAD.git
synced 2025-02-20 07:34:36 +01:00
142 lines
3.3 KiB
Markdown
142 lines
3.3 KiB
Markdown
# polysections
|
|
|
|
Crosscutting a tube-like shape at different points gets several cross-sections. This module can operate reversely. It uses cross-sections to construct a tube-like shape. For example, imagine that you have the following cross-sections:
|
|
|
|
data:image/s3,"s3://crabby-images/c58b0/c58b07e28a15a87d6f247efc699c4ec8fbbd5001" alt="polysections"
|
|
|
|
This module can use them to construct the following model:
|
|
|
|
data:image/s3,"s3://crabby-images/22362/22362acb95f837e67c6df21c26ae88807fbf353b" alt="polysections"
|
|
|
|
Looks like extruding along the path? Yes, it can perform the task; however, it's more flexible.
|
|
|
|
You can also view it as a better polyline3d module if you want. If you have only the points of a path, using `polyline3d` or `hull_polyline3d` is a simple solution. If you know the cross sections along a path, you can use `polysections` to do more.
|
|
|
|
When using this module, you should use points to represent each cross section. The points of your cross section should have count-clockwise indexes. For example:
|
|
|
|
data:image/s3,"s3://crabby-images/a693b/a693b5c129a668ac46f51b4a8e070692aea4971f" alt="polysections"
|
|
|
|
If your cross section is hollow, set the `triangles` parameter to `"HOLLOW"` and index the points as the following:
|
|
|
|
data:image/s3,"s3://crabby-images/b6d69/b6d6937b1edd0b63e3265e773b148db71266da97" alt="polysections"
|
|
|
|
You can cut triangles by yourself. For example, the above shape can be cut into triangles such as:
|
|
|
|
data:image/s3,"s3://crabby-images/1c8ab/1c8ab7b4be370f5129af9757dfb3fee278ce5605" alt="polysections"
|
|
|
|
The indexes of the above triangles is:
|
|
|
|
[
|
|
[0, 3, 1],
|
|
[1, 3, 4],
|
|
[1, 4, 2],
|
|
[2, 4, 5],
|
|
[2, 5, 0],
|
|
[0, 5, 3]
|
|
]
|
|
|
|
When defining triangles, you can use clockwise or counter-clockwise indexes.
|
|
|
|
## Parameters
|
|
|
|
- `sections` : A list of cross-sections. Each cross-section is represented by a list of points. See the example below.
|
|
- `triangles` : `"SOLID"` (default), `"HOLLOW"`, or user-defined indexes. See example below.
|
|
|
|
## Examples
|
|
|
|
include <rotate_p.scad>;
|
|
include <polysections.scad>;
|
|
|
|
section1 = [
|
|
[20, 0, 0],
|
|
[18, 9, 0],
|
|
[15, 10, 0],
|
|
[10, 0, 0]
|
|
];
|
|
|
|
// spin section1
|
|
sections = [
|
|
for(i = [0:55])
|
|
[
|
|
for(p = section1)
|
|
let(pt = rotate_p(p, [90, 0, 10 * i]))
|
|
[pt[0], pt[1] , pt[2] + i]
|
|
]
|
|
];
|
|
|
|
polysections(sections);
|
|
|
|
data:image/s3,"s3://crabby-images/04bd4/04bd45d63cca0aa916ff3920c02b117c97a96b89" alt="polysections"
|
|
|
|
include <rotate_p.scad>;
|
|
include <polysections.scad>;
|
|
|
|
section1 = [
|
|
// outer
|
|
[20, 0, 0],
|
|
[18, 9, 0],
|
|
[15, 10, 0],
|
|
[10, 0, 0],
|
|
// inner
|
|
[18, 2, 0],
|
|
[17, 7, 0],
|
|
[15, 7, 0],
|
|
[12, 2, 0]
|
|
];
|
|
|
|
// spin section1
|
|
sections = [
|
|
for(i = [0:55])
|
|
[
|
|
for(p = section1)
|
|
let(pt = rotate_p(p, [90, 0, 10 * i]))
|
|
[pt[0], pt[1] , pt[2] + i]
|
|
]
|
|
];
|
|
|
|
polysections(sections, "HOLLOW");
|
|
|
|
data:image/s3,"s3://crabby-images/dbf30/dbf30d4186d85cd7a05232351e351d5154514e0b" alt="polysections"
|
|
|
|
include <rotate_p.scad>;
|
|
include <polysections.scad>;
|
|
|
|
section1 = [
|
|
// outer
|
|
[30, 0, 0],
|
|
[15, 10, 0],
|
|
[10, 0, 0],
|
|
// inner
|
|
[26, 1, 0],
|
|
[15, 8, 0],
|
|
[12, 1, 0],
|
|
];
|
|
|
|
// spin section1
|
|
sections = [
|
|
for(i = [0:55])
|
|
[
|
|
for(p = section1)
|
|
let(pt = rotate_p(p, [90, 0, 10 * i]))
|
|
[pt[0], pt[1] , pt[2] + i]
|
|
]
|
|
];
|
|
|
|
polysections(
|
|
sections = sections,
|
|
triangles = [
|
|
[0, 3, 1],
|
|
[1, 3, 4],
|
|
[1, 4, 2],
|
|
[2, 4, 5],
|
|
[2, 5, 0],
|
|
[0, 5, 3]
|
|
]
|
|
);
|
|
|
|
data:image/s3,"s3://crabby-images/98e63/98e638bc64aab46dad6e81d76794cfe549909b38" alt="polysections"
|
|
|
|
|
|
|
|
|