2019-04-26 02:15:53 -07:00
//////////////////////////////////////////////////////////////////////
// LibFile: walls.scad
2022-04-21 00:26:20 -04:00
// Walls and structural elements that 3D print without support.
2021-01-05 01:20:01 -08:00
// Includes:
2019-04-26 02:15:53 -07:00
// include <BOSL2/std.scad>
// include <BOSL2/walls.scad>
2021-12-13 15:48:30 -08:00
// FileGroup: Parts
// FileSummary: Walls and structural elements that 3D print without support.
2019-04-26 02:15:53 -07:00
//////////////////////////////////////////////////////////////////////
// Section: Walls
2022-03-31 19:20:29 -07:00
// Module: sparse_wall()
2023-03-31 20:08:00 -07:00
// Synopsis: Makes an open cross-braced rectangular wall.
2023-05-29 21:48:48 -07:00
// SynTags: Geom
2023-03-31 20:08:00 -07:00
// Topics: FDM Optimized, Walls
2024-05-12 21:09:44 -04:00
// See Also: corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
2022-03-31 19:20:29 -07:00
//
// Usage:
// sparse_wall(h, l, thick, [maxang=], [strut=], [max_bridge=]) [ATTACHMENTS];
//
2019-04-26 02:15:53 -07:00
// Description:
2022-03-31 19:20:29 -07:00
// Makes an open rectangular strut with X-shaped cross-bracing, designed to reduce
// the need for support material in 3D printing.
//
// Arguments:
// h = height of strut wall.
// l = length of strut wall.
// thick = thickness of strut wall.
// ---
2024-05-12 21:09:44 -04:00
// 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
2022-03-31 19:20:29 -07:00
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
//
// See Also: corrugated_wall(), thinning_wall()
//
// Example: Typical Shape
// sparse_wall(h=40, l=100, thick=3);
// Example: Thinner Strut
// sparse_wall(h=40, l=100, thick=3, strut=2);
// Example: Larger maxang
// sparse_wall(h=40, l=100, thick=3, strut=2, maxang=45);
// Example: Longer max_bridge
// sparse_wall(h=40, l=100, thick=3, strut=2, maxang=45, max_bridge=30);
module sparse_wall ( h = 50 , l = 100 , thick = 4 , maxang = 30 , strut = 5 , max_bridge = 20 , anchor = CENTER , spin = 0 , orient = UP )
{
zoff = h / 2 - strut / 2 ;
yoff = l / 2 - strut / 2 ;
maxhyp = 1.5 * ( max_bridge + strut ) / 2 / sin ( maxang ) ;
maxz = 2 * maxhyp * cos ( maxang ) ;
zreps = ceil ( 2 * zoff / maxz ) ;
zstep = 2 * zoff / zreps ;
hyp = zstep / 2 / cos ( maxang ) ;
maxy = min ( 2 * hyp * sin ( maxang ) , max_bridge + strut ) ;
yreps = ceil ( 2 * yoff / maxy ) ;
ystep = 2 * yoff / yreps ;
ang = atan ( ystep / zstep ) ;
len = zstep / cos ( ang ) ;
size = [ thick , l , h ] ;
attachable ( anchor , spin , orient , size = size ) {
yrot ( 90 )
linear_extrude ( height = thick , convexity = 4 * yreps , center = true ) {
difference ( ) {
square ( [ h , l ] , center = true ) ;
square ( [ h - 2 * strut , l - 2 * strut ] , center = true ) ;
}
ycopies ( ystep , n = yreps ) {
xcopies ( zstep , n = zreps ) {
2024-05-12 22:48:53 -04:00
skew ( syx = tan ( - ang ) ) square ( [ ( h - strut ) / zreps , strut / cos ( ang ) ] , center = true ) ;
skew ( syx = tan ( ang ) ) square ( [ ( h - strut ) / zreps , strut / cos ( ang ) ] , center = true ) ;
2022-03-31 19:20:29 -07:00
}
}
}
children ( ) ;
}
}
2024-05-12 21:09:44 -04:00
// Module: sparse_cuboid()
// Synopsis: Makes an open cross-braced cuboid
// SynTags: Geom
// Topics: FDM Optimized, Walls
// See Also: sparse_wall(), 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
2024-05-12 22:48:53 -04:00
// 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.
2024-05-12 21:09:44 -04:00
// Arguments:
// 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"
// ---
// 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](attachments.scad#section-specifying-edges). Default: all edges.
// except = Edges to explicitly NOT mask. See [Specifying Edges](attachments.scad#section-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](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards. See [orient](attachments.scad#subsection-orient). Default: `UP`
// Examples:
// sparse_cuboid([10,20,30], strut=1);
// sparse_cuboid([10,20,30], "Y", strut=1);
// sparse_cuboid([10,20,30], UP, strut=1);
2024-05-12 22:48:53 -04:00
// sparse_cuboid(30, FWD, strut=2, rounding=2, $fn=24);
2024-05-12 21:09:44 -04:00
module sparse_cuboid ( size , dir = RIGHT , strut = 5 , maxang = 30 , max_bridge = 20 ,
chamfer ,
rounding ,
edges = EDGES_ALL ,
except = [ ] ,
except_edges ,
trimcorners = true ,
teardrop = false ,
anchor = CENTER , spin = 0 , orient = UP )
{
size = scalar_vec3 ( size ) ;
dummy1 = assert ( in_list ( dir , [ "X" , "Y" , "Z" ] ) || is_vector ( dir , 3 ) , "dir must be a 3-vector or one of \"X\", \"Y\", or \"Z\"" ) ;
count = len ( [ for ( d = dir ) if ( d ! = 0 ) d ] ) ;
dummy2 = assert ( is_string ( dir ) || ( count = = 1 && len ( dir ) < = 3 ) , "vector valued dir must have exactly one non-zero component" ) ;
dir = is_string ( dir ) ? dir
: dir . x ? "X"
: dir . y ? "Y"
: "Z" ;
attachable ( anchor , spin , orient , size = size ) {
intersection ( ) {
if ( dir = = "X" )
sparse_wall ( size . z , size . y , size . x , strut = strut , maxang = maxang , max_bridge = max_bridge ) ;
else if ( dir = = "Y" )
zrot ( 90 )
sparse_wall ( size . z , size . x , size . y , strut = strut , maxang = maxang , max_bridge = max_bridge ) ;
else
yrot ( 90 )
sparse_wall ( size . x , size . y , size . z , strut = strut , maxang = maxang , max_bridge = max_bridge ) ;
cuboid ( size = size , chamfer = chamfer , rounding = rounding , edges = edges , except = except , except_edges = except_edges ,
trimcorners = trimcorners , teardrop = teardrop ) ;
}
children ( ) ;
}
}
2022-03-31 19:20:29 -07:00
// Module: corrugated_wall()
2023-03-31 20:08:00 -07:00
// Synopsis: Makes a corrugated rectangular wall.
2023-05-29 21:48:48 -07:00
// SynTags: Geom
2023-03-31 20:08:00 -07:00
// Topics: FDM Optimized, Walls
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
2019-04-26 02:15:53 -07:00
//
// Usage:
2022-03-31 19:20:29 -07:00
// 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.
2019-04-26 02:15:53 -07:00
//
// Arguments:
2022-03-31 19:20:29 -07:00
// h = height of strut wall.
// l = length of strut wall.
// thick = thickness of strut wall.
// ---
// strut = the width of the cross-braces.
// wall = thickness of corrugations.
2021-11-19 22:33:16 -05:00
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
2019-04-26 02:15:53 -07:00
//
2022-03-31 19:20:29 -07:00
// See Also: sparse_wall(), thinning_wall()
//
// Example: Typical Shape
// corrugated_wall(h=50, l=100);
// Example: Wider Strut
// corrugated_wall(h=50, l=100, strut=8);
// Example: Thicker Wall
// corrugated_wall(h=50, l=100, strut=8, wall=3);
module corrugated_wall ( h = 50 , l = 100 , thick = 5 , strut = 5 , wall = 2 , anchor = CENTER , spin = 0 , orient = UP )
2019-04-26 02:15:53 -07:00
{
2022-03-31 19:20:29 -07:00
amplitude = ( thick - wall ) / 2 ;
period = min ( 15 , thick * 2 ) ;
steps = quantup ( segs ( thick / 2 ) , 4 ) ;
step = period / steps ;
il = l - 2 * strut + 2 * step ;
size = [ thick , l , h ] ;
2020-05-29 19:04:34 -07:00
attachable ( anchor , spin , orient , size = size ) {
2022-03-31 19:20:29 -07:00
union ( ) {
linear_extrude ( height = h - 2 * strut + 0.1 , slices = 2 , convexity = ceil ( 2 * il / period ) , center = true ) {
polygon (
points = concat (
[ for ( y = [ - il / 2 : step : il / 2 ] ) [ amplitude * sin ( y / period * 360 ) - wall / 2 , y ] ] ,
[ for ( y = [ il / 2 : - step : - il / 2 ] ) [ amplitude * sin ( y / period * 360 ) + wall / 2 , y ] ]
)
) ;
}
difference ( ) {
cube ( [ thick , l , h ] , center = true ) ;
cube ( [ thick + 0.5 , l - 2 * strut , h - 2 * strut ] , center = true ) ;
2020-05-29 19:04:34 -07:00
}
}
children ( ) ;
}
2019-04-26 02:15:53 -07:00
}
// Module: thinning_wall()
2023-03-31 20:08:00 -07:00
// Synopsis: Makes a rectangular wall with a thin middle.
2023-05-29 21:48:48 -07:00
// SynTags: Geom
2023-03-31 20:08:00 -07:00
// Topics: FDM Optimized, Walls
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
2019-04-26 02:15:53 -07:00
//
2022-03-31 19:20:29 -07:00
// Usage:
// thinning_wall(h, l, thick, [ang=], [braces=], [strut=], [wall=]) [ATTACHMENTS];
//
2019-04-26 02:15:53 -07:00
// Description:
// Makes a rectangular wall which thins to a smaller width in the center,
// with angled supports to prevent critical overhangs.
//
// Arguments:
2019-06-22 23:55:39 -07:00
// 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.
2022-03-31 19:20:29 -07:00
// ---
2019-06-22 23:55:39 -07:00
// ang = Maximum overhang angle of diagonal brace.
// braces = If true, adds diagonal crossbraces for strength.
2020-05-18 21:51:25 -07:00
// strut = The width of the borders and diagonal braces. Default: `thick/2`
2022-03-31 19:20:29 -07:00
// wall = The thickness of the thinned portion of the wall. Default: `thick/2`
2021-11-19 22:33:16 -05:00
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
2019-04-26 02:15:53 -07:00
//
2022-03-31 19:20:29 -07:00
// See Also: sparse_wall(), corrugated_wall(), thinning_triangle()
//
2019-04-26 02:15:53 -07:00
// Example: Typical Shape
// thinning_wall(h=50, l=80, thick=4);
// Example: Trapezoidal
// thinning_wall(h=50, l=[80,50], thick=4);
2019-06-23 00:03:13 -07:00
// Example: Trapezoidal with Braces
// thinning_wall(h=50, l=[80,50], thick=4, strut=4, wall=2, braces=true);
2020-05-18 21:51:25 -07:00
module thinning_wall ( h = 50 , l = 100 , thick = 5 , ang = 30 , braces = false , strut , wall , anchor = CENTER , spin = 0 , orient = UP )
2019-04-26 02:15:53 -07:00
{
2020-05-29 19:04:34 -07:00
l1 = ( l [ 0 ] = = undef ) ? l : l [ 0 ] ;
l2 = ( l [ 1 ] = = undef ) ? l : l [ 1 ] ;
strut = is_num ( strut ) ? strut : min ( h , l1 , l2 , thick ) / 2 ;
wall = is_num ( wall ) ? wall : thick / 2 ;
bevel_h = strut + ( thick - wall ) / 2 / tan ( ang ) ;
2022-04-06 20:13:39 -07:00
cp1 = circle_2tangents ( strut , [ 0 , 0 , + h / 2 ] , [ l2 / 2 , 0 , + h / 2 ] , [ l1 / 2 , 0 , - h / 2 ] ) [ 0 ] ;
cp2 = circle_2tangents ( bevel_h , [ 0 , 0 , + h / 2 ] , [ l2 / 2 , 0 , + h / 2 ] , [ l1 / 2 , 0 , - h / 2 ] ) [ 0 ] ;
cp3 = circle_2tangents ( bevel_h , [ 0 , 0 , - h / 2 ] , [ l1 / 2 , 0 , - h / 2 ] , [ l2 / 2 , 0 , + h / 2 ] ) [ 0 ] ;
cp4 = circle_2tangents ( strut , [ 0 , 0 , - h / 2 ] , [ l1 / 2 , 0 , - h / 2 ] , [ l2 / 2 , 0 , + h / 2 ] ) [ 0 ] ;
2020-05-29 19:04:34 -07:00
z1 = h / 2 ;
z2 = cp1 . z ;
z3 = cp2 . z ;
x1 = l2 / 2 ;
x2 = cp1 . x ;
x3 = cp2 . x ;
x4 = l1 / 2 ;
x5 = cp4 . x ;
x6 = cp3 . x ;
y1 = thick / 2 ;
y2 = wall / 2 ;
corner1 = [ x2 , 0 , z2 ] ;
corner2 = [ - x5 , 0 , - z2 ] ;
brace_len = norm ( corner1 - corner2 ) ;
size = [ l1 , thick , h ] ;
attachable ( anchor , spin , orient , size = size , size2 = [ l2 , thick ] ) {
2021-06-22 20:04:33 -07:00
zrot ( 90 ) {
2020-05-29 19:04:34 -07:00
polyhedron (
points = [
[ - x4 , - y1 , - z1 ] ,
[ x4 , - y1 , - z1 ] ,
[ x1 , - y1 , z1 ] ,
[ - x1 , - y1 , z1 ] ,
[ - x5 , - y1 , - z2 ] ,
[ x5 , - y1 , - z2 ] ,
[ x2 , - y1 , z2 ] ,
[ - x2 , - y1 , z2 ] ,
[ - x6 , - y2 , - z3 ] ,
[ x6 , - y2 , - z3 ] ,
[ x3 , - y2 , z3 ] ,
[ - x3 , - y2 , z3 ] ,
[ - x4 , y1 , - z1 ] ,
[ x4 , y1 , - z1 ] ,
[ x1 , y1 , z1 ] ,
[ - x1 , y1 , z1 ] ,
[ - x5 , y1 , - z2 ] ,
[ x5 , y1 , - z2 ] ,
[ x2 , y1 , z2 ] ,
[ - x2 , y1 , z2 ] ,
[ - x6 , y2 , - z3 ] ,
[ x6 , y2 , - z3 ] ,
[ x3 , y2 , z3 ] ,
[ - x3 , y2 , z3 ] ,
] ,
faces = [
[ 4 , 5 , 1 ] ,
[ 5 , 6 , 2 ] ,
[ 6 , 7 , 3 ] ,
[ 7 , 4 , 0 ] ,
[ 4 , 1 , 0 ] ,
[ 5 , 2 , 1 ] ,
[ 6 , 3 , 2 ] ,
[ 7 , 0 , 3 ] ,
[ 8 , 9 , 5 ] ,
[ 9 , 10 , 6 ] ,
[ 10 , 11 , 7 ] ,
[ 11 , 8 , 4 ] ,
[ 8 , 5 , 4 ] ,
[ 9 , 6 , 5 ] ,
[ 10 , 7 , 6 ] ,
[ 11 , 4 , 7 ] ,
[ 11 , 10 , 9 ] ,
[ 20 , 21 , 22 ] ,
[ 11 , 9 , 8 ] ,
[ 20 , 22 , 23 ] ,
[ 16 , 17 , 21 ] ,
[ 17 , 18 , 22 ] ,
[ 18 , 19 , 23 ] ,
[ 19 , 16 , 20 ] ,
[ 16 , 21 , 20 ] ,
[ 17 , 22 , 21 ] ,
[ 18 , 23 , 22 ] ,
[ 19 , 20 , 23 ] ,
[ 12 , 13 , 17 ] ,
[ 13 , 14 , 18 ] ,
[ 14 , 15 , 19 ] ,
[ 15 , 12 , 16 ] ,
[ 12 , 17 , 16 ] ,
[ 13 , 18 , 17 ] ,
[ 14 , 19 , 18 ] ,
[ 15 , 16 , 19 ] ,
[ 0 , 1 , 13 ] ,
[ 1 , 2 , 14 ] ,
[ 2 , 3 , 15 ] ,
[ 3 , 0 , 12 ] ,
[ 0 , 13 , 12 ] ,
[ 1 , 14 , 13 ] ,
[ 2 , 15 , 14 ] ,
[ 3 , 12 , 15 ] ,
] ,
convexity = 6
) ;
if ( braces ) {
bracepath = [
[ - strut * 0.33 , thick / 2 ] ,
[ strut * 0.33 , thick / 2 ] ,
[ strut * 0.33 + ( thick - wall ) / 2 / tan ( ang ) , wall / 2 ] ,
[ strut * 0.33 + ( thick - wall ) / 2 / tan ( ang ) , - wall / 2 ] ,
[ strut * 0.33 , - thick / 2 ] ,
[ - strut * 0.33 , - thick / 2 ] ,
[ - strut * 0.33 - ( thick - wall ) / 2 / tan ( ang ) , - wall / 2 ] ,
[ - strut * 0.33 - ( thick - wall ) / 2 / tan ( ang ) , wall / 2 ]
] ;
xflip_copy ( ) {
intersection ( ) {
extrude_from_to ( corner1 , corner2 ) {
polygon ( bracepath ) ;
}
prismoid ( [ l1 , thick ] , [ l2 , thick ] , h = h , anchor = CENTER ) ;
}
}
}
}
children ( ) ;
}
2019-04-26 02:15:53 -07:00
}
// Module: thinning_triangle()
2023-03-31 20:08:00 -07:00
// Synopsis: Makes a triangular wall with a thin middle.
2023-05-29 21:48:48 -07:00
// SynTags: Geom
2023-03-31 20:08:00 -07:00
// Topics: FDM Optimized, Walls
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
2019-04-26 02:15:53 -07:00
//
2022-03-31 19:20:29 -07:00
// Usage:
// thinning_triangle(h, l, thick, [ang=], [strut=], [wall=], [diagonly=], [center=]) [ATTACHMENTS];
//
2019-04-26 02:15:53 -07:00
// 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:
// h = height of wall.
// l = length of wall.
// thick = thickness of wall.
2022-03-31 19:20:29 -07:00
// ---
2019-04-26 02:15:53 -07:00
// 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`.
2021-11-19 22:33:16 -05:00
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
2019-04-26 02:15:53 -07:00
//
2022-03-31 19:20:29 -07:00
// See Also: thinning_wall()
//
2019-04-26 02:15:53 -07:00
// Example: Centered
// thinning_triangle(h=50, l=80, thick=4, ang=30, strut=5, wall=2, center=true);
// Example: All Braces
// thinning_triangle(h=50, l=80, thick=4, ang=30, strut=5, wall=2, center=false);
// Example: Diagonal Brace Only
// thinning_triangle(h=50, l=80, thick=4, ang=30, strut=5, wall=2, diagonly=true, center=false);
2020-02-29 13:16:15 -08:00
module thinning_triangle ( h = 50 , l = 100 , thick = 5 , ang = 30 , strut = 5 , wall = 3 , diagonly = false , center , anchor , spin = 0 , orient = UP )
2019-04-26 02:15:53 -07:00
{
2020-05-29 19:04:34 -07:00
dang = atan ( h / l ) ;
dlen = h / sin ( dang ) ;
size = [ thick , l , h ] ;
anchor = get_anchor ( anchor , center , BOT + FRONT , CENTER ) ;
attachable ( anchor , spin , orient , size = size ) {
difference ( ) {
union ( ) {
if ( ! diagonly ) {
translate ( [ 0 , 0 , - h / 2 ] )
narrowing_strut ( w = thick , l = l , wall = strut , ang = ang ) ;
translate ( [ 0 , - l / 2 , 0 ] )
xrot ( - 90 ) narrowing_strut ( w = thick , l = h - 0.1 , wall = strut , ang = ang ) ;
}
intersection ( ) {
cube ( size = [ thick , l , h ] , center = true ) ;
xrot ( - dang ) yrot ( 180 ) {
narrowing_strut ( w = thick , l = dlen * 1.2 , wall = strut , ang = ang ) ;
}
}
cube ( size = [ wall , l - 0.1 , h - 0.1 ] , center = true ) ;
}
xrot ( - dang ) {
translate ( [ 0 , 0 , h / 2 ] ) {
cube ( size = [ thick + 0.1 , l * 2 , h ] , center = true ) ;
}
}
}
children ( ) ;
}
2019-04-26 02:15:53 -07:00
}
2022-03-31 19:20:29 -07:00
// Module: narrowing_strut()
2023-03-31 20:08:00 -07:00
// Synopsis: Makes a strut like an extruded baseball home plate.
2023-05-29 21:48:48 -07:00
// SynTags: Geom
2023-03-31 20:08:00 -07:00
// Topics: FDM Optimized
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
2019-04-26 02:15:53 -07:00
//
// Usage:
2022-03-31 19:20:29 -07:00
// narrowing_strut(w, l, wall, [ang=]) [ATTACHMENTS];
2019-04-26 02:15:53 -07:00
//
// Description:
2022-03-31 19:20:29 -07:00
// 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.
2019-04-26 02:15:53 -07:00
//
// Arguments:
2022-03-31 19:20:29 -07:00
// w = Width (thickness) of the strut.
// l = Length of the strut.
// wall = height of rectangular portion of the strut.
// ---
// ang = angle that the trianglar side will converge at.
2021-11-19 22:33:16 -05:00
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
// spin = Rotate this many degrees around the Z axis after anchor. See [spin](attachments.scad#subsection-spin). Default: `0`
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
2019-04-26 02:15:53 -07:00
//
2022-03-31 19:20:29 -07:00
// Example:
// narrowing_strut(w=10, l=100, wall=5, ang=30);
module narrowing_strut ( w = 10 , l = 100 , wall = 5 , ang = 30 , anchor = BOTTOM , spin = 0 , orient = UP )
2019-04-26 02:15:53 -07:00
{
2022-03-31 19:20:29 -07:00
h = wall + w / 2 / tan ( ang ) ;
2020-05-29 19:04:34 -07:00
size = [ w , l , h ] ;
attachable ( anchor , spin , orient , size = size ) {
2022-03-31 19:20:29 -07:00
xrot ( 90 )
fwd ( h / 2 ) {
linear_extrude ( height = l , center = true , slices = 2 ) {
back ( wall / 2 ) square ( [ w , wall ] , center = true ) ;
back ( wall - 0.001 ) {
yscale ( 1 / tan ( ang ) ) {
difference ( ) {
zrot ( 45 ) square ( w / sqrt ( 2 ) , center = true ) ;
fwd ( w / 2 ) square ( w , center = true ) ;
2020-05-29 19:04:34 -07:00
}
}
}
}
}
children ( ) ;
}
2019-04-26 02:15:53 -07:00
}
2020-05-29 19:04:34 -07:00
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap