BOSL2/tutorials/Basic_Shapes.md

259 lines
6.0 KiB
Markdown
Raw Normal View History

2020-03-24 23:16:16 -07:00
# Basic Shapes Tutorial
2020-04-28 22:59:32 -07:00
## Primitives
There are 5 built-in primitive shapes that OpenSCAD provides.
`square()`, `circle()`, `cube()`, `cylinder()`, and `sphere()`.
The BOSL2 library extends or provides alternative to these shapes so
that they support more features, and more ways to simply reorient them.
2020-03-24 23:16:16 -07:00
2020-04-28 22:59:32 -07:00
### 2D Squares
2020-04-28 16:45:48 -07:00
You still use `square()` in the familiar ways that OpenSCAD provides:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
square(100, center=false);
```
```openscad-example
square(100, center=true);
```
```openscad-example
2020-04-28 16:45:48 -07:00
square([60,40], center=true);
2020-03-24 23:16:16 -07:00
```
2020-04-28 22:59:32 -07:00
BOSL2 has a `rect()` command that acts an an enhanced `square()` that has
extended functionality. For example, it allows you to round the corners:
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], center=true, rounding=10);
2020-03-24 23:16:16 -07:00
```
It also supports chamfers:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], center=true, chamfer=10);
2020-03-24 23:16:16 -07:00
```
2020-04-28 16:45:48 -07:00
It allows you to specify *which* corners get rounded or chamferred:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], center=true, rounding=[0,5,10,15]);
2020-03-24 23:16:16 -07:00
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], center=true, chamfer=[0,5,10,15]);
2020-03-24 23:16:16 -07:00
```
It will even let you mix rounding and chamferring:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], center=true, rounding=[5,0,10,0], chamfer=[0,5,0,15]);
2020-03-24 23:16:16 -07:00
```
### Anchors and Spin
2020-04-28 22:59:32 -07:00
Another way that `rect()` is enhanced over `square()`, is that you can anchor,
spin and attach it.
2020-03-24 23:16:16 -07:00
The `anchor=` argument is an alternative to `center=`, which allows more
alignment options. It takes a vector as a value, pointing roughly towards
the side or corner you want to align to the origin. For example, to align
the center of the back edge to the origin, set the anchor to `[0,1]`:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=[0,1]);
2020-03-24 23:16:16 -07:00
```
To align the front right corner to the origin:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=[1,-1]);
2020-03-24 23:16:16 -07:00
```
To center:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=[0,0]);
2020-03-24 23:16:16 -07:00
```
2020-04-28 22:59:32 -07:00
To make it clearer when giving vectors, there are several standard vector
constants defined:
Constant | Direction | Value
-------- | --------- | -----------
`LEFT` | X- | `[-1,0,0]`
`RIGHT` | X+ | `[1,0,0]`
`FRONT`/`FORWARD`/`FWD` | Y- | `[0,-1,0]`
`BACK` | Y+ | `[0,1,0]`
`BOTTOM`/`BOT`/`BTM`/`DOWN` | Z- | `[0,0,-1]` (3D only.)
`TOP`/`UP` | Z+ | `[0,0,1]` (3D only.)
`CENTER`/`CTR` | Centered | `[0,0,0]`
Note that even though these are 3D vectors, you can use most of them,
(except `UP`/`DOWN`, of course) for anchors in 2D shapes:
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=BACK);
2020-03-24 23:16:16 -07:00
```
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=CENTER);
2020-03-24 23:16:16 -07:00
```
You can add them together to point to corners:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=FRONT+RIGHT);
2020-03-24 23:16:16 -07:00
```
2020-04-28 22:59:32 -07:00
Finally, the `spin` argument can rotate the shape by a given number of degrees
clockwise:
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=CENTER, spin=30);
2020-03-24 23:16:16 -07:00
```
Anchoring or centering is performed before the spin:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
2020-04-28 16:45:48 -07:00
rect([60,40], anchor=BACK, spin=30);
2020-03-24 23:16:16 -07:00
```
### Enhanced 2D Circle
The enhanced `circle()` primitive can be used like the OpenSCAD built-in:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
circle(r=50);
```
```openscad-example
circle(d=100);
```
```openscad-example
circle(d=100, $fn=8);
```
Since a circle in OpenSCAD can only be approximated by a regular polygon with
a number of straight sides, this can lead to size and shape inaccuracies. To
counter this, the `realign` and `circum` arguments are also provided.
2020-04-28 22:59:32 -07:00
The `realign` argument, if set `true`, rotates the circle by half the angle
between sides:
2020-03-24 23:16:16 -07:00
```openscad-example
circle(d=100, $fn=8, realign=true);
```
2020-04-28 22:59:32 -07:00
The `circum` argument, if true, makes the polygon describing the circle
circumscribe the ideal circle instead of inscribing it.
2020-03-24 23:16:16 -07:00
Inscribing the ideal circle:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
difference() {
circle(d=100, $fn=360);
circle(d=100, $fn=6);
}
```
Circumscribing the ideal circle:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
difference() {
circle(d=100, $fn=6, circum=true);
circle(d=100, $fn=360);
}
```
You can also use anchor and spin on enhanced `circle()`:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
circle(r=50, anchor=BACK);
```
```openscad-example
circle(r=50, anchor=FRONT+RIGHT);
```
2020-04-28 22:59:32 -07:00
Using spin on a circle may not make initial sense, until you remember that
anchoring is performed before spin:
2020-03-24 23:16:16 -07:00
```openscad-example
circle(r=50, anchor=FRONT, spin=30);
```
2020-04-28 22:59:32 -07:00
### Enhanced 3D Cube
2020-03-24 23:16:16 -07:00
You can use enhanced `cube()` like the normal OpenSCAD built-in:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube(100);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube(100, center=true);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], center=true);
```
You can use `anchor` similarly to `square()`, except you can anchor vertically
too, in 3D, allowing anchoring to faces, edges, and corners:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], anchor=BOTTOM);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], anchor=TOP+BACK);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], anchor=TOP+FRONT+LEFT);
```
You can use `spin` as well, to rotate around the Z axis:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], anchor=FRONT, spin=30);
```
3D objects also gain the ability to use an extra trick with `spin`;
if you pass a list of `[X,Y,Z]` rotation angles to `spin`, it will
rotate by the three given axis angles, similar to using `rotate()`:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], anchor=FRONT, spin=[15,0,30]);
```
3D objects also can be given an `orient` argument that is given as a vector,
pointing towards where the top of the shape should be rotated towards.
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], orient=UP+BACK+RIGHT);
```
If you use `anchor`, `spin`, and `orient` together, the anchor is performed
first, then the spin, then the orient:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cube([50,40,20], anchor=FRONT, spin=45, orient=UP+FWD+RIGHT);
```
2020-04-28 22:59:32 -07:00
### Enhanced 3D Cylinder
2020-03-24 23:16:16 -07:00
You can use the enhanced `cylinder()` as normal for OpenSCAD:
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cylinder(r=50,h=50);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cylinder(r=50,h=50,center=true);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cylinder(d=100,h=50,center=true);
```
2020-04-28 22:59:32 -07:00
2020-03-24 23:16:16 -07:00
```openscad-example
cylinder(d1=100,d2=80,h=50,center=true);
```