Skip to content

walls.scad

Revar Desmera edited this page Nov 29, 2024 · 1 revision

LibFile: walls.scad

Walls and structural elements that 3D print without support.

To use, add the following lines to the beginning of your file:

include <BOSL2/std.scad>
include <BOSL2/walls.scad>

File Contents

  1. Section: Walls

Section: Walls

Module: sparse_wall()

Synopsis: Makes an open cross-braced rectangular wall. [Geom]

Topics: FDM Optimized, Walls

See Also: hex_panel(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()

See Also: corrugated_wall(), thinning_wall()

Usage:

  • sparse_wall(h, l, thick, [maxang=], [strut=], [max_bridge=]) [ATTACHMENTS];

Description:

Makes an open rectangular strut with X-shaped cross-bracing, designed to reduce the need for support material in 3D printing.

Arguments:

By Position What it does
h height of strut wall.
l length of strut wall.
thick thickness of strut wall.
By Name What it does
maxang maximum overhang angle of cross-braces, measured down from vertical. Default: 30
strut the width of the cross-braces. Default: 5
max_bridge maximum bridging distance between cross-braces. Default: 20
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
orient Vector to rotate top towards, after spin. See orient. Default: UP

Example 1: Typical Shape

sparse\_wall() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall(h=40, l=100, thick=3);



Example 2: Thinner Strut

sparse\_wall() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall(h=40, l=100, thick=3, strut=2);



Example 3: Larger maxang

sparse\_wall() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall(h=40, l=100, thick=3, strut=2, maxang=45);



Example 4: Longer max_bridge

sparse\_wall() Example 4
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall(h=40, l=100, thick=3, strut=2, maxang=45, max_bridge=30);

Module: sparse_wall2d()

Synopsis: Makes an open cross-braced rectangular wall. [Geom]

Topics: FDM Optimized, Walls

See Also: sparse_wall(), hex_panel(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()

See Also: corrugated_wall(), thinning_wall()

Usage:

  • sparse_wall2d(size, [maxang=], [strut=], [max_bridge=]) [ATTACHMENTS];

Description:

Makes a 2D open rectangular square with X-shaped cross-bracing, designed to be extruded, to make a strut that reduces the need for support material in 3D printing.

Arguments:

By Position What it does
size The [X,Y] size of the outer rectangle.
By Name What it does
maxang maximum overhang angle of cross-braces.
strut the width of the cross-braces.
max_bridge maximum bridging distance between cross-braces.
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: Typical Shape

sparse\_wall2d() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall2d(size=[40,100]);



Example 2: Thinner Strut

sparse\_wall2d() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall2d(size=[40,100], strut=2);



Example 3: Larger maxang

sparse\_wall2d() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall2d(size=[40,100], strut=2, maxang=45);



Example 4: Longer max_bridge

sparse\_wall2d() Example 4
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_wall2d(size=[40,100], strut=2, maxang=45, max_bridge=30);

Module: sparse_cuboid()

Synopsis: Makes an open cross-braced cuboid [Geom]

Topics: FDM Optimized, Walls

See Also: sparse_wall(), hex_panel(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut(), cuboid()

Usage:

  • sparse_cuboid(size, [dir], [maxang=], [struct=]

Description:

Makes an open rectangular cuboid with X-shaped cross-bracing to reduce the need for material in 3d printing. The direction of the cross bracing can be aligned with the X, Y or Z axis. This module can be used as a drop-in replacement for cuboid() if you belatedly decide that your model would benefit from the sparse construction. Note that for Z aligned bracing the max_bridge parameter contrains the gaps that are parallel to the Y axis, and the angle is measured relative to the X direction.

Arguments:

By Position What it does
size The size of sparse wall, a number or length 3 vector.
dir direction of holes through the cuboid, must be a vector parallel to the X, Y or Z axes, or one of "X", "Y" or "Z". Default: "Y"
By Name What it does
maxang maximum overhang angle of cross-braces, measured down from vertical. Default: 30
strut the width of the cross-braces. Default: 5
max_bridge maximum bridging distance between cross-braces. Default: 20
chamfer Size of chamfer, inset from sides. Default: No chamfering.
rounding Radius of the edge rounding. Default: No rounding.
edges Edges to mask. See Specifying Edges. Default: all edges.
except Edges to explicitly NOT mask. See Specifying Edges. Default: No edges.
trimcorners If true, rounds or chamfers corners where three chamfered/rounded edges meet. Default: true
teardrop If given as a number, rounding around the bottom edge of the cuboid won't exceed this many degrees from vertical. If true, the limit angle is 45 degrees. 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. See spin. Default: 0
orient Vector to rotate top towards. See orient. Default: UP

Example 1:

sparse\_cuboid() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_cuboid([10,20,30], strut=1);



Example 2:

sparse\_cuboid() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_cuboid([10,20,30], "Y", strut=1);



Example 3:

sparse\_cuboid() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_cuboid([10,20,30], UP, strut=1);



Example 4:

sparse\_cuboid() Example 4
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
sparse_cuboid(30, FWD, strut=2, rounding=2, $fn=24);




Module: hex_panel()

Synopsis: Create a hexagon braced panel of any shape [Geom]

Topics: FDM Optimized, Walls

See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()

Usage:

  • hex_panel(shape, wall, spacing, [frame=], [bevel=], [bevel_frame=], [h=|height=|l=|length=], [anchor=], [orient=], [spin=])

Description:

Produces a panel with a honeycomb interior that can be rectangular with optional beveling, or an arbitrary polygon shape without beveling. The panel consists of a frame containing a honeycob interior. The frame is laid out in the XY plane with the honeycob interior and then extruded to the height h. The shape argument defines the outer bounderies of the frame.

The simplest way to define the frame shape is to give a cuboid size as a 3d vector for the shape argument. The h argument is not allowed in this case. With rectangular frames you can supply the bevel argument which applies a 45 deg bevel on the specified list of edges. These edges can be LEFT, RIGHT, FRONT, or BACK to place a bevel the edge facing upward. You can add BOTTOM, as in LEFT+BOT, to get a bevel that faces down. When beveling a separate beveled frame is added to the model. You can independently control its thickness by setting bevel_frame, which defaults to the frame thickness. Note also that frame and bevel_frame can be set to zero to produce just the honeycomb.

The other option is to provide a 2D path as the shape argument. The path must not intersect itself. You must give the height argument in this case and you cannot give the bevel argument. The panel is made from a linear extrusion of the specified shape. In this case, anchoring is done as usual for linear sweeps. The shape appears by default on its base and you can choose "hull" or "intersect" anchor types.

Arguments:

By Position What it does
shape 3D size vector or a 2D path
strut thickness of hexagonal bracing
spacing center-to-center spacing of hex cells in the honeycomb.
By Name What it does
frame width of the frame around the honeycomb. Default: same as strut
bevel list of edges to bevel on rectangular case when shape is a size vector; allowed options are RIGHT, LEFT, BACK, or FRONT, or those directions with BOTTOM added. Default: []
bevel_frame width of the frame applied at bevels. Default: same as frame
h / height / l / length thickness of the panel when shape is a path
anchor Translate so anchor point is at origin (0,0,0). See anchor. Default: CENTER for rectangular panels, "zcenter" for extrusions.
spin Rotate this many degrees around the Z axis after anchor. See spin. Default: 0
orient Vector to rotate top towards, after spin. See orient. Default: UP
atype Select "hull", "intersect" anchor types. Default: "hull"
cp Centerpoint for determining "intersect" anchors or centering the shape. Determintes the base of the anchor vector. Can be "centroid", "mean", "box" or a 3D point. Default: "centroid"

Named Anchors:

Anchor Name Position
"base" Anchor to the base of the shape in its native position
"top" Anchor to the top of the shape in its native position
"zcenter" Center shape in the Z direction in the native XY position (default)

Anchor Types:

Anchor Type What it is
hull Anchors to the convex hull of the linear sweep of the path, ignoring any end roundings.
intersect Anchors to the surface of the linear sweep of the path, ignoring any end roundings.

Example 1:

hex\_panel() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 5], strut=1.5, spacing=10);



Example 2:

hex\_panel() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 5], 1.5, 10, frame = 5);



Example 3:

hex\_panel() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 5], 5, 10.05);



Example 4:

hex\_panel() Example 4
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 5], 1.5, 20, frame = 5);



Example 5:

hex\_panel() Example 5
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 5], 1.5, 12, frame = 0);



Example 6:

hex\_panel() Example 6
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 5], frame = 10, spacing = 20, strut = 4);



Example 7:

hex\_panel() Example 7
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 5, bevel = [LEFT, RIGHT]);

Example 8:

hex\_panel() Example 8
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 5, bevel = [FWD,  BACK]);

Example 9:

hex\_panel() Example 9
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 3, bevel = [LEFT, RIGHT, FWD, BACK]);

Example 10:

hex\_panel() Example 10
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 1, bevel = [LEFT, RIGHT, FWD+BOTTOM, BACK+BOTTOM]);

Example 11:

hex\_panel() Example 11
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame=2, bevel_frame=0, bevel = [FWD, BACK+BOT, RIGHT, LEFT]);

Example 12: Triangle

hex\_panel() Example 12
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
s = [[0, -40], [0, 40], [60, 0]];
hex_panel(s, strut=1.5, spacing=10, h = 10, frame = 5);



Example 13: Concave polygon

hex\_panel() Example 13
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
s = [[0, -40], [0, 70], [60, 0], [80, 20], [70, -20]];
hex_panel(s, 1.5, 10, h = 10, frame = 5);



Example 14: Another concave example

hex\_panel() Example 14
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
s = [[0, -40], [0, 40], [30, 20], [60, 40], [60, -40], [30, -20]];
hex_panel(s, 1.5, 10, h = 10, frame = 5);

Example 15: Circular panel

hex\_panel() Example 15
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel(circle(30), 1.5, 10, h = 10, frame = 5);



Example 16: More complicated shape

hex\_panel() Example 16
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
s = glued_circles(d=50, spread=50, tangent=30);
hex_panel(s, 1.5, 10, h = 10, frame = 5);



Example 17: Care is required when arranging panels vertically for 3d printability. Setting orient=RIGHT produces the correct result.

hex\_panel() Example 17
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 5, bevel = [FWD, BACK], anchor = BACK + RIGHT + BOTTOM, orient = RIGHT);
zrot(-90)hex_panel([50, 100, 10], 1.5, 10, frame = 5,  bevel = [FWD, BACK], anchor = FWD + RIGHT + BOTTOM, orient = RIGHT);

Example 18: In this example panels one of the panels is positioned with orient=FWD which produces hexagons with 60 deg overhang edges that may not be 3d printable. This example alsu uses bevel_frame to thin the material at the corner.

hex\_panel() Example 18
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 5, bevel_frame=1, bevel = [FWD,  BACK], anchor = BACK + RIGHT + BOTTOM, orient = RIGHT);
hex_panel([100, 50, 10], 1.5, 10, frame = 5, bevel_frame=1, bevel = [LEFT, RIGHT], anchor = FWD + LEFT + BOTTOM, orient = FWD);

Example 19: Joining panels with attach(). In this case panels were joined front beveled edge to back beveled edge, which means the hex structure doesn't align at the joint

hex\_panel() Example 19
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 5, bevel_frame=0, bevel = [FWD, BACK], anchor = BACK + RIGHT + BOTTOM, orient = RIGHT)
  attach(BACK,FRONT)
     hex_panel([50, 100, 10], 1.5, 10, frame = 5, bevel_frame=0, bevel = [FWD, BACK]);

Example 20: Joining panels with attach(). Attaching BACK to BACK aligns the hex structure which looks better.

hex\_panel() Example 20
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
hex_panel([50, 100, 10], 1.5, 10, frame = 1, bevel = [FWD, BACK], anchor = BACK + RIGHT + BOTTOM, orient = RIGHT)
  attach(BACK,BACK)
     hex_panel([50, 100, 10], 1.5, 10, frame = 1, bevel = [FWD, BACK]);

Module: corrugated_wall()

Synopsis: Makes a corrugated rectangular wall. [Geom]

Topics: FDM Optimized, Walls

See Also: sparse_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()

See Also: sparse_wall(), thinning_wall()

Usage:

  • corrugated_wall(h, l, thick, [strut=], [wall=]) [ATTACHMENTS];

Description:

Makes a corrugated wall which relieves contraction stress while still providing support strength. Designed with 3D printing in mind.

Arguments:

By Position What it does
h height of strut wall.
l length of strut wall.
thick thickness of strut wall.
By Name What it does
strut the width of the frame.
wall thickness of corrugations.
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
orient Vector to rotate top towards, after spin. See orient. Default: UP

Example 1: Typical Shape

corrugated\_wall() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
corrugated_wall(h=50, l=100);



Example 2: Wider Strut

corrugated\_wall() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
corrugated_wall(h=50, l=100, strut=8);



Example 3: Thicker Wall

corrugated\_wall() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
corrugated_wall(h=50, l=100, strut=8, wall=3);




Module: thinning_wall()

Synopsis: Makes a rectangular wall with a thin middle. [Geom]

Topics: FDM Optimized, Walls

See Also: sparse_wall(), corrugated_wall(), thinning_triangle(), narrowing_strut()

See Also: sparse_wall(), corrugated_wall(), thinning_triangle()

Usage:

  • thinning_wall(h, l, thick, [ang=], [braces=], [strut=], [wall=]) [ATTACHMENTS];

Description:

Makes a rectangular wall which thins to a smaller width in the center, with angled supports to prevent critical overhangs.

Arguments:

By Position What it does
h Height of wall.
l Length of wall. If given as a vector of two numbers, specifies bottom and top lengths, respectively.
thick Thickness of wall.
By Name What it does
ang Maximum overhang angle of diagonal brace.
braces If true, adds diagonal crossbraces for strength.
strut The width of the borders and diagonal braces. Default: thick/2
wall The thickness of the thinned portion of the wall. Default: thick/2
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
orient Vector to rotate top towards, after spin. See orient. Default: UP

Example 1: Typical Shape

thinning\_wall() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
thinning_wall(h=50, l=80, thick=4);



Example 2: Trapezoidal

thinning\_wall() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
thinning_wall(h=50, l=[80,50], thick=4);



Example 3: Trapezoidal with Braces

thinning\_wall() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
thinning_wall(h=50, l=[80,50], thick=4, strut=4, wall=2, braces=true);

Module: thinning_triangle()

Synopsis: Makes a triangular wall with a thin middle. [Geom]

Topics: FDM Optimized, Walls

See Also: sparse_wall(), corrugated_wall(), thinning_wall(), narrowing_strut()

See Also: thinning_wall()

Usage:

  • thinning_triangle(h, l, thick, [ang=], [strut=], [wall=], [diagonly=], [center=]) [ATTACHMENTS];

Description:

Makes a triangular wall with thick edges, which thins to a smaller width in the center, with angled supports to prevent critical overhangs.

Arguments:

By Position What it does
h height of wall.
l length of wall.
thick thickness of wall.
By Name What it does
ang maximum overhang angle of diagonal brace.
strut the width of the diagonal brace.
wall the thickness of the thinned portion of the wall.
diagonly boolean, which denotes only the diagonal side (hypotenuse) should be thick.
center If true, centers shape. If false, overrides anchor with UP+BACK.
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
orient Vector to rotate top towards, after spin. See orient. Default: UP

Example 1: Centered

thinning\_triangle() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
thinning_triangle(h=50, l=80, thick=4, ang=30, strut=5, wall=2, center=true);

Example 2: All Braces

thinning\_triangle() Example 2
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
thinning_triangle(h=50, l=80, thick=4, ang=30, strut=5, wall=2, center=false);

Example 3: Diagonal Brace Only

thinning\_triangle() Example 3
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
thinning_triangle(h=50, l=80, thick=4, ang=30, strut=5, wall=2, diagonly=true, center=false);

Module: narrowing_strut()

Synopsis: Makes a strut like an extruded baseball home plate. [Geom]

Topics: FDM Optimized

See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle()

Usage:

  • narrowing_strut(w, l, wall, [ang=]) [ATTACHMENTS];

Description:

Makes a rectangular strut with the top side narrowing in a triangle. The shape created may be likened to an extruded home plate from baseball. This is useful for constructing parts that minimize the need to support overhangs.

Arguments:

By Position What it does
w Width (thickness) of the strut.
l Length of the strut.
wall height of rectangular portion of the strut.
By Name What it does
ang angle that the trianglar side will converge at.
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
orient Vector to rotate top towards, after spin. See orient. Default: UP

Example 1:

narrowing\_strut() Example 1
include <BOSL2/std.scad>
include <BOSL2/walls.scad>
narrowing_strut(w=10, l=100, wall=5, ang=30);




Clone this wiki locally