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);
|
|
|
|
```
|
|
|
|
|