-
Notifications
You must be signed in to change notification settings - Fork 138
masks2d.scad
This file provides 2D masking shapes that you can use with edge_profile()
to mask edges.
The shapes include the simple roundover and chamfer as well as more elaborate shapes
like the cove and ogee found in furniture and architecture. You can make the masks
as geometry or as 2D paths.
To use, add the following lines to the beginning of your file:
include <BOSL2/std.scad>
-
Section: 2D Masking Shapes
-
mask2d_roundover()
– Creates a circular mask shape for rounding edges or beading. [Geom] [Path] -
mask2d_teardrop()
– Creates a 2D teardrop shape with specified max angle from vertical. [Geom] [Path] -
mask2d_cove()
– Creates a 2D cove (quarter-round) mask shape. [Geom] [Path] -
mask2d_chamfer()
– Produces a 2D chamfer mask shape. [Geom] [Path] -
mask2d_rabbet()
– Creates a rabbet mask shape. [Geom] [Path] -
mask2d_dovetail()
– Creates a 2D dovetail mask shape. [Geom] [Path] -
mask2d_ogee()
– Creates a 2D ogee mask shape. [Geom] [Path]
-
Synopsis: Creates a circular mask shape for rounding edges or beading. [Geom] [Path]
Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
See Also: corner_profile(), edge_profile(), face_profile(), fillet()
Usage: As module
- mask2d_roundover(r|d=|h=|height=|cut=|joint=, [inset], [mask_angle], [excess], [flat_top=], [quarter_round=]) [ATTACHMENTS];
Usage: As function
- path = mask2d_roundover(r|d=|h=|height=|cut=|joint=, [inset], [mask_angle], [excess], [flat_top=], [quarter_round=]);
Description:
Creates a 2D roundover/bead mask shape that is useful for extruding into a 3D mask for an edge. Conversely, you can use that same extruded shape to make an interior fillet between two walls. As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis. If called as a function, returns a 2D path of the outline of the mask shape.
The roundover can be specified by radius, diameter, height, cut, or joint length.
If you need roundings to agree on edges of different mask_angle, e.g. to round the base of a prismoid, then you need all of the
masks used to have the same height. (Note that it may appear that matching joint would also work, but it does not because the joint distances are measured
in different directions.) You can get the same height by setting the height
parameter, which is an alternate way to control the size of the rounding.
You can also set quarter_round=true
, which creates a rounding that uses a quarter circle of the specified radius for all mask angles. If you have set inset
you will need flat_top=true
as well. Note that this is the default if you use quarter_round=true
but not otherwise. Generally if you want a roundover
results are best using the height
option but if you want a bead as you get using inset
the results are often best using the quarter_round=true
option.
Arguments:
By Position | What it does |
---|---|
r |
Radius of the roundover. |
inset |
Optional bead inset size, perpendicular to the two edges. Scalar or 2-vector. Default: 0 |
mask_angle |
Number of degrees in the corner angle to mask. Default: 90 |
excess |
Extra amount of mask shape to creates on the X and quasi-Y sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
d |
Diameter of the roundover. |
h / height
|
Mask height excluding inset and excess. Give instead of r / d, cut or joint when you want a consistent mask height, no matter what the mask angle. |
cut |
Cut distance. IE: How much of the corner to cut off. See Types of Roundovers. |
joint |
Joint distance. IE: How far from the edge the roundover should start. See Types of Roundovers. |
flat_top |
If true, the top inset of the mask will be horizontal instead of angled by the mask_angle. Default: true if quarter_round is set, false otherwise. |
quarter_round |
If true, make a roundover independent of the mask_angle, defined based on a quarter circle of the specified size. Creates mask with angle-independent height. Default: false. |
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Roundover Mask by Radius
data:image/s3,"s3://crabby-images/83ea6/83ea6dd01cec9d44a37be19b71e45b1bca8214da" alt="mask2d\_roundover() Example 1"
include <BOSL2/std.scad>
mask2d_roundover(r=10);
Example 2: 2D Bead Mask
data:image/s3,"s3://crabby-images/0c469/0c469c34a1ca24cc881cab611563be8ae82bc4d1" alt="mask2d\_roundover() Example 2"
include <BOSL2/std.scad>
mask2d_roundover(r=10,inset=2);
Example 3: 2D Roundover Mask by Radius, acute angle
data:image/s3,"s3://crabby-images/a7cb9/a7cb9e29b51bb70f0da990a6e73c949fce3adda2" alt="mask2d\_roundover() Example 3"
include <BOSL2/std.scad>
mask2d_roundover(r=10, mask_angle=50);
Example 4: 2D Bead Mask by Radius, acute angle
data:image/s3,"s3://crabby-images/4f93b/4f93bca73fe837b273ef96a0db2409c029c9c17c" alt="mask2d\_roundover() Example 4"
include <BOSL2/std.scad>
mask2d_roundover(r=10, inset=2, mask_angle=50);
Example 5: 2D Bead Mask for obtuse angle, by height
data:image/s3,"s3://crabby-images/f05f3/f05f380fea23d1be8161c4722cb2ad7088d0955e" alt="mask2d\_roundover() Example 5"
include <BOSL2/std.scad>
mask2d_roundover(h=10, inset=2, mask_angle=135, $fn=64);
Example 6: 2D Bead Mask for obtuse angle, by height with flat top
data:image/s3,"s3://crabby-images/793de/793de3d5ac54121828b0057c2b63244a2dd3839c" alt="mask2d\_roundover() Example 6"
include <BOSL2/std.scad>
mask2d_roundover(h=10, inset=2, mask_angle=135, flat_top=true, $fn=64);
Example 7: 2D Angled Bead Mask by Joint Length. Joint length does not include the inset.
data:image/s3,"s3://crabby-images/c4242/c4242541cb16df36bf28ff90d239b3c76e14ac3e" alt="mask2d\_roundover() Example 7"
include <BOSL2/std.scad>
mask2d_roundover(joint=10, inset=2, mask_angle=75);
Example 8: Increasing the Excess
data:image/s3,"s3://crabby-images/dc07c/dc07cad26ca700160dbb994c072e26d08f5abe14" alt="mask2d\_roundover() Example 8"
include <BOSL2/std.scad>
mask2d_roundover(r=10, inset=2, mask_angle=75, excess=2);
Example 9: quarter_round bead on an acute angle
data:image/s3,"s3://crabby-images/8dbe4/8dbe4253d93c924e8b9d41ba7efe8aec361b19df" alt="mask2d\_roundover() Example 9"
include <BOSL2/std.scad>
mask2d_roundover(r=10, inset=2, mask_angle=50, quarter_round=true);
Example 10: quarter_round bead on an obtuse angle
data:image/s3,"s3://crabby-images/f794f/f794fdd3093ab495beff1e6be12523871ea686a7" alt="mask2d\_roundover() Example 10"
include <BOSL2/std.scad>
mask2d_roundover(r=10, inset=2, mask_angle=135, quarter_round=true);
Example 11: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/b7fd1/b7fd1f343da584ffa290e26f12053d8975ae1f83" alt="mask2d\_roundover() Example 11"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
mask2d_roundover(h=12, inset=2);
Example 12: Making an interior fillet
data:image/s3,"s3://crabby-images/18922/189227d183e6a1cf7f2e97b6fcd5c30a5ab8b21c" alt="mask2d\_roundover() Example 12"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_roundover(r=10);
Example 13: Rounding over top of an extreme prismoid using height option
data:image/s3,"s3://crabby-images/ec287/ec287b142f0e93f80387b117de9a3c85ab76705d" alt="mask2d\_roundover() Example 13"
include <BOSL2/std.scad>
diff()
prismoid([30,20], [50,60], h=20, shift=[40,50])
edge_profile(TOP, excess=27)
mask2d_roundover(height=5, mask_angle=$edge_angle, $fn=128);
Example 14: Using the quarter_round option results in a lip on obtuse angles, so it may not be the best choice for pure roundings.
data:image/s3,"s3://crabby-images/0c11d/0c11d504dbb82aad4870fac1f4af056c8e8c9dbe" alt="mask2d\_roundover() Example 14"
include <BOSL2/std.scad>
diff()
prismoid([30,20], [50,60], h=20, shift=[40,50])
edge_profile(TOP, excess=27)
mask2d_roundover(r=5, mask_angle=$edge_angle, quarter_round=true, $fn=128);
Example 15: Creating a bead on the prismoid using the height option with flat_top=true:
data:image/s3,"s3://crabby-images/41611/4161109193172ad99a1e7978038a2d22be108104" alt="mask2d\_roundover() Example 15"
include <BOSL2/std.scad>
diff()
prismoid([30,20], [50,60], h=20, shift=[40,50])
edge_profile(TOP, excess=27)
mask2d_roundover(height=5, mask_angle=$edge_angle, inset=1.5, flat_top=true, $fn=128);
Example 16: Bead may be more pleasing using the quarter_round option, with curves terminating in a plane parallel to the prismoid top. The size of the inset edge will be larger than requested when the angle is obtuse.
data:image/s3,"s3://crabby-images/fa8b3/fa8b37274fe09bf85d8fc805ae19416c8b8c19ab" alt="mask2d\_roundover() Example 16"
include <BOSL2/std.scad>
diff()
prismoid([30,20], [50,60], h=20, shift=[40,50])
edge_profile(TOP, excess=27)
mask2d_roundover(r=5, mask_angle=$edge_angle, quarter_round=true, inset=1.5, $fn=128);
Synopsis: Creates a 2D teardrop shape with specified max angle from vertical. [Geom] [Path]
Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D), FDM Optimized
See Also: corner_profile(), edge_profile(), face_profile()
Usage: As Module
- mask2d_teardrop(r|d=, [angle], [inset] [mask_angle], [excess], [cut=], [joint=], [h=|height=]) [ATTACHMENTS];
Usage: As Function
- path = mask2d_teardrop(r|d=, [angle], [inset], [mask_angle], [excess], [cut=], [joint=], [h=|height=]);
Description:
Creates a 2D teardrop mask shape that is useful for extruding into a 3D mask for an edge.
Conversely, you can use that same extruded shape to make an interior teardrop fillet between two walls.
As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis.
If called as a function, returns a 2D path of the outline of the mask shape.
This is particularly useful to make partially rounded bottoms, that don't need support to print.
The roundover can be specified by radius, diameter, height, cut, or joint length.
Arguments:
By Position | What it does |
---|---|
r |
Radius of the rounding. |
angle |
The angle from vertical of the flat section. Must be between mask_angle-90 and 90 degrees. Default: 45. |
inset |
Optional bead inset size perpendicular to edges. Default: 0 |
mask_angle |
Number of degrees in the corner angle to mask. Default: 90 |
excess |
Extra amount of mask shape to creates on the X- and Y- sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
d |
Diameter of the rounding. |
h / height
|
Mask height excluding inset and excess. Given instead of r or d when you want a consistent mask height, no matter what the mask angle. |
cut |
Cut distance. IE: How much of the corner to cut off. See Types of Roundovers. |
joint |
Joint distance. IE: How far from the edge the roundover should start. See Types of Roundovers. |
flat_top |
If true, the top inset of the mask will be horizontal instead of angled by the mask_angle. Default: true. |
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Teardrop Mask
data:image/s3,"s3://crabby-images/df62c/df62c59f3c2eedeb1b2552f0a94f68dc84ff2557" alt="mask2d\_teardrop() Example 1"
include <BOSL2/std.scad>
mask2d_teardrop(r=10,$fn=64);
Example 2: 2D Teardrop Mask for acute angle
data:image/s3,"s3://crabby-images/03a2c/03a2cfd4098a238ec1f473d5b469a844ec08a749" alt="mask2d\_teardrop() Example 2"
include <BOSL2/std.scad>
mask2d_teardrop(r=10, mask_angle=75,$fn=64);
Example 3: 2D Teardrop Mask for obtuse angle, specifying height
data:image/s3,"s3://crabby-images/3f789/3f789d36ae0879650c8929106219d6d4c0584377" alt="mask2d\_teardrop() Example 3"
include <BOSL2/std.scad>
mask2d_teardrop(h=10, mask_angle=115,$fn=128);
Example 4: Increasing Excess
data:image/s3,"s3://crabby-images/3f159/3f1598676e88a665d878f511fdce3926c986b8df" alt="mask2d\_teardrop() Example 4"
include <BOSL2/std.scad>
mask2d_teardrop(r=10, mask_angle=75, excess=2);
Example 5: Using a Custom Angle
data:image/s3,"s3://crabby-images/ee742/ee74214573e0c04594cf5d86438bd0f645b51f91" alt="mask2d\_teardrop() Example 5"
include <BOSL2/std.scad>
mask2d_teardrop(r=10,angle=30,$fn=128);
Example 6: With an acute mask_angle you can choose an angle of zero:
data:image/s3,"s3://crabby-images/10f9d/10f9dcde25dd3eaf2785be5bcb27ac5fc69deb66" alt="mask2d\_teardrop() Example 6"
include <BOSL2/std.scad>
mask2d_teardrop(r=10,mask_angle=44,angle=0);
Example 7: With an acute mask_angle you can even choose a negative angle
data:image/s3,"s3://crabby-images/67b80/67b80ef9e26375964fb74f6c8c41b73405db5164" alt="mask2d\_teardrop() Example 7"
include <BOSL2/std.scad>
mask2d_teardrop(r=10,mask_angle=44,angle=-15);
Example 8: With an obtuse angle you need to choose a larger angle. Here we add inset.
data:image/s3,"s3://crabby-images/0b824/0b82419c61d6b4544ebe98c22ccfcd881631b646" alt="mask2d\_teardrop() Example 8"
include <BOSL2/std.scad>
mask2d_teardrop(h=10, mask_angle=135,angle=60, inset=2);
Example 9: Same thing with flat_top=true
.
data:image/s3,"s3://crabby-images/1d359/1d359f2d0578efcb7fcb3a8d648ef325e0e290ef" alt="mask2d\_teardrop() Example 9"
include <BOSL2/std.scad>
mask2d_teardrop(h=10, mask_angle=135,angle=60, inset=2, flat_top=true);
Example 10: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/bc31c/bc31c0c94c5ea9998eda8300ef4946b5710cf784" alt="mask2d\_teardrop() Example 10"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile(BOT)
mask2d_teardrop(r=10, angle=40);
Example 11: Making an interior teardrop fillet
data:image/s3,"s3://crabby-images/ab302/ab3028e66c8811febdabad00dcde1f8661d61016" alt="mask2d\_teardrop() Example 11"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_teardrop(r=10);
Synopsis: Creates a 2D cove (quarter-round) mask shape. [Geom] [Path]
Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
See Also: corner_profile(), edge_profile(), face_profile()
Usage: As module
- mask2d_cove(r|d=|h=|height=, [inset], [mask_angle], [excess], [bulge=], [flat_top=], [quarter_round=]) [ATTACHMENTS];
Usage: As function
- path = mask2d_cove(r|d=|h=, [inset], [mask_angle], [excess], [bulge=], [flat_top=]);
Description:
Creates a 2D cove mask shape that is useful for extruding into a 3D mask for an edge. Conversely, you can use that same extruded shape to make an interior rounded shelf decoration between two walls. As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis. If called as a function, returns a 2D path of the outline of the mask shape.
If you need coves to agree on edges of different mask_angle, e.g. on the top of a prismoid, then you need all of the
masks used to have the same height. You can get the same height by setting the height
parameter. For obtuse angles, however, the cove mask may not
have is maximum height at the edge, which means it won't mate with adjacent coves. You can fix this using flat_top=true
which extends the circle
with a line to maintain a flat top. Another way to fix it is to set bulge
. You can also achieve constant height using the quarter_round=
option,
which uses a quarter circle of the specified size for all mask_angle values. This option often produces a nice result because coves all terminate in a
plane at 90 degrees.
Arguments:
By Position | What it does |
---|---|
r |
Radius of the cove. |
inset |
Optional amount to inset in the perpendicular direction from the edges. Scalar or 2-vector. Default: 0 |
mask_angle |
Number of degrees in the corner angle to mask. Default: 90 |
excess |
Extra amount of mask shape to creates on the X and quasi-Y sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
d |
Diameter of the cove. |
h / height
|
Mask height, excluding inset and excess. Given instead of r or d when you want a consistent mask height, no matter what the mask angle. |
bulge |
specify arc as the distance away from a straight line chamfer. The arc will not meet the sides at a 90 deg angle. |
quarter_round |
If true, make cove independent of the mask_angle, defined based on a quarter circle, with angle-independent radius. The mask will have constant height. Default: false. |
flat_top |
If true, the top inset of the mask will be horizontal instead of angled by the mask_angle. In the case of obtuse angles force the mask to have a flat section at its left side instead of a circular arc. Default: true if quarter_round is set, false otherwise. |
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Cove Mask by Radius
data:image/s3,"s3://crabby-images/ef68b/ef68b2cecec1170bacbf865c1ca373a98fb429f2" alt="mask2d\_cove() Example 1"
include <BOSL2/std.scad>
mask2d_cove(r=10);
Example 2: 2D Inset Cove Mask (not much different than a regular cove of larger radius)
data:image/s3,"s3://crabby-images/c3961/c39610dbe5801f313eb8e85838a4ae3a0f16cdb7" alt="mask2d\_cove() Example 2"
include <BOSL2/std.scad>
mask2d_cove(r=10,inset=3);
Example 3: 2D Cove Mask for acute angle, specified by height, with the bulge set to change the curve. Note that the circular arc is not perpendicular to the sides.
data:image/s3,"s3://crabby-images/66c94/66c94e691588343d67a4ae989729095dff8fc62e" alt="mask2d\_cove() Example 3"
include <BOSL2/std.scad>
mask2d_cove(h=10,mask_angle=55, bulge=3);
Example 4: 2D Cove Mask for obtuse angle, specified by height. This will produce an odd result if combined with other masks because the maximum height is in the middle.
data:image/s3,"s3://crabby-images/d2c5c/d2c5c2b26085169da8e1e433b4d4f9f85ea5211b" alt="mask2d\_cove() Example 4"
include <BOSL2/std.scad>
mask2d_cove(h=10,mask_angle=145);
Example 5: 2D Cove Mask for obtuse angle with flat top. This is one solution to the problem of the previous example. Max height is achieved at the left corner.
data:image/s3,"s3://crabby-images/adb63/adb639d6983e17f99eabc2000feb6b11548ed53f" alt="mask2d\_cove() Example 5"
include <BOSL2/std.scad>
mask2d_cove(h=10,mask_angle=145,flat_top=true);
Example 6: 2D Cove Mask for obtuse angle, specified by height with bulge parameter. Another way to fix the problem of the previous example: the max height is again achieved at the left corner.
data:image/s3,"s3://crabby-images/a8661/a8661d898196bd83107cd4b67288abadc8a17718" alt="mask2d\_cove() Example 6"
include <BOSL2/std.scad>
mask2d_cove(h=10,mask_angle=145, bulge=3, $fn=128);
Example 7: 2D Cove Mask for acute angle with quarter_round enabled
data:image/s3,"s3://crabby-images/5d166/5d16666e871253a80c7961a7b6723a9962c2add0" alt="mask2d\_cove() Example 7"
include <BOSL2/std.scad>
mask2d_cove(r=10,mask_angle=55,quarter_round=true);
Example 8: 2D Cove Mask for obtuse angle, specified by height. Note that flat_top is on by default in quarter_round mode.
data:image/s3,"s3://crabby-images/dd540/dd5408882452aa4cd5d0ff6380dca907d2a08987" alt="mask2d\_cove() Example 8"
include <BOSL2/std.scad>
mask2d_cove(r=10,mask_angle=145,quarter_round=true);
Example 9: Increasing the Excess
data:image/s3,"s3://crabby-images/016c7/016c7e2640ab50940b64019d62ac4b7c68a5289c" alt="mask2d\_cove() Example 9"
include <BOSL2/std.scad>
mask2d_cove(r=10,inset=3,mask_angle=75, excess=2);
Example 10: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/9d35d/9d35dabbaf3846ddd9c736cbfa8bfe4b6b5c4423" alt="mask2d\_cove() Example 10"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
mask2d_cove(h=10, inset=3);
Example 11: Making an interior rounded shelf
data:image/s3,"s3://crabby-images/8cb05/8cb05473a2e5ea9c203b7be6358f3a8a06b17b4f" alt="mask2d\_cove() Example 11"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_cove(r=5, inset=5);
Example 12: A cove on top of an extreme prismoid top by setting height and using flat_top mode. This creates long flat tops sections at obtuse angles.
data:image/s3,"s3://crabby-images/6c918/6c918d1aa2203b94db479b335c63ee379b2547c4" alt="mask2d\_cove() Example 12"
include <BOSL2/std.scad>
diff()
prismoid([50,60], [20,30], h=20, shift=[25,16])
edge_profile(TOP, excess=20)
mask2d_cove(h=5, inset=0, mask_angle=$edge_angle, flat_top=true, $fn=128);
Example 13: Cove on an extreme prismoid top by setting height and bulge. Obtuse angles have long curved sections.
data:image/s3,"s3://crabby-images/d36e2/d36e2074a14c1edef8ec64bfdfcc451cc6fa770f" alt="mask2d\_cove() Example 13"
include <BOSL2/std.scad>
diff()
prismoid([50,60], [20,30], h=20, shift=[25,16])
edge_profile(TOP, excess=20)
mask2d_cove(h=5, inset=0, mask_angle=$edge_angle, bulge=1, $fn=128);
Example 14: Rounding an extreme prismoid top using quarter_round. Another way to handle this situation.
data:image/s3,"s3://crabby-images/caffb/caffb37986252bbf8cacfc315efbdbd3cd6a55fa" alt="mask2d\_cove() Example 14"
include <BOSL2/std.scad>
diff()
prismoid([50,60], [20,30], h=20, shift=[25,16])
edge_profile(TOP, excess=20)
mask2d_cove(r=5, inset=0, mask_angle=$edge_angle, quarter_round=true, $fn=128);
Synopsis: Produces a 2D chamfer mask shape. [Geom] [Path]
Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
See Also: corner_profile(), edge_profile(), face_profile()
Usage: As Module
- mask2d_chamfer(edge, [angle], [inset], [excess]) [ATTACHMENTS];
- mask2d_chamfer(y=, [angle=], [inset=], [excess=]) [ATTACHMENTS];
- mask2d_chamfer(x=, [angle=], [inset=], [excess=]) [ATTACHMENTS];
Usage: As Function
- path = mask2d_chamfer(edge, [angle], [inset], [excess]);
- path = mask2d_chamfer(y=, [angle=], [inset=], [excess=]);
- path = mask2d_chamfer(x=, [angle=], [inset=], [excess=]);
Description:
Creates a 2D chamfer mask shape that is useful for extruding into a 3D mask for an edge. Conversely, you can use that same extruded shape to make an interior chamfer between two walls. As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis. If called as a function, returns a 2D path of the outline of the mask shape. The edge parameter specifies the length of the chamfer's slanted edge. The x parameter specifies the width. The y parameter specfies the length of the non-horizontal arm of the chamfer. The height specifies the height of the chamfer independent of angle. You can specify any combination of parameters that determines a chamfer geometry.
Arguments:
By Position | What it does |
---|---|
edge |
The length of the edge of the chamfer. |
angle |
The angle of the chamfer edge, away from vertical. Default: mask_angle/2. |
inset |
Optional amount to inset perpendicular to each edge. Scalar or 2-vector. Default: 0 |
mask_angle |
Number of degrees in the corner angle to mask. Default: 90 |
excess |
Extra amount of mask shape to creates on the X- and Y- sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
x |
The width of the chamfer (joint distance in x direction) |
y |
The set-back (joint distance) in the non-x direction of the chamfer. |
h / height
|
The height of the chamfer (excluding inset and excess). |
w / width
|
The width of the chamfer (excluding inset and excess). |
quarter_round |
If true, make a roundover independent of the mask_angle, defined based on a 90 deg angle, with a constant height. Default: false. |
flat_top |
If true, the top inset of the mask will be horizontal instead of angled by the mask_angle. Default: true. |
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Chamfer Mask, at 45 deg by default
data:image/s3,"s3://crabby-images/99450/9945059bae6e871d95d71eb7197fd4812face9db" alt="mask2d\_chamfer() Example 1"
include <BOSL2/std.scad>
mask2d_chamfer(x=10);
Example 2: 2D Chamfer Mask, at 30 deg (measured down from vertical)
data:image/s3,"s3://crabby-images/f7bdf/f7bdf4a941ec0d893fa8b35711323e5a969bb928" alt="mask2d\_chamfer() Example 2"
include <BOSL2/std.scad>
mask2d_chamfer(x=10,angle=30);
Example 3: 2D Chamfer Mask on an acute angle. The default chamfer angle is to produce a symmetric chamfer.
data:image/s3,"s3://crabby-images/33044/330449175e11fed5aff91860a72d4d940dbdb5c7" alt="mask2d\_chamfer() Example 3"
include <BOSL2/std.scad>
mask2d_chamfer(x=10,mask_angle=45);
Example 4: 2D Chamfer Mask on an acute angle. Here we specify the angle of the chamfer
data:image/s3,"s3://crabby-images/b8140/b81401258e6ae2feb0c0fcae1075dca3a1e96154" alt="mask2d\_chamfer() Example 4"
include <BOSL2/std.scad>
mask2d_chamfer(x=10,mask_angle=45,angle=45);
Example 5: 2D Chamfer Mask specified by x and y length
data:image/s3,"s3://crabby-images/01c73/01c73a978938e1187f51d941746287d610e35516" alt="mask2d\_chamfer() Example 5"
include <BOSL2/std.scad>
mask2d_chamfer(x=4,y=10);
Example 6: 2D Chamfer Mask specified by x and y length. The y length is along the top side of the chamfer, not parallel to the Y axis.
data:image/s3,"s3://crabby-images/6bac8/6bac8b4734f35ab40645853a87832ab5224e7b98" alt="mask2d\_chamfer() Example 6"
include <BOSL2/std.scad>
mask2d_chamfer(x=4,y=5,mask_angle=44);
Example 7: 2D Chamfer Mask specified by width and height.
data:image/s3,"s3://crabby-images/582f0/582f068cb5e1fb4ff498b8a4e004edfaa7c4d56b" alt="mask2d\_chamfer() Example 7"
include <BOSL2/std.scad>
mask2d_chamfer(w=4,h=5,mask_angle=44);
Example 8: 2D Chamfer Mask on obtuse angle, specifying x. The right tip is 10 units from the origin.
data:image/s3,"s3://crabby-images/cb191/cb191f92359caaef299615fbecb37c25d2cf542c" alt="mask2d\_chamfer() Example 8"
include <BOSL2/std.scad>
mask2d_chamfer(x=10,mask_angle=127);
Example 9: 2D Chamfer Mask on obtuse angle, specifying width. The entire width is 10.
data:image/s3,"s3://crabby-images/293cf/293cf7ad7acd5053a37127144d060ba06c5b78ce" alt="mask2d\_chamfer() Example 9"
include <BOSL2/std.scad>
mask2d_chamfer(w=10,mask_angle=127);
Example 10: 2D Chamfer Mask by edge
data:image/s3,"s3://crabby-images/462da/462da85518b29b759da45a2b4620add6b6a30d24" alt="mask2d\_chamfer() Example 10"
include <BOSL2/std.scad>
mask2d_chamfer(edge=10);
Example 11: 2D Chamfer Mask by edge, acute case
data:image/s3,"s3://crabby-images/7260a/7260ae81555ec74fd026dbb6119b1e4e25ad6a65" alt="mask2d\_chamfer() Example 11"
include <BOSL2/std.scad>
mask2d_chamfer(edge=10, mask_angle=44);
Example 12: 2D Chamfer Mask by edge, obtuse case
data:image/s3,"s3://crabby-images/a12d2/a12d23b89f521b8921f510e51c4aa198a76e6b4e" alt="mask2d\_chamfer() Example 12"
include <BOSL2/std.scad>
mask2d_chamfer(edge=10, mask_angle=144);
Example 13: 2D Chamfer Mask by edge and angle
data:image/s3,"s3://crabby-images/08e29/08e295edce8e52ba96dcc14a2c60cc6b822c10dc" alt="mask2d\_chamfer() Example 13"
include <BOSL2/std.scad>
mask2d_chamfer(edge=10, angle=30);
Example 14: 2D Chamfer Mask by edge and x
data:image/s3,"s3://crabby-images/95bc7/95bc74dce2f2fc2ae4fb2a93de85972efc036697" alt="mask2d\_chamfer() Example 14"
include <BOSL2/std.scad>
mask2d_chamfer(edge=10, x=9);
Example 15: 2D Inset Chamfer Mask
data:image/s3,"s3://crabby-images/3931c/3931c4d7ecf3b5e069be56d418399cb6abb195a4" alt="mask2d\_chamfer() Example 15"
include <BOSL2/std.scad>
mask2d_chamfer(x=10, inset=2);
Example 16: 2D Inset Chamfer Mask on acute angle
data:image/s3,"s3://crabby-images/b4503/b4503d089a0eb8a416b412df7b7cfbe62d4d9ac2" alt="mask2d\_chamfer() Example 16"
include <BOSL2/std.scad>
mask2d_chamfer(x=10, inset=2, mask_angle=77);
Example 17: 2D Inset Chamfer Mask on acute angle with flat top
data:image/s3,"s3://crabby-images/e2b1a/e2b1a93a8f5c92e993d923ed7a2668b6ab5c8526" alt="mask2d\_chamfer() Example 17"
include <BOSL2/std.scad>
mask2d_chamfer(x=10, inset=2, mask_angle=77, flat_top=true);
Example 18: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/ba9d9/ba9d9a65b48d6f6d2296089e4a2d418c10eb9dfa" alt="mask2d\_chamfer() Example 18"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
mask2d_chamfer(x=10, inset=2);
Example 19: Making an interior chamfer
data:image/s3,"s3://crabby-images/bd735/bd735669edc5c77c2fddcf5f7e69d7106f49c1f7" alt="mask2d\_chamfer() Example 19"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_chamfer(edge=10);
Example 20: Chamfering an extreme prismoid by setting height
data:image/s3,"s3://crabby-images/18949/1894901334ec08c312342ff1fa306ee4e683ffea" alt="mask2d\_chamfer() Example 20"
include <BOSL2/std.scad>
diff()
prismoid([50,60], [20,30], h=20, shift=[25,16])
edge_profile(TOP, excess=20)//let(f=$edge_angle)
mask2d_chamfer(h=5,mask_angle=$edge_angle);
Example 21: Chamfering an extreme prismoid with a fixed chamfer angle. Note that a very large chamfer angle is required because of the large obtuse angles.
data:image/s3,"s3://crabby-images/76fc5/76fc560ce747c6ceedec4c2a6482affc6845b8e5" alt="mask2d\_chamfer() Example 21"
include <BOSL2/std.scad>
diff()
prismoid([50,60], [20,30], h=20, shift=[25,16])
edge_profile(TOP, excess=20)//let(f=$edge_angle)
mask2d_chamfer(h=5,mask_angle=$edge_angle,angle=64);
Example 22: Chamfering an extreme prismoid by setting height with inset and flat_top=true.
data:image/s3,"s3://crabby-images/0fa72/0fa724af87ded68abb96acc6820ff9ccc7893f01" alt="mask2d\_chamfer() Example 22"
include <BOSL2/std.scad>
diff()
prismoid([50,60], [20,30], h=20, shift=[25,16])
edge_profile(TOP, excess=20)//let(f=$edge_angle)
mask2d_chamfer(h=4,inset=1,flat_top=true,mask_angle=$edge_angle);
Synopsis: Creates a rabbet mask shape. [Geom] [Path]
Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
See Also: corner_profile(), edge_profile(), face_profile()
Usage: As Module
- mask2d_rabbet(size, [mask_angle], [excess]) [ATTACHMENTS];
Usage: As Function
- path = mask2d_rabbet(size, [mask_angle], [excess]);
Description:
Creates a 2D rabbet mask shape. When differenced away, this mask creates at the corner a rectanguler space of the specified size. This mask can be extruding into a 3D mask for an edge, or you can use that same extruded shape to make an interior shelf decoration between two walls. As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis. If called as a function, returns a 2D path of the outline of the mask shape.
Arguments:
By Position | What it does |
---|---|
size |
The size of the rabbet, either as a scalar or an [X,Y] list. |
mask_angle |
Number of degrees in the corner angle to mask. Default: 90 |
excess |
Extra amount of mask shape to creates on the X and quasi-Y sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Rabbet Mask
data:image/s3,"s3://crabby-images/4f969/4f96916a486f2dae87c1dab6c187cbd1a5ec98bf" alt="mask2d\_rabbet() Example 1"
include <BOSL2/std.scad>
mask2d_rabbet(size=10);
Example 2: 2D Asymmetrical Rabbet Mask
data:image/s3,"s3://crabby-images/e3b83/e3b83878aec03c1d1901c6d7551b217c242e734f" alt="mask2d\_rabbet() Example 2"
include <BOSL2/std.scad>
mask2d_rabbet(size=[5,10]);
Example 3: 2D Mask for a acute angle edge
data:image/s3,"s3://crabby-images/b9b34/b9b3430779096284310be005ab07f7776730d76b" alt="mask2d\_rabbet() Example 3"
include <BOSL2/std.scad>
mask2d_rabbet(size=10, mask_angle=75);
Example 4: 2D Mask for obtuse angle edge. If the obtuse angle is too large the rabbet will not fit. If that happens, you will need to increase the rabbet width.
data:image/s3,"s3://crabby-images/a0f08/a0f0849123518437a383bb252328340e5b3830ae" alt="mask2d\_rabbet() Example 4"
include <BOSL2/std.scad>
mask2d_rabbet(size=10, mask_angle=125);
Example 5: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/f33e6/f33e6034c0af7196e0f7c9518db3596cebe0eb03" alt="mask2d\_rabbet() Example 5"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
mask2d_rabbet(size=10);
Example 6: Making an interior shelf
data:image/s3,"s3://crabby-images/4a1c0/4a1c05c44092289ba8fa06fb9ab1fecf0f97d302" alt="mask2d\_rabbet() Example 6"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_rabbet(size=[5,10]);
Synopsis: Creates a 2D dovetail mask shape. [Geom] [Path]
Topics: Masks (2D), Shapes (2D), Paths (2D), Path Generators, Attachable
See Also: corner_profile(), edge_profile(), face_profile()
Usage: As Module
- mask2d_dovetail(edge, angle, [inset], [shelf], [excess], ...) [ATTACHMENTS];
- mask2d_dovetail(width=, angle=, [inset=], [shelf=], [excess=], ...) [ATTACHMENTS];
- mask2d_dovetail(height=, angle=, [inset=], [shelf=], [excess=], ...) [ATTACHMENTS];
- mask2d_dovetail(width=, height=, [inset=], [shelf=], [excess=], ...) [ATTACHMENTS];
Usage: As Function
- path = mask2d_dovetail(edge, [angle], [inset], [shelf], [excess]);
Description:
Creates a 2D dovetail mask shape that is useful for extruding into a 3D mask for a 90° edge. Conversely, you can use that same extruded shape to make an interior dovetail between two walls at a 90º angle. As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis. If called as a function, returns a 2D path of the outline of the mask shape.
Arguments:
By Position | What it does |
---|---|
edge |
The length of the edge of the dovetail. |
angle |
The angle of the chamfer edge, away from vertical. |
shelf |
The extra height to add to the inside corner of the dovetail. Default: 0 |
inset |
Optional amount to inset in perpendicular direction from each edge. Default: 0 |
mask_angle |
Number of degrees in the corner angle to mask. Default: 90 |
excess |
Extra amount of mask shape to creates on the X and quasi-Y sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
width |
The width of the dovetail (excluding any inset) |
height |
The height of the dovetail (excluding any inset or shelf). |
flat_top |
If true, the top inset of the mask will be horizontal instead of angled by the mask_angle. Default: true. |
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Dovetail Mask
data:image/s3,"s3://crabby-images/4f332/4f33266977b73380104a5c086112125b1eb1b2a7" alt="mask2d\_dovetail() Example 1"
include <BOSL2/std.scad>
mask2d_dovetail(width=10,angle=14);
Example 2: 2D Dovetail Mask by height and slope. A slope of 1/6 is a common choice.
data:image/s3,"s3://crabby-images/e4fd1/e4fd11a3538888b8f7a56a059ab87cae8be6593d" alt="mask2d\_dovetail() Example 2"
include <BOSL2/std.scad>
mask2d_dovetail(height=20, slope=1/6);
Example 3: 2D Inset Dovetail Mask to make the dovetail wider
data:image/s3,"s3://crabby-images/c40ec/c40ecc0884983fb7eacca887f30ae6f553a318e1" alt="mask2d\_dovetail() Example 3"
include <BOSL2/std.scad>
mask2d_dovetail(width=5, angle=12, inset=[4,0]);
Example 4: 2D Inset Dovetail Mask on an obtuse angle
data:image/s3,"s3://crabby-images/60dd2/60dd2b6443610b6e50daa08e48d480ad3fa498e1" alt="mask2d\_dovetail() Example 4"
include <BOSL2/std.scad>
mask2d_dovetail(width=5, mask_angle=110, angle=12);
Example 5: 2D Inset Dovetail Mask on an acute angle will generally require an inset in order to fit.
data:image/s3,"s3://crabby-images/d2db3/d2db35ac4641d49aaa176bb2ef6644d0f8eafcce" alt="mask2d\_dovetail() Example 5"
include <BOSL2/std.scad>
mask2d_dovetail(width=5, mask_angle=70, angle=12, inset=[6,0]);
Example 6: 2D dovetail mask by edge length and angle
data:image/s3,"s3://crabby-images/4b19d/4b19d15312a85640e103e340f265085adc533f6e" alt="mask2d\_dovetail() Example 6"
include <BOSL2/std.scad>
mask2d_dovetail(edge=10,width=4);
Example 7: 2D dovetail mask by width and height
data:image/s3,"s3://crabby-images/fcc5a/fcc5abbe9c796b596791c06f55e87b579668b11f" alt="mask2d\_dovetail() Example 7"
include <BOSL2/std.scad>
mask2d_dovetail(width=5,height=25);
Example 8: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/2f208/2f2084b0d010262eaf801a12d3a998b20c9de074" alt="mask2d\_dovetail() Example 8"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
mask2d_dovetail(width=10, angle=30, inset=2);
Example 9: Making an interior dovetail
data:image/s3,"s3://crabby-images/1c7b3/1c7b32d8783a826297244bbd3c6eb24b869ce713" alt="mask2d\_dovetail() Example 9"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_dovetail(width=10,angle=30);
Synopsis: Creates a 2D ogee mask shape. [Geom] [Path]
Topics: Shapes (2D), Paths (2D), Path Generators, Attachable, Masks (2D)
See Also: corner_profile(), edge_profile(), face_profile()
Usage: As Module
- mask2d_ogee(pattern, [excess], ...) [ATTAHCMENTS];
Usage: As Function
- path = mask2d_ogee(pattern, [excess], ...);
Description:
Creates a 2D Ogee mask shape that is useful for extruding into a 3D mask for a 90° edge.
Conversely, you can use that same extruded shape to make an interior ogee decoration between two walls at a 90º angle.
As a 2D mask, this is designed to be differenced away from the edge of a shape that with its corner at the origin and one edge on the X+ axis and the other mask_angle degrees counterclockwise from the X+ axis.
Since there are a number of shapes that fall under the name ogee, the shape of this mask is given as a pattern.
Patterns are given as TYPE, VALUE pairs. ie: ["fillet",10, "xstep",2, "step",[5,5], ...]
. See Patterns below.
If called as a function, returns a 2D path of the outline of the mask shape.
Type | Argument | Description |
---|---|---|
"step" | [x,y] | Makes a line to a point x right and y down. |
"xstep" | dist | Makes a dist length line towards X+. |
"ystep" | dist | Makes a dist length line towards Y-. |
"round" | radius | Makes an arc that will mask a roundover. |
"fillet" | radius | Makes an arc that will mask a fillet. |
Arguments:
By Position | What it does |
---|---|
pattern |
A list of pattern pieces to describe the Ogee. |
excess |
Extra amount of mask shape to creates on the X- and Y- sides of the shape. Default: 0.01 |
By Name | What it does |
---|---|
anchor |
Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER
|
spin |
Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
|
Example 1: 2D Ogee Mask
data:image/s3,"s3://crabby-images/7c85f/7c85fb993a6e1e953b1a50508bc85ff6b12e153a" alt="mask2d\_ogee() Example 1"
include <BOSL2/std.scad>
mask2d_ogee([
"xstep",1, "ystep",1, // Starting shoulder.
"fillet",5, "round",5, // S-curve.
"ystep",1, "xstep",1 // Ending shoulder.
]);
Example 2: Masking by Edge Attachment
data:image/s3,"s3://crabby-images/b5463/b5463aa9846718d89538205e00e90090d9357c01" alt="mask2d\_ogee() Example 2"
include <BOSL2/std.scad>
diff()
cube([50,60,70],center=true)
edge_profile(TOP)
mask2d_ogee([
"xstep",1, "ystep",1, // Starting shoulder.
"fillet",5, "round",5, // S-curve.
"ystep",1, "xstep",1 // Ending shoulder.
]);
Example 3: Making an interior ogee
data:image/s3,"s3://crabby-images/03329/03329ef96d4e8c44853b7adda9a5c253e489d1a7" alt="mask2d\_ogee() Example 3"
include <BOSL2/std.scad>
%render() difference() {
move(-[5,0,5]) cube(30, anchor=BOT+LEFT);
cube(310, anchor=BOT+LEFT);
}
xrot(90)
linear_extrude(height=30, center=true)
mask2d_ogee([
"xstep", 1, "round",5,
"ystep",1, "fillet",5,
"xstep", 1, "ystep", 1,
]);
Table of Contents
Function Index
Topics Index
Cheat Sheet
Tutorials
Basic Modeling:
- constants.scad STD
- transforms.scad STD
- attachments.scad STD
- shapes2d.scad STD
- shapes3d.scad STD
- drawing.scad STD
- masks2d.scad STD
- masks3d.scad STD
- distributors.scad STD
- color.scad STD
- partitions.scad STD
- miscellaneous.scad STD
Advanced Modeling:
- paths.scad STD
- regions.scad STD
- skin.scad STD
- vnf.scad STD
- beziers.scad STD
- nurbs.scad
- rounding.scad
- turtle3d.scad
- isosurface.scad
Math:
- math.scad STD
- linalg.scad STD
- vectors.scad STD
- coords.scad STD
- geometry.scad STD
- trigonometry.scad STD
Data Management:
- version.scad STD
- comparisons.scad STD
- lists.scad STD
- utility.scad STD
- strings.scad STD
- structs.scad STD
- fnliterals.scad
Threaded Parts:
Parts:
- ball_bearings.scad
- cubetruss.scad
- gears.scad
- hinges.scad
- joiners.scad
- linear_bearings.scad
- modular_hose.scad
- nema_steppers.scad
- polyhedra.scad
- sliders.scad
- tripod_mounts.scad
- walls.scad
- wiring.scad
STD = Included in std.scad