mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
commit
b80360a189
2 changed files with 296 additions and 135 deletions
312
screws.scad
312
screws.scad
|
@ -16,7 +16,7 @@ include <structs.scad>
|
||||||
include <threading.scad>
|
include <threading.scad>
|
||||||
include <screw_drive.scad>
|
include <screw_drive.scad>
|
||||||
|
|
||||||
// Section: Screw Parameters
|
// Section: Screw and Nut Parameters
|
||||||
// This modules in this file create standard ISO (metric) and UTS (English) threaded screws.
|
// This modules in this file create standard ISO (metric) and UTS (English) threaded screws.
|
||||||
// The {{screw()}} and {{nut()}} modules produce
|
// The {{screw()}} and {{nut()}} modules produce
|
||||||
// screws and nuts that comply with the relevant ISO and ASME standards,
|
// screws and nuts that comply with the relevant ISO and ASME standards,
|
||||||
|
@ -99,6 +99,21 @@ include <screw_drive.scad>
|
||||||
// angle for UTS, or undercut heads. You can also request a "sharp" screw which will set the screw diameter
|
// angle for UTS, or undercut heads. You can also request a "sharp" screw which will set the screw diameter
|
||||||
// the theoretical maximum and produce sharp corners instead of a flat edge on the head. The flat head options
|
// the theoretical maximum and produce sharp corners instead of a flat edge on the head. The flat head options
|
||||||
// can be mixed in any order, for example, "flat sharp undercut" or "flat undercut sharp".
|
// can be mixed in any order, for example, "flat sharp undercut" or "flat undercut sharp".
|
||||||
|
// Subsection: Nuts
|
||||||
|
// Nuts come in standard sizes and BOSL2 has tables to produce sizes for both Imperial and metric nuts.
|
||||||
|
// A nut for a given thread size is defined by its shape, width and thickness. The shape is either "hex"
|
||||||
|
// for hexagonal nuts or "square" for square nuts. For hexagonal Imperial nuts, you can choose from thickness values
|
||||||
|
// of "thin", "normal" or "thick", but the thin and thick nuts are defined only for thread sizes of 1/4 inch and above.
|
||||||
|
// .
|
||||||
|
// Metric nut standards are more complicated because ISO has a series of standards and DIN has a series of conflicting
|
||||||
|
// standards. Nuts from McMaster-Carr in the USA comply with DIN rather than ISO. Furthermore, ISO does not appear
|
||||||
|
// to specify dimensions for square nuts. For metric nuts you can specify "thin", "normal" and "thick" and the
|
||||||
|
// nut will be constructed to ISO standards (ISO 4035, ISO 4032, and ISO 4033 respectively). The DIN standard for thin
|
||||||
|
// nuts matches ISO, but the DIN normal thickness nuts are thinner than ISO nuts. You can request DIN nuts
|
||||||
|
// by specifying a thickness of "DIN" or "undersized". If you request a square nut it necessariliy derives from DIN
|
||||||
|
// instead of ISO. For most nut sizes, the nut widths match between ISO and DIN, but they do differ for M10, M12, M14 and M22.
|
||||||
|
// .
|
||||||
|
// You can of course specify nuts by giving an explicit numerical width and thickness in millimeters.
|
||||||
// Subsection: Tolerance
|
// Subsection: Tolerance
|
||||||
// Without tolerance requirements, screws would not fit together. The screw standards specify a
|
// Without tolerance requirements, screws would not fit together. The screw standards specify a
|
||||||
// nominal size, but the tolerance determines a range of allowed sizes based on that nominal size.
|
// nominal size, but the tolerance determines a range of allowed sizes based on that nominal size.
|
||||||
|
@ -171,7 +186,7 @@ Torx values: https://www.stanleyengineeredfastening.com/-/media/web/sef/resourc
|
||||||
// Usage:
|
// Usage:
|
||||||
// screw([spec], [head], [drive], [thread=], [drive_size=], [length=|l=], [thread_len=], [undersize=], [shaft_undersize=], [head_undersize=], [tolerance=], [details=], [anchor=], [atype=], [orient=], [spin=]) [ATTACHMENTS];
|
// screw([spec], [head], [drive], [thread=], [drive_size=], [length=|l=], [thread_len=], [undersize=], [shaft_undersize=], [head_undersize=], [tolerance=], [details=], [anchor=], [atype=], [orient=], [spin=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Create a screw. See [screw parameters](#section-screw-parameters) for details on the parameters that define a screw.
|
// Create a screw. See [screw and nut parameters](#section-screw-and-nut-parameters) for details on the parameters that define a screw.
|
||||||
// The tolerance determines the dimensions of the screw
|
// The tolerance determines the dimensions of the screw
|
||||||
// based on ISO and ASME standards. Screws fabricated at those dimensions will mate properly with standard hardware.
|
// based on ISO and ASME standards. Screws fabricated at those dimensions will mate properly with standard hardware.
|
||||||
// Note that the $slop argument does not affect the size of screws: it only adjusts screw holes. This will work fine
|
// Note that the $slop argument does not affect the size of screws: it only adjusts screw holes. This will work fine
|
||||||
|
@ -180,9 +195,14 @@ Torx values: https://www.stanleyengineeredfastening.com/-/media/web/sef/resourc
|
||||||
// .
|
// .
|
||||||
// You can generate a screw specification from {{screw_info()}}, possibly create a modified version using {{struct_set()}}, and pass that in rather than giving the parameters.
|
// You can generate a screw specification from {{screw_info()}}, possibly create a modified version using {{struct_set()}}, and pass that in rather than giving the parameters.
|
||||||
// .
|
// .
|
||||||
// The anchors and anchor types refer to various parts of the screw, which are labeled below. The "screw" anchor type (the default) is simply
|
// Various anchor types refer to different parts of the screw, some
|
||||||
// the whole screw and the "head" anchor is the head. These anchors use the bounding cylinder for the specified screw part, except for hex
|
// of which are labeled below. The "screw" anchor type (the
|
||||||
// heads, which anchor to a hexagonal prism.
|
// default) is simply the entire screw, so TOP and BOTTOM refer to
|
||||||
|
// the head end and tip respectively, and CENTER is the midpoint of
|
||||||
|
// the whole screw, including the head. The "head" anchor refers to
|
||||||
|
// the head alone. Both of these anchor types refer to the bounding
|
||||||
|
// cylinder for the specified screw part, except for hex heads,
|
||||||
|
// which anchor to a hexagonal prism.
|
||||||
// Figure(2D,Med,VPD = 140, VPT = [18.4209, 14.9821, -3.59741], VPR = [0, 0, 0],NoAxes):
|
// Figure(2D,Med,VPD = 140, VPT = [18.4209, 14.9821, -3.59741], VPR = [0, 0, 0],NoAxes):
|
||||||
// rpos=33;
|
// rpos=33;
|
||||||
// fsize=2.5;
|
// fsize=2.5;
|
||||||
|
@ -418,8 +438,9 @@ function _get_spec(spec, needtype, origin, thread, // common parameters
|
||||||
shape, thickness // nut parameters
|
shape, thickness // nut parameters
|
||||||
) =
|
) =
|
||||||
assert(needtype=="screw_info" || needtype=="nut_info")
|
assert(needtype=="screw_info" || needtype=="nut_info")
|
||||||
assert(is_undef(thickness) || (is_num(thickness) && thickness>0) || in_list(thickness,["thin","normal","thick"]),
|
assert(is_undef(thickness) || (is_num(thickness) && thickness>0) ||
|
||||||
"thickness must be a positive number of one of \"thin\", \"thick\", or \"normal\"")
|
in_list(_downcase_if_str(thickness),["thin","normal","thick","undersized","din"]),
|
||||||
|
"thickness must be a positive number of one of \"thin\", \"thick\", \"normal\", \"undersized\", or \"DIN\"")
|
||||||
assert(!(is_undef(spec) && is_undef($screw_spec)), "No screw spec given and no parent spec available to inherit")
|
assert(!(is_undef(spec) && is_undef($screw_spec)), "No screw spec given and no parent spec available to inherit")
|
||||||
let(spec=is_undef(spec) ? $screw_spec : spec)
|
let(spec=is_undef(spec) ? $screw_spec : spec)
|
||||||
assert(is_string(spec) || is_struct(spec), "Screw/nut specification must be a string or struct")
|
assert(is_string(spec) || is_struct(spec), "Screw/nut specification must be a string or struct")
|
||||||
|
@ -642,7 +663,7 @@ module screw(spec, head, drive, thread, drive_size,
|
||||||
// Usage:
|
// Usage:
|
||||||
// screw_hole([spec], [head], [thread=], [length=|l=], [oversize=], [hole_oversize=], [head_oversize], [tolerance=], [$slop=], [anchor=], [atype=], [orient=], [spin=]) [ATTACHMENTS];
|
// screw_hole([spec], [head], [thread=], [length=|l=], [oversize=], [hole_oversize=], [head_oversize], [tolerance=], [$slop=], [anchor=], [atype=], [orient=], [spin=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Create a screw hole mask. See [screw parameters](#section-screw-parameters) for details on the parameters that define a screw.
|
// Create a screw hole mask. See [screw and nut parameters](#section-screw-and-nut-parameters) for details on the parameters that define a screw.
|
||||||
// The screw hole can be threaded to receive a screw or it can be an unthreaded clearance hole.
|
// The screw hole can be threaded to receive a screw or it can be an unthreaded clearance hole.
|
||||||
// The tolerance determines the dimensions of the screw
|
// The tolerance determines the dimensions of the screw
|
||||||
// based on ISO and ASME standards. Screws fabricated at those dimensions will mate properly with standard hardware.
|
// based on ISO and ASME standards. Screws fabricated at those dimensions will mate properly with standard hardware.
|
||||||
|
@ -660,6 +681,9 @@ module screw(spec, head, drive, thread, drive_size,
|
||||||
// replaces the head with a cylinder large enough for the head to fit. For a flat head you must specify the length of the counterbore. For other heads you can
|
// replaces the head with a cylinder large enough for the head to fit. For a flat head you must specify the length of the counterbore. For other heads you can
|
||||||
// set counterbore to true and it will be sized to match the head height. The counterbore will extend 0.01 above the TOP of the hole mask to ensure no
|
// set counterbore to true and it will be sized to match the head height. The counterbore will extend 0.01 above the TOP of the hole mask to ensure no
|
||||||
// problems with differences.
|
// problems with differences.
|
||||||
|
// .
|
||||||
|
// Anchoring for screw_hole() is the same as anchoring for {{screw()}}, with all the same anchor types and named anchors. If you specify a counterbore it is treated as
|
||||||
|
// the "head", or in the case of flat heads, it becomes part of the head.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// spec = screw specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming). This can also be a screw specification structure of the form produced by {{screw_info()}}.
|
// spec = screw specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming). This can also be a screw specification structure of the form produced by {{screw_info()}}.
|
||||||
// head = head type. See [screw heads](#subsection-screw-heads) Default: none
|
// head = head type. See [screw heads](#subsection-screw-heads) Default: none
|
||||||
|
@ -713,9 +737,8 @@ module screw(spec, head, drive, thread, drive_size,
|
||||||
// Example: Threaded hole
|
// Example: Threaded hole
|
||||||
// diff()
|
// diff()
|
||||||
// cuboid(20)
|
// cuboid(20)
|
||||||
// attach(TOP)
|
// attach(FRONT)
|
||||||
// screw_hole("M16,15",anchor=TOP,thread=true);
|
// screw_hole("M16,15",anchor=TOP,thread=true);
|
||||||
|
|
||||||
module screw_hole(spec, head, thread, oversize, hole_oversize, head_oversize,
|
module screw_hole(spec, head, thread, oversize, hole_oversize, head_oversize,
|
||||||
length, l, thread_len, tolerance=undef, counterbore=0,
|
length, l, thread_len, tolerance=undef, counterbore=0,
|
||||||
atype="screw",anchor=BOTTOM,spin=0, orient=UP)
|
atype="screw",anchor=BOTTOM,spin=0, orient=UP)
|
||||||
|
@ -853,9 +876,10 @@ module screw_hole(spec, head, thread, oversize, hole_oversize, head_oversize,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Module: shoulder_screw()
|
// Module: shoulder_screw()
|
||||||
// Usage: shoulder_screw(s, d, length, [head=], [thread_len=], [tolerance=], [head_size=], [drive=], [drive_size=], [thread=], [undersize=], [shaft_undersize=], [head_undersize=], [shoulder_undersize=],[atype=],[anchor=],[orient=],[spin=]) [ATTACHMENTS];
|
// Usage:
|
||||||
|
// shoulder_screw(s, d, length, [head=], [thread_len=], [tolerance=], [head_size=], [drive=], [drive_size=], [thread=], [undersize=], [shaft_undersize=], [head_undersize=], [shoulder_undersize=],[atype=],[anchor=],[orient=],[spin=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Create a shoulder screw. See [screw parameters](#section-screw-parameters) for details on the parameters that define a screw.
|
// Create a shoulder screw. See [screw and nut parameters](#section-screw-and-nut-parameters) for details on the parameters that define a screw.
|
||||||
// The tolerance determines the dimensions of the screw
|
// The tolerance determines the dimensions of the screw
|
||||||
// based on ISO and ASME standards. Screws fabricated at those dimensions will mate properly with standard hardware.
|
// based on ISO and ASME standards. Screws fabricated at those dimensions will mate properly with standard hardware.
|
||||||
// Note that the $slop argument does not affect the size of screws: it only adjusts screw holes. This will work fine
|
// Note that the $slop argument does not affect the size of screws: it only adjusts screw holes. This will work fine
|
||||||
|
@ -868,16 +892,14 @@ module screw_hole(spec, head, thread, oversize, hole_oversize, head_oversize,
|
||||||
// and length, and shoulder_screw() will supply the other parameters.
|
// and length, and shoulder_screw() will supply the other parameters.
|
||||||
// .
|
// .
|
||||||
// Hardware sources like McMaster sell many screws that don't comply with the standards. If you want to make such a screw then
|
// Hardware sources like McMaster sell many screws that don't comply with the standards. If you want to make such a screw then
|
||||||
// you can specify
|
// you can specify parameters like thread_len, the length of the threaded portion below the shoulder, and you can choose a different head
|
||||||
// with a
|
// type. You will need to specify the size of the head, since it cannot be looked up in tables. You can also
|
||||||
|
// generate a screw specification from {{screw_info()}}, possibly create a modified version using {{struct_set()}}, and pass that in rather than giving the parameters.
|
||||||
// .
|
// .
|
||||||
// You can generate a screw specification from {{screw_info()}}, possibly create a modified version using {{struct_set()}}, and pass that in rather than giving the parameters.
|
// The anchors and anchor types are the same as for {{screw()}} except that there is an anchor type for the shoulder and an additional set of named anchors
|
||||||
// .
|
// refering to parts of the shoulder.
|
||||||
// The anchors and anchor types refer to various parts of the screw, which are labeled below. The "screw" anchor type (the default) is simply
|
|
||||||
// the whole screw and the "head" anchor is the head. These anchors use the bounding cylinder for the specified screw part, except for hex
|
|
||||||
// heads, which anchor to a hexagonal prism.
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// s = screw system to use, case insensitive, either "ISO", "UTS", "english" or "metric", or a screw specification
|
// s = screw system to use, case insensitive, either "ISO", "UTS", "english" or "metric", or a screw name or specification. See [screw naming](#subsection-screw-naming).
|
||||||
// d = nominal shoulder diameter in mm for ISO or inches for UTS
|
// d = nominal shoulder diameter in mm for ISO or inches for UTS
|
||||||
// length = length of the shoulder (in mm)
|
// length = length of the shoulder (in mm)
|
||||||
// ---
|
// ---
|
||||||
|
@ -1356,16 +1378,18 @@ module screw_head(screw_info,details=false, counterbore=0,flat_height) {
|
||||||
// nut([spec], [shape], [thickness], [nutwidth], [thread=], [tolerance=], [hole_oversize=], [bevel=], [$slop=], [anchor=], [spin=], [orient=]) [ATTACHMENTS];
|
// nut([spec], [shape], [thickness], [nutwidth], [thread=], [tolerance=], [hole_oversize=], [bevel=], [$slop=], [anchor=], [spin=], [orient=]) [ATTACHMENTS];
|
||||||
|
|
||||||
// Description:
|
// Description:
|
||||||
// Generates a hexagonal nut. See [screw parameters](#section-screw-parameters) for details on the parameters that define a nut.
|
// Generates a hexagonal or square nut. See [screw and nut parameters](#section-screw-and-nut-parameters) for details on the parameters that define a nut.
|
||||||
// As for screws, you can give the specification in `spec` and then omit the name. The diameter is the flat-to-flat
|
// As with screws, you can give the specification in `spec` and then omit the name. The diameter is the flat-to-flat
|
||||||
// size of the nut produced.
|
// size of the nut produced. The thickness can be "thin", "normal" or "thick" to choose standard nut dimensions. For metric
|
||||||
|
// nuts you can also use thickness values of "DIN" or "undersized". The nut's shape is hexagonal by default; set shape to "square" for
|
||||||
|
// a square nut.
|
||||||
// .
|
// .
|
||||||
// The tolerance determines the actual thread sizing based on the nominal size in accordance with standards.
|
// The tolerance determines the actual thread sizing based on the nominal size in accordance with standards.
|
||||||
// The $slop parameter determines extra gaps left to account for printing overextrusion. It defaults to 0.
|
// The $slop parameter determines extra gaps left to account for printing overextrusion. It defaults to 0.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// spec = screw specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming).
|
// spec = nut specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming). This can also be a nut or screw specification structure of the form produced by {{nut_info()}} or {{screw_info()}}.
|
||||||
// shape = "hex" or "square" to specify nut shape. Default: "hex"
|
// shape = "hex" or "square" to specify nut shape. Default: "hex"
|
||||||
// thickness = "thin", "normal", "thick", or a thickness in mm. Default: "normal"
|
// thickness = "thin", "normal", "thick", or a thickness in mm. See [nuts](#subsection-nuts). Default: "normal"
|
||||||
// ---
|
// ---
|
||||||
// nutwidth = width of nut (overrides table values)
|
// nutwidth = width of nut (overrides table values)
|
||||||
// thread = thread type or specification. See [screw pitch](#subsection-standard-screw-pitch). Default: "coarse"
|
// thread = thread type or specification. See [screw pitch](#subsection-standard-screw-pitch). Default: "coarse"
|
||||||
|
@ -1378,10 +1402,26 @@ module screw_head(screw_info,details=false, counterbore=0,flat_height) {
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// Side Effects:
|
// Side Effects:
|
||||||
// `$screw_spec` is set to the spec specification structure.
|
// `$screw_spec` is set to the spec specification structure.
|
||||||
// Example: A metric and UTS nut at standard dimensions
|
// Example: All the UTS nuts at one size. Note that square nuts come in only one thickness.
|
||||||
// nut("3/8");
|
// xdistribute(spacing=0.75*INCH){
|
||||||
// //right(25) //////////////////////////////////////////// FIXME
|
// nut("3/8",thickness="thin");
|
||||||
// // nut("M8");
|
// nut("3/8",thickness="normal");
|
||||||
|
// nut("3/8",thickness="thick");
|
||||||
|
// nut("3/8",shape="square");
|
||||||
|
// }
|
||||||
|
// Example: All the ISO (and DIN) nuts at one size. Note that M10 is one of the four cases where the DIN nut width is larger.
|
||||||
|
// ydistribute(spacing=30){
|
||||||
|
// xdistribute(spacing=22){
|
||||||
|
// nut("M10", thickness="thin");
|
||||||
|
// nut("M10",thickness="undersized");
|
||||||
|
// nut("M10",thickness="normal");
|
||||||
|
// nut("M10",thickness="thick");
|
||||||
|
// }
|
||||||
|
// xdistribute(spacing=25){
|
||||||
|
// nut("M10", shape="square", thickness="thin");
|
||||||
|
// nut("M10", shape="square", thickness="normal");
|
||||||
|
// }
|
||||||
|
// }
|
||||||
// Example: The three different UTS nut tolerances (thickner than normal nuts)
|
// Example: The three different UTS nut tolerances (thickner than normal nuts)
|
||||||
// module mark(number)
|
// module mark(number)
|
||||||
// {
|
// {
|
||||||
|
@ -1410,6 +1450,7 @@ module nut(spec, shape, thickness, nutwidth, thread, tolerance, hole_oversize,
|
||||||
["width", nutwidth],
|
["width", nutwidth],
|
||||||
["threads_oversize", hole_oversize],
|
["threads_oversize", hole_oversize],
|
||||||
]);
|
]);
|
||||||
|
dummy=_validate_nut_spec(spec);
|
||||||
$screw_spec = spec;
|
$screw_spec = spec;
|
||||||
shape = struct_val(spec, "shape");
|
shape = struct_val(spec, "shape");
|
||||||
pitch = struct_val(spec, "pitch") ;
|
pitch = struct_val(spec, "pitch") ;
|
||||||
|
@ -1417,7 +1458,7 @@ module nut(spec, shape, thickness, nutwidth, thread, tolerance, hole_oversize,
|
||||||
nutwidth = struct_val(spec, "width");
|
nutwidth = struct_val(spec, "width");
|
||||||
thickness = struct_val(spec, "thickness");
|
thickness = struct_val(spec, "thickness");
|
||||||
threaded_nut(
|
threaded_nut(
|
||||||
od=nutwidth,
|
nutwidth=nutwidth,
|
||||||
id=[mean(struct_val(threadspec, "d_minor")),
|
id=[mean(struct_val(threadspec, "d_minor")),
|
||||||
mean(struct_val(threadspec, "d_pitch")),
|
mean(struct_val(threadspec, "d_pitch")),
|
||||||
mean(struct_val(threadspec, "d_major"))],
|
mean(struct_val(threadspec, "d_major"))],
|
||||||
|
@ -1431,7 +1472,7 @@ module nut(spec, shape, thickness, nutwidth, thread, tolerance, hole_oversize,
|
||||||
|
|
||||||
// Module: nut_trap_side()
|
// Module: nut_trap_side()
|
||||||
// Usage:
|
// Usage:
|
||||||
// nut_trap_side(trap_width, [spec], [shape], [poke_len=], [poke_diam=], [$slop=], [anchor=], [orient=], [spin=]) [ATTACHMENTS];
|
// nut_trap_side(trap_width, [spec], [shape], [thickness], [nutwidth=], [poke_len=], [poke_diam=], [$slop=], [anchor=], [orient=], [spin=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Create a nut trap that extends sideways, so the nut slides in perpendicular to the screw axis.
|
// Create a nut trap that extends sideways, so the nut slides in perpendicular to the screw axis.
|
||||||
// The CENTER anchor is the center of the screw hole location in the trap. The trap width is
|
// The CENTER anchor is the center of the screw hole location in the trap. The trap width is
|
||||||
|
@ -1442,9 +1483,11 @@ module nut(spec, shape, thickness, nutwidth, thread, tolerance, hole_oversize,
|
||||||
// The trap will have a default tag of "remove" if no other tag is in force.
|
// The trap will have a default tag of "remove" if no other tag is in force.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// trap_width = width of nut trap, measured from screw center, must be larger than half the nut width (If spec is omitted this argument must be given by name.)
|
// trap_width = width of nut trap, measured from screw center, must be larger than half the nut width (If spec is omitted this argument must be given by name.)
|
||||||
// spec = screw specification
|
// spec = nut specification, e.g. "M5" or "#8". See [screw naming](#subsection-screw-naming). This can also be a screw or nut specification structure of the form produced by {{nut_info()}} or {{screw_info()}}.
|
||||||
// shape = "hex" or "square" to specify the shape of the nut. Default: "hex"
|
// shape = "hex" or "square" to specify the shape of the nut. Default: "hex"
|
||||||
|
// thickness = "thin", "normal", or "thick". "DIN" or "undersized" for metric nuts. See [nuts](#subsection-nuts). Default: "normal"
|
||||||
// ---
|
// ---
|
||||||
|
// nutwidth = width of the nut. Default: determined from tables
|
||||||
// poke_len = length of poke hole. Default: no poke hole
|
// poke_len = length of poke hole. Default: no poke hole
|
||||||
// poke_diam = diameter of poke hole. Default: nut thickness
|
// poke_diam = diameter of poke hole. Default: nut thickness
|
||||||
// $slop = extra space left to account for printing over-extrusion. Default: 0
|
// $slop = extra space left to account for printing over-extrusion. Default: 0
|
||||||
|
@ -1479,17 +1522,17 @@ module nut(spec, shape, thickness, nutwidth, thread, tolerance, hole_oversize,
|
||||||
// position(TOP)screw_hole("#8,1",anchor=TOP)
|
// position(TOP)screw_hole("#8,1",anchor=TOP)
|
||||||
// position(BOT) nut_trap_side(trap_width=16);
|
// position(BOT) nut_trap_side(trap_width=16);
|
||||||
// Example: Hole-trap assembly where we position the trap relative to a feature on the model and then position the screw hole through the trap as a child to the trap.
|
// Example: Hole-trap assembly where we position the trap relative to a feature on the model and then position the screw hole through the trap as a child to the trap.
|
||||||
// diff()
|
// diff()
|
||||||
// cuboid([30,30,20])
|
// cuboid([30,30,20])
|
||||||
// position(RIGHT)cuboid([4,20,3],anchor=LEFT)
|
// position(RIGHT)cuboid([4,20,3],anchor=LEFT)
|
||||||
// right(1)position(TOP+LEFT)nut_trap_side(15, "#8",anchor=BOT+RIGHT)
|
// right(1)position(TOP+LEFT)nut_trap_side(15, "#8",anchor=BOT+RIGHT)
|
||||||
// screw_hole(length=20);
|
// screw_hole(length=20,anchor=BOT);
|
||||||
module nut_trap_side(trap_width, spec, shape, thickness, nutwidth, anchor=BOT, orient, spin, poke_len=0, poke_diam) {
|
module nut_trap_side(trap_width, spec, shape, thickness, nutwidth, anchor=BOT, orient, spin, poke_len=0, poke_diam) {
|
||||||
dummy9=assert(is_num(trap_width), "trap_width is missing or the wrong type");
|
dummy9=assert(is_num(trap_width), "trap_width is missing or the wrong type");
|
||||||
tempspec = _get_spec(spec, "nut_info", "nut_trap", shape=shape, thickness=thickness);
|
tempspec = _get_spec(spec, "nut_info", "nut_trap", shape=shape, thickness=thickness);
|
||||||
nutdata = _struct_reset(tempspec, [["width", nutwidth]]);
|
nutdata = _struct_reset(tempspec, [["width", nutwidth]]);
|
||||||
echo_struct(nutdata);
|
|
||||||
$screw_spec = is_def(spec) ? nutdata : $screw_spec;
|
$screw_spec = is_def(spec) ? nutdata : $screw_spec;
|
||||||
|
dummy8 = _validate_nut_spec(nutdata);
|
||||||
nutwidth = struct_val(nutdata,"width")+2*get_slop();
|
nutwidth = struct_val(nutdata,"width")+2*get_slop();
|
||||||
dummy = assert(is_num(poke_len) && poke_len>=0, "poke_len must be a nonnegative number")
|
dummy = assert(is_num(poke_len) && poke_len>=0, "poke_len must be a nonnegative number")
|
||||||
assert(is_undef(poke_diam) || (is_num(poke_diam) && poke_diam>0), "poke_diam must be a positive number")
|
assert(is_undef(poke_diam) || (is_num(poke_diam) && poke_diam>0), "poke_diam must be a positive number")
|
||||||
|
@ -1525,8 +1568,8 @@ module nut_trap_side(trap_width, spec, shape, thickness, nutwidth, anchor=BOT, o
|
||||||
// do this backwards, to declare a trap at a screw size and make a child screw hole, which will inherit
|
// do this backwards, to declare a trap at a screw size and make a child screw hole, which will inherit
|
||||||
// the screw dimensions.
|
// the screw dimensions.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// length/l/height/h = length/height of nut trap (must be given by name if spec is omitted)
|
// length/l/height/h = length/height of nut trap
|
||||||
// spec = screw specification
|
// spec = nut specification, e.g. "M5" or "#8". See [screw naming](#subsection-screw-naming). This can also be a screw or nut specification structure of the form produced by {{nut_info()}} or {{screw_info()}}.
|
||||||
// shape = "hex" or "square to determine type of nut. Default: "hex"
|
// shape = "hex" or "square to determine type of nut. Default: "hex"
|
||||||
// ---
|
// ---
|
||||||
// $slop = extra space left to account for printing over-extrusion. Default: 0
|
// $slop = extra space left to account for printing over-extrusion. Default: 0
|
||||||
|
@ -1547,7 +1590,7 @@ module nut_trap_side(trap_width, spec, shape, thickness, nutwidth, anchor=BOT, o
|
||||||
// Example: Nut trap with child screw hole
|
// Example: Nut trap with child screw hole
|
||||||
// nut_trap_inline(10, "#8")
|
// nut_trap_inline(10, "#8")
|
||||||
// position(TOP)screw_hole(length=10,anchor=BOT,head="flat");
|
// position(TOP)screw_hole(length=10,anchor=BOT,head="flat");
|
||||||
// Example: a pipe clamp
|
// Example(Med): a pipe clamp
|
||||||
// bardiam = 32;
|
// bardiam = 32;
|
||||||
// bandwidth = 10;
|
// bandwidth = 10;
|
||||||
// thickness = 3;
|
// thickness = 3;
|
||||||
|
@ -1563,8 +1606,8 @@ module nut_trap_side(trap_width, spec, shape, thickness, nutwidth, anchor=BOT, o
|
||||||
module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orient, spin) {
|
module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orient, spin) {
|
||||||
tempspec = _get_spec(spec, "nut_info", "nut_trap", shape=shape, thickness=undef);
|
tempspec = _get_spec(spec, "nut_info", "nut_trap", shape=shape, thickness=undef);
|
||||||
nutdata = _struct_reset(tempspec, [["width", nutwidth]]);
|
nutdata = _struct_reset(tempspec, [["width", nutwidth]]);
|
||||||
echo_struct(nutdata);
|
|
||||||
$screw_spec = is_def(spec) ? nutdata : $screw_spec;
|
$screw_spec = is_def(spec) ? nutdata : $screw_spec;
|
||||||
|
dummy = _validate_nut_spec(nutdata);
|
||||||
length = one_defined([l,length,h,height],"l,length,h,height");
|
length = one_defined([l,length,h,height],"l,length,h,height");
|
||||||
assert(is_num(length) && length>0, "length must be a positive number");
|
assert(is_num(length) && length>0, "length must be a positive number");
|
||||||
nutwidth = struct_val(nutdata,"width")+2*get_slop();
|
nutwidth = struct_val(nutdata,"width")+2*get_slop();
|
||||||
|
@ -1586,7 +1629,7 @@ module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orie
|
||||||
// info = screw_info(spec, [head], [drive], [thread=], [drive_size=], [oversize=], [head_oversize=])
|
// info = screw_info(spec, [head], [drive], [thread=], [drive_size=], [oversize=], [head_oversize=])
|
||||||
// Description:
|
// Description:
|
||||||
// Look up screw characteristics for the specified screw type.
|
// Look up screw characteristics for the specified screw type.
|
||||||
// See [screw parameters](#section-screw-parameters) for details on the parameters that define a screw.
|
// See [screw and nut parameters](#section-screw-and-nut-parameters) for details on the parameters that define a screw.
|
||||||
// .
|
// .
|
||||||
// The `oversize=` parameter adds the specified amount to the screw and head diameter to make an
|
// The `oversize=` parameter adds the specified amount to the screw and head diameter to make an
|
||||||
// oversized screw. Does not affect length, thread pitch or head height.
|
// oversized screw. Does not affect length, thread pitch or head height.
|
||||||
|
@ -1594,7 +1637,7 @@ module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orie
|
||||||
// Note that flat head screws are defined by two different diameters, the theoretical maximum diameter, "head_size_sharp"
|
// Note that flat head screws are defined by two different diameters, the theoretical maximum diameter, "head_size_sharp"
|
||||||
// and the actual diameter, "head_size". The screw form is defined using the theoretical maximum, which gives
|
// and the actual diameter, "head_size". The screw form is defined using the theoretical maximum, which gives
|
||||||
// sharp circular edge at the top of the screw. Real screws have a flat chamfer around the edge.
|
// sharp circular edge at the top of the screw. Real screws have a flat chamfer around the edge.
|
||||||
// Figure(2D,Med,NoAxes,VPD=39,VPT=[0,-4]): Flat head screw geometry
|
// Figure(2D,Med,NoAxes,VPD=39,VPT=[0,-4,0],VPR=[0,0,0]): Flat head screw geometry
|
||||||
// polysharp = [[0, -5.07407], [4.92593, -5.07407], [10, 0], [10, 0.01], [0, 0.01]];
|
// polysharp = [[0, -5.07407], [4.92593, -5.07407], [10, 0], [10, 0.01], [0, 0.01]];
|
||||||
// color("blue"){
|
// color("blue"){
|
||||||
// xflip_copy()polygon(polysharp);
|
// xflip_copy()polygon(polysharp);
|
||||||
|
@ -1704,9 +1747,12 @@ function screw_info(spec, head, drive, thread, drive_size, threads_oversize=0, h
|
||||||
// hole_oversize = amount ot increase diameter of hole in nut. Default: 0
|
// hole_oversize = amount ot increase diameter of hole in nut. Default: 0
|
||||||
|
|
||||||
function nut_info(spec, shape, thickness, thread, hole_oversize=0, width, _origin) =
|
function nut_info(spec, shape, thickness, thread, hole_oversize=0, width, _origin) =
|
||||||
|
assert(is_undef(thickness) || (is_num(thickness) && thickness>0) ||
|
||||||
|
in_list(_downcase_if_str(thickness),["thin","normal","thick","undersized","din"]),
|
||||||
|
"thickness must be a positive number of one of \"thin\", \"thick\", \"normal\", \"undersized\", or \"DIN\"")
|
||||||
let(
|
let(
|
||||||
shape = default(shape,"hex"),
|
shape = downcase(default(shape,"hex")),
|
||||||
thickness = default(thickness, "normal")
|
thickness = _downcase_if_str(default(thickness, "normal"))
|
||||||
)
|
)
|
||||||
assert(is_string(spec), str("Nut specification must be a string ",spec))
|
assert(is_string(spec), str("Nut specification must be a string ",spec))
|
||||||
assert(in_list(shape, ["hex","square"]), "Nut shape must be \"hex\" or \"square\"")
|
assert(in_list(shape, ["hex","square"]), "Nut shape must be \"hex\" or \"square\"")
|
||||||
|
@ -1716,8 +1762,8 @@ function nut_info(spec, shape, thickness, thread, hole_oversize=0, width, _origi
|
||||||
thread = is_undef(thread) || thread==true ? "coarse"
|
thread = is_undef(thread) || thread==true ? "coarse"
|
||||||
: thread==false || thread=="none" ? 0
|
: thread==false || thread=="none" ? 0
|
||||||
: thread,
|
: thread,
|
||||||
nutdata = type[0]=="english" ? _nut_info_english(type[1],type[2], thread, shape, thickness)
|
nutdata = type[0]=="english" ? _nut_info_english(type[1],type[2], thread, shape, thickness, width)
|
||||||
: type[0]=="metric" ? _nut_info_metric(type[1],type[2], thread, shape, thickness)
|
: type[0]=="metric" ? _nut_info_metric(type[1],type[2], thread, shape, thickness, width)
|
||||||
: []
|
: []
|
||||||
)
|
)
|
||||||
_struct_reset(nutdata, [["name", spec],
|
_struct_reset(nutdata, [["name", spec],
|
||||||
|
@ -1729,6 +1775,8 @@ function nut_info(spec, shape, thickness, thread, hole_oversize=0, width, _origi
|
||||||
|
|
||||||
// Nut data is from ASME B18.2.2, mostly Table A-1
|
// Nut data is from ASME B18.2.2, mostly Table A-1
|
||||||
function _nut_info_english(diam, threadcount, thread, shape, thickness, width) =
|
function _nut_info_english(diam, threadcount, thread, shape, thickness, width) =
|
||||||
|
assert(!is_string(thickness) || in_list(thickness,["normal","thin","thick"]),
|
||||||
|
"You cannot use thickness \"DIN\" or \"undersized\" with English nuts")
|
||||||
let(
|
let(
|
||||||
screwspec=_screw_info_english(diam, threadcount, head="none", thread=thread),
|
screwspec=_screw_info_english(diam, threadcount, head="none", thread=thread),
|
||||||
diameter = struct_val(screwspec,"diameter")/INCH,
|
diameter = struct_val(screwspec,"diameter")/INCH,
|
||||||
|
@ -1792,7 +1840,8 @@ function _nut_info_english(diam, threadcount, thread, shape, thickness, width) =
|
||||||
: diameter < 11/16 ? quantdn(7/8*diameter,1/64)
|
: diameter < 11/16 ? quantdn(7/8*diameter,1/64)
|
||||||
: diameter < 1+3/16 ? 7/8*diameter - 1/64
|
: diameter < 1+3/16 ? 7/8*diameter - 1/64
|
||||||
: 7/8 * diameter - 1/32,
|
: 7/8 * diameter - 1/32,
|
||||||
width = is_def(entry[1]) ? entry[1]
|
width = is_num(width) ? width/INCH
|
||||||
|
: is_def(entry[1]) ? entry[1]
|
||||||
: shape=="square" ? (diameter<5/8 ? quantup(1.5*diameter,1/16)+1/16 : 1.5*diameter)
|
: shape=="square" ? (diameter<5/8 ? quantup(1.5*diameter,1/16)+1/16 : 1.5*diameter)
|
||||||
: quantup(1.5*diameter,1/16)
|
: quantup(1.5*diameter,1/16)
|
||||||
)
|
)
|
||||||
|
@ -1805,41 +1854,122 @@ function _nut_info_english(diam, threadcount, thread, shape, thickness, width) =
|
||||||
["shape", shape]];
|
["shape", shape]];
|
||||||
|
|
||||||
|
|
||||||
|
function _downcase_if_str(s) = is_string(s) ? downcase(s) : s;
|
||||||
|
|
||||||
/*
|
function _nut_info_metric(diam, pitch, thread, shape, thickness, width) =
|
||||||
|
let(
|
||||||
|
screwspec=_screw_info_metric(diam, pitch, head="none", thread=thread),
|
||||||
|
diameter = struct_val(screwspec,"diameter"),
|
||||||
|
|
||||||
normal
|
ISO_table = // - ASME B18.4.1M - DIN 439
|
||||||
1.6, [3.2
|
// --- ISO 4032 ---- ISO 4035 ISO 4033
|
||||||
2, [4 1.6
|
// normal normal thin thick
|
||||||
2.5, [5 2
|
// diam width midpt max (max) (max)
|
||||||
3, [5.5 2.4
|
// Preferred threads
|
||||||
4, [7 3.2
|
[
|
||||||
5, [8 4
|
[1.6, [3.2 , 1.2, 1.3, 1.0 ]],
|
||||||
6, [10
|
[2, [4 , 1.5, 1.6, 1.2 ]],
|
||||||
8, [13 6.5
|
[2.5, [5 , 1.875, 2, 1.6 ]],
|
||||||
10, [16 8
|
[3, [5.5 , 2.25, 2.4, 1.8 ]],
|
||||||
12, [18 10
|
[4, [7 , 3, 3.2, 2.2 ]],
|
||||||
16, [24 13
|
[5, [8 , 4.5 , 4.7, 2.7, 5.1]],
|
||||||
20, [30 16
|
[6, [10 , 5, 5.2, 3.2, 5.7]],
|
||||||
24, [36 19
|
[8, [13 , 6.675, 6.8, undef, 7.5]],
|
||||||
30, [46 24
|
[10, [16 , 8.25, 8.4, undef, 9.3]],
|
||||||
36, [55 29
|
[12, [18 , 10.5, 10.8, undef, 12 ]],
|
||||||
42, [65 34
|
[16, [24 , 14.5, 14.8, undef, 16.4]],
|
||||||
48, [75 38
|
[20, [30 , 17.5, 18, undef, 20.3]],
|
||||||
56, [85
|
[24, [36 , 21, 21.5, undef, 23.9]],
|
||||||
64, [95
|
[30, [46 , 25, 25.6, undef, 28.6]],
|
||||||
|
[36, [55 , 30, 31, undef, 34.7]],
|
||||||
3.5, [6
|
[42, [65 , 33, 34, undef ]],
|
||||||
14, [21
|
[48, [75 , 37, 38, undef ]],
|
||||||
18, [27
|
[56, [85 , 44, 45, undef ]],
|
||||||
22, [34
|
[64, [95 , 50, 51, undef ]],
|
||||||
27, [41
|
// Non-preferred threads
|
||||||
33, [50
|
[3.5, [ 6, 2.675, 2.8, 2 ]],
|
||||||
39, [60
|
[14, [21, 12.5, 12.8, undef, 14.1]],
|
||||||
45, [70
|
[18, [27, 15.5, 15.8, undef, 17.6]],
|
||||||
52, [80
|
[22, [34, 19, 19.4, undef, 21.8]],
|
||||||
60, [90
|
[27, [41, 23, 23.8, undef, 26.7]],
|
||||||
*/
|
[33, [50, 28, 28.7, undef, 32.5]],
|
||||||
|
[39, [60, 33, 33.4, undef ]],
|
||||||
|
[45, [70, 35, 36, undef ]],
|
||||||
|
[52, [80, 41, 42, undef ]],
|
||||||
|
[60, [90, 47, 48, undef ]]
|
||||||
|
],
|
||||||
|
DIN_table =
|
||||||
|
[
|
||||||
|
// DIN 934 DIN 936 DIN 562 DIN 557
|
||||||
|
//diam width normal thin thin square square
|
||||||
|
[ 1, [ 2.5, 0.8, undef]],
|
||||||
|
[ 1.2, [ 3, 1 , undef]],
|
||||||
|
[ 1.4, [ 3, 1.2, undef]],
|
||||||
|
[ 1.6, [ 3.2, 1.3, undef, 1.0]],
|
||||||
|
[ 2, [ 4, 1.6, undef, 1.2]],
|
||||||
|
[ 2.5, [ 5, 2 , undef, 1.6]],
|
||||||
|
[ 3, [ 5.5, 2.4, undef, 1.8]],
|
||||||
|
[ 3.5, [ 6, 2.8, undef, 2.0]],
|
||||||
|
[ 4, [ 7, 3.2, 2.8, 2.2]],
|
||||||
|
[ 5, [ 8, 4, 3.5, 2.7]],
|
||||||
|
[ 6, [ 10, 5, 4 , 3.2]],
|
||||||
|
[ 7, [ 11, 5.5, 4 ]],
|
||||||
|
[ 8, [ 13, 6.5, 5 ]],
|
||||||
|
[ 10, [ 17, 8, 6 ]], //
|
||||||
|
[ 12, [ 19, 10, 7 ]], //
|
||||||
|
[ 14, [ 22, 11, 8 ]], //
|
||||||
|
[ 16, [ 24, 13, 8 ]],
|
||||||
|
[ 18, [ 27, 15, 9 ]],
|
||||||
|
[ 20, [ 30, 16, 9 ]],
|
||||||
|
[ 22, [ 32, 18, 10 ]], //
|
||||||
|
[ 24, [ 36, 19, 10 ]],
|
||||||
|
[ 27, [ 41, 22, 12 ]],
|
||||||
|
[ 30, [ 46, 24, 12 ]],
|
||||||
|
[ 33, [ 50, 26, 14 ]],
|
||||||
|
[ 36, [ 55, 29, 14 ]],
|
||||||
|
[ 39, [ 60, 31, 16 ]],
|
||||||
|
[ 42, [ 65, 34, 16 ]],
|
||||||
|
[ 45, [ 70, 36, 18 ]],
|
||||||
|
[ 48, [ 75, 38, 18 ]],
|
||||||
|
[ 52, [ 80, 42, 20 ]],
|
||||||
|
[ 56, [ 85, 45]],
|
||||||
|
[ 60, [ 90, 48]],
|
||||||
|
[ 64, [ 95, 51]],
|
||||||
|
[ 68, [ 100, 54]],
|
||||||
|
[ 72, [ 105, 58]],
|
||||||
|
[ 76, [ 110, 61]],
|
||||||
|
[ 80, [ 115, 64]],
|
||||||
|
[ 85, [ 120, 68]],
|
||||||
|
[ 90, [ 130, 72]],
|
||||||
|
[ 100, [ 145, 80]],
|
||||||
|
[ 110, [ 155, 88]],
|
||||||
|
[ 125, [ 180, 100]],
|
||||||
|
[ 140, [ 200, 112]],
|
||||||
|
[ 160, [ 230, 128]]
|
||||||
|
],
|
||||||
|
useDIN = thickness=="din" || thickness=="undersized" || shape=="square",
|
||||||
|
entry = struct_val(useDIN ? DIN_table : ISO_table, diameter),
|
||||||
|
width = is_def(width) ? width
|
||||||
|
: entry[0],
|
||||||
|
thickind = useDIN && thickness=="thin" ? 3
|
||||||
|
: useDIN ? 1
|
||||||
|
: thickness=="normal" ? 2
|
||||||
|
: thickness=="thin" ? 3
|
||||||
|
: thickness=="thick" ? 4
|
||||||
|
: undef,
|
||||||
|
thickness = is_num(thickness) ? thickness
|
||||||
|
: is_def(entry[thickind]) ? entry[thickind]
|
||||||
|
: thickness=="thin" && diameter > 8 ? diam/2
|
||||||
|
: undef
|
||||||
|
)
|
||||||
|
assert(is_def(thickness) && is_def(width), "Unknown thickness, size and shape combination for nut")
|
||||||
|
[["type","nut_info"],
|
||||||
|
["system", "ISO"],
|
||||||
|
["diameter", struct_val(screwspec, "diameter")],
|
||||||
|
["pitch", struct_val(screwspec,"pitch")],
|
||||||
|
["width", width],
|
||||||
|
["thickness", thickness],
|
||||||
|
["shape", shape]];
|
||||||
|
|
||||||
|
|
||||||
function _screw_info_english(diam, threadcount, head, thread, drive) =
|
function _screw_info_english(diam, threadcount, head, thread, drive) =
|
||||||
|
@ -2565,8 +2695,30 @@ function _screw_info_metric(diam, pitch, head, thread, drive) =
|
||||||
|
|
||||||
function _is_positive(x) = is_num(x) && x>0;
|
function _is_positive(x) = is_num(x) && x>0;
|
||||||
|
|
||||||
|
|
||||||
|
function _validate_nut_spec(spec) =
|
||||||
|
let(
|
||||||
|
//dummy=echo_struct(spec,"Screw Specification"),
|
||||||
|
systemOK = in_list(struct_val(spec,"system"), ["UTS","ISO"]),
|
||||||
|
diamOK = _is_positive(struct_val(spec, "diameter")),
|
||||||
|
pitch = struct_val(spec,"pitch"),
|
||||||
|
pitchOK = is_undef(pitch) || (is_num(pitch) && pitch>=0),
|
||||||
|
shape = struct_val(spec, "shape"),
|
||||||
|
shapeOK = shape=="hex" || shape=="square",
|
||||||
|
thicknessOK = _is_positive(struct_val(spec, "thickness")),
|
||||||
|
widthOK = _is_positive(struct_val(spec, "width"))
|
||||||
|
)
|
||||||
|
assert(systemOK, str("Nut spec has invalid \"system\", ", struct_val(spec,"system"), ". Must be \"ISO\" or \"UTS\""))
|
||||||
|
assert(diamOK, str("Nut spec has invalid \"diameter\", ", struct_val(spec,"diameter")))
|
||||||
|
assert(pitchOK, str("Nut spec has invalid \"pitch\", ", pitch))
|
||||||
|
assert(shapeOK, str("Nut spec has invalid \"shape\", ", shape, ". Must be \"square\" or \"hex\""))
|
||||||
|
assert(thicknessOK, str("Nut spec thickness is not a postive number: ",struct_val(spec,"thickness")))
|
||||||
|
assert(widthOK, str("Nut spec width is not a postive number: ",struct_val(spec,"width")))
|
||||||
|
spec;
|
||||||
|
|
||||||
|
|
||||||
function _validate_screw_spec(spec) = let(
|
function _validate_screw_spec(spec) = let(
|
||||||
dummy=echo_struct(spec,"Screw Specification"),
|
//dummy=echo_struct(spec,"Screw Specification"),
|
||||||
systemOK = in_list(struct_val(spec,"system"), ["UTS","ISO"]),
|
systemOK = in_list(struct_val(spec,"system"), ["UTS","ISO"]),
|
||||||
diamOK = _is_positive(struct_val(spec, "diameter")),
|
diamOK = _is_positive(struct_val(spec, "diameter")),
|
||||||
pitch = struct_val(spec,"pitch"),
|
pitch = struct_val(spec,"pitch"),
|
||||||
|
|
111
threading.scad
111
threading.scad
|
@ -56,8 +56,8 @@
|
||||||
// threaded_rod(l=40, pitch=pitch, d=d,starts=starts,anchor=BOTTOM);
|
// threaded_rod(l=40, pitch=pitch, d=d,starts=starts,anchor=BOTTOM);
|
||||||
// threaded_rod(l=40, pitch=pitch, d=d, left_handed=true,starts=starts,anchor=BOTTOM);
|
// threaded_rod(l=40, pitch=pitch, d=d, left_handed=true,starts=starts,anchor=BOTTOM);
|
||||||
// }
|
// }
|
||||||
// threaded_nut(od=4.5/8*INCH,id=d,h=3/8*INCH,pitch=pitch,starts=starts,anchor=BOTTOM);
|
// threaded_nut(nutwidth=4.5/8*INCH,id=d,h=3/8*INCH,pitch=pitch,starts=starts,anchor=BOTTOM);
|
||||||
// threaded_nut(od=4.5/8*INCH,id=d,h=3/8*INCH,pitch=pitch,starts=starts,left_handed=true,anchor=BOTTOM);
|
// threaded_nut(nutwidth=4.5/8*INCH,id=d,h=3/8*INCH,pitch=pitch,starts=starts,left_handed=true,anchor=BOTTOM);
|
||||||
// }
|
// }
|
||||||
function threaded_rod(
|
function threaded_rod(
|
||||||
d, l, pitch,
|
d, l, pitch,
|
||||||
|
@ -128,11 +128,11 @@ module threaded_rod(
|
||||||
|
|
||||||
// Module: threaded_nut()
|
// Module: threaded_nut()
|
||||||
// Usage:
|
// Usage:
|
||||||
// threaded_nut(od, id, h, pitch,...) [ATTACHMENTS];
|
// threaded_nut(nutwidth, id, h, pitch,...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a hex nut or square nut for an ISO (metric) or UTS (English) threaded rod.
|
// Constructs a hex nut or square nut for an ISO (metric) or UTS (English) threaded rod.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// od = diameter of the nut.
|
// nutwidth = flat to flat width of nut
|
||||||
// id = diameter of threaded rod to screw onto.
|
// id = diameter of threaded rod to screw onto.
|
||||||
// h = height/thickness of nut.
|
// h = height/thickness of nut.
|
||||||
// pitch = Length between threads.
|
// pitch = Length between threads.
|
||||||
|
@ -148,15 +148,15 @@ module threaded_rod(
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
||||||
// Examples(Med):
|
// Examples(Med):
|
||||||
// threaded_nut(od=16, id=8, h=8, pitch=1.25, $slop=0.05, $fa=1, $fs=1);
|
// threaded_nut(nutwidth=16, id=8, h=8, pitch=1.25, $slop=0.05, $fa=1, $fs=1);
|
||||||
// threaded_nut(od=16, id=8, h=8, pitch=1.25, left_handed=true, bevel=true, $slop=0.1, $fa=1, $fs=1);
|
// threaded_nut(nutwidth=16, id=8, h=8, pitch=1.25, left_handed=true, bevel=true, $slop=0.1, $fa=1, $fs=1);
|
||||||
function threaded_nut(
|
function threaded_nut(
|
||||||
od, id, h,
|
nutwidth, id, h,
|
||||||
pitch, starts=1, shape, left_handed=false, bevel, bevel1, bevel2, id1,id2,
|
pitch, starts=1, shape, left_handed=false, bevel, bevel1, bevel2, id1,id2,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
)=no_function("threaded_nut");
|
)=no_function("threaded_nut");
|
||||||
module threaded_nut(
|
module threaded_nut(
|
||||||
od, id, h,
|
nutwidth, id, h,
|
||||||
pitch, starts=1, shape="hex", left_handed=false, bevel, bevel1, bevel2, id1,id2,
|
pitch, starts=1, shape="hex", left_handed=false, bevel, bevel1, bevel2, id1,id2,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
) {
|
) {
|
||||||
|
@ -184,7 +184,7 @@ module threaded_nut(
|
||||||
[ 6/16, -depth/pitch]
|
[ 6/16, -depth/pitch]
|
||||||
];
|
];
|
||||||
generic_threaded_nut(
|
generic_threaded_nut(
|
||||||
od=od,
|
nutwidth=nutwidth,
|
||||||
id=basic ? id : id[2], id1=id1, id2=id2,
|
id=basic ? id : id[2], id1=id1, id2=id2,
|
||||||
h=h,
|
h=h,
|
||||||
pitch=pitch,
|
pitch=pitch,
|
||||||
|
@ -323,14 +323,14 @@ module trapezoidal_threaded_rod(
|
||||||
|
|
||||||
// Module: trapezoidal_threaded_nut()
|
// Module: trapezoidal_threaded_nut()
|
||||||
// Usage:
|
// Usage:
|
||||||
// trapezoidal_threaded_nut(od, id, h, pitch, [thread_angle], [thread_depth], ...) [ATTACHMENTS];
|
// trapezoidal_threaded_nut(nutwidth, id, h, pitch, [thread_angle], [thread_depth], ...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a hex nut or square nut for a symmetric trapzoidal threaded rod.
|
// Constructs a hex nut or square nut for a symmetric trapzoidal threaded rod.
|
||||||
// By default produces the nominal dimensions
|
// By default produces the nominal dimensions
|
||||||
// for metric trapezoidal threads: a thread angle of 30 degrees and a depth set to half the pitch.
|
// for metric trapezoidal threads: a thread angle of 30 degrees and a depth set to half the pitch.
|
||||||
// You can also specify your own trapezoid parameters. For ACME threads see acme_threaded_nut().
|
// You can also specify your own trapezoid parameters. For ACME threads see acme_threaded_nut().
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// od = diameter of the nut.
|
// nutwidth = flat to flat width of nut
|
||||||
// id = diameter of threaded rod to screw onto.
|
// id = diameter of threaded rod to screw onto.
|
||||||
// h = height/thickness of nut.
|
// h = height/thickness of nut.
|
||||||
// pitch = Thread spacing.
|
// pitch = Thread spacing.
|
||||||
|
@ -348,11 +348,11 @@ module trapezoidal_threaded_rod(
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
||||||
// Examples(Med):
|
// Examples(Med):
|
||||||
// trapezoidal_threaded_nut(od=16, id=8, h=8, pitch=2, $slop=0.1, anchor=UP);
|
// trapezoidal_threaded_nut(nutwidth=16, id=8, h=8, pitch=2, $slop=0.1, anchor=UP);
|
||||||
// trapezoidal_threaded_nut(od=16, id=8, h=8, pitch=2, bevel=true, $slop=0.05, anchor=UP);
|
// trapezoidal_threaded_nut(nutwidth=16, id=8, h=8, pitch=2, bevel=true, $slop=0.05, anchor=UP);
|
||||||
// trapezoidal_threaded_nut(od=17.4, id=10, h=10, pitch=2, $slop=0.1, left_handed=true);
|
// trapezoidal_threaded_nut(nutwidth=17.4, id=10, h=10, pitch=2, $slop=0.1, left_handed=true);
|
||||||
// trapezoidal_threaded_nut(od=17.4, id=10, h=10, pitch=2, starts=3, $fa=1, $fs=1, $slop=0.15);
|
// trapezoidal_threaded_nut(nutwidth=17.4, id=10, h=10, pitch=2, starts=3, $fa=1, $fs=1, $slop=0.15);
|
||||||
function trapezoidal_threaded_rod(
|
function trapezoidal_threaded_nut(
|
||||||
d, l, pitch,
|
d, l, pitch,
|
||||||
thread_angle=30,
|
thread_angle=30,
|
||||||
thread_depth=undef, shape,
|
thread_depth=undef, shape,
|
||||||
|
@ -364,7 +364,7 @@ function trapezoidal_threaded_rod(
|
||||||
center, anchor, spin, orient
|
center, anchor, spin, orient
|
||||||
) = no_function("trapezoidal_threaded_nut");
|
) = no_function("trapezoidal_threaded_nut");
|
||||||
module trapezoidal_threaded_nut(
|
module trapezoidal_threaded_nut(
|
||||||
od,
|
nutwidth,
|
||||||
id,
|
id,
|
||||||
h,
|
h,
|
||||||
pitch,
|
pitch,
|
||||||
|
@ -389,7 +389,7 @@ module trapezoidal_threaded_nut(
|
||||||
[ z1, 0],
|
[ z1, 0],
|
||||||
[ z2, rr1],
|
[ z2, rr1],
|
||||||
];
|
];
|
||||||
generic_threaded_nut(od=od,id=id,h=h,pitch=pitch,profile=profile,id1=id1,id2=id2,
|
generic_threaded_nut(nutwidth=nutwidth,id=id,h=h,pitch=pitch,profile=profile,id1=id1,id2=id2,
|
||||||
shape=shape,left_handed=left_handed,bevel=bevel,bevel1=bevel1,bevel2=bevel2,starts=starts,
|
shape=shape,left_handed=left_handed,bevel=bevel,bevel1=bevel1,bevel2=bevel2,starts=starts,
|
||||||
anchor=anchor,spin=spin,orient=orient)
|
anchor=anchor,spin=spin,orient=orient)
|
||||||
children();
|
children();
|
||||||
|
@ -465,11 +465,11 @@ module acme_threaded_rod(
|
||||||
|
|
||||||
// Module: acme_threaded_nut()
|
// Module: acme_threaded_nut()
|
||||||
// Usage:
|
// Usage:
|
||||||
// acme_threaded_nut(od, id, h, tpi|pitch=, ...) [ATTACHMENTS];
|
// acme_threaded_nut(nutwidth, id, h, tpi|pitch=, [shape=], ...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a hex nut for an ACME threaded screw rod.
|
// Constructs a hexagonal or square nut for an ACME threaded screw rod.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// od = diameter of the nut.
|
// nutwidth = flat to flat width of nut.
|
||||||
// id = diameter of threaded rod to screw onto.
|
// id = diameter of threaded rod to screw onto.
|
||||||
// h = height/thickness of nut.
|
// h = height/thickness of nut.
|
||||||
// tpi = threads per inch
|
// tpi = threads per inch
|
||||||
|
@ -486,17 +486,17 @@ module acme_threaded_rod(
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
||||||
// Examples(Med):
|
// Examples(Med):
|
||||||
// acme_threaded_nut(od=16, id=3/8*INCH, h=8, tpi=8, $slop=0.05);
|
// acme_threaded_nut(nutwidth=16, id=3/8*INCH, h=8, tpi=8, $slop=0.05);
|
||||||
// acme_threaded_nut(od=16, id=1/2*INCH, h=10, tpi=12, starts=3, $slop=0.1, $fa=1, $fs=1);
|
// acme_threaded_nut(nutwidth=16, id=1/2*INCH, h=10, tpi=12, starts=3, $slop=0.1, $fa=1, $fs=1);
|
||||||
function acme_threaded_nut(
|
function acme_threaded_nut(
|
||||||
od, id, h, tpi, pitch,
|
nutwidth, id, h, tpi, pitch,
|
||||||
starts=1,
|
starts=1,
|
||||||
left_handed=false,shape,
|
left_handed=false,shape,
|
||||||
bevel,bevel1,bevel2,
|
bevel,bevel1,bevel2,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
) = no_function("acme_threaded_nut");
|
) = no_function("acme_threaded_nut");
|
||||||
module acme_threaded_nut(
|
module acme_threaded_nut(
|
||||||
od, id, h, tpi, pitch,
|
nutwidth, id, h, tpi, pitch,
|
||||||
starts=1,
|
starts=1,
|
||||||
left_handed=false,shape="hex",
|
left_handed=false,shape="hex",
|
||||||
bevel,bevel1,bevel2,
|
bevel,bevel1,bevel2,
|
||||||
|
@ -506,7 +506,7 @@ module acme_threaded_nut(
|
||||||
pitch = is_undef(pitch) ? INCH/tpi : pitch;
|
pitch = is_undef(pitch) ? INCH/tpi : pitch;
|
||||||
dummy2=assert(is_num(pitch) && pitch>0);
|
dummy2=assert(is_num(pitch) && pitch>0);
|
||||||
trapezoidal_threaded_nut(
|
trapezoidal_threaded_nut(
|
||||||
od=od, id=id, h=h, pitch=pitch,
|
nutwidth=nutwidth, id=id, h=h, pitch=pitch,
|
||||||
thread_depth = pitch/2,
|
thread_depth = pitch/2,
|
||||||
thread_angle=29,shape=shape,
|
thread_angle=29,shape=shape,
|
||||||
left_handed=left_handed,
|
left_handed=left_handed,
|
||||||
|
@ -725,11 +725,11 @@ module buttress_threaded_rod(
|
||||||
|
|
||||||
// Module: buttress_threaded_nut()
|
// Module: buttress_threaded_nut()
|
||||||
// Usage:
|
// Usage:
|
||||||
// buttress_threaded_nut(od, id, h, pitch, ...) [ATTACHMENTS];
|
// buttress_threaded_nut(nutwidth, id, h, pitch, ...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a hex nut for a simple buttress threaded screw rod.
|
// Constructs a hexagonal or square nut for a simple buttress threaded screw rod.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// od = diameter of the nut.
|
// nutwidth = diameter of the nut.
|
||||||
// id = diameter of threaded rod to screw onto.
|
// id = diameter of threaded rod to screw onto.
|
||||||
// h = height/thickness of nut.
|
// h = height/thickness of nut.
|
||||||
// pitch = Thread spacing.
|
// pitch = Thread spacing.
|
||||||
|
@ -745,15 +745,15 @@ module buttress_threaded_rod(
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
||||||
// Examples(Med):
|
// Examples(Med):
|
||||||
// buttress_threaded_nut(od=16, id=8, h=8, pitch=1.25, left_handed=true, $slop=0.05, $fa=1, $fs=1);
|
// buttress_threaded_nut(nutwidth=16, id=8, h=8, pitch=1.25, left_handed=true, $slop=0.05, $fa=1, $fs=1);
|
||||||
function buttress_threaded_nut(
|
function buttress_threaded_nut(
|
||||||
od=16, id=10, h=10,
|
nutwidth=16, id=10, h=10,
|
||||||
pitch=2, shape, left_handed=false,
|
pitch=2, shape, left_handed=false,
|
||||||
bevel,bevel1,bevel2,starts,
|
bevel,bevel1,bevel2,starts,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
) = no_function("buttress_threaded_nut");
|
) = no_function("buttress_threaded_nut");
|
||||||
module buttress_threaded_nut(
|
module buttress_threaded_nut(
|
||||||
od=16, id=10, h=10,
|
nutwidth=16, id=10, h=10,
|
||||||
pitch=2, shape="hex", left_handed=false,
|
pitch=2, shape="hex", left_handed=false,
|
||||||
bevel,bevel1,bevel2,starts=1,
|
bevel,bevel1,bevel2,starts=1,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
|
@ -767,7 +767,7 @@ module buttress_threaded_nut(
|
||||||
[ 1/ 2, -0.77],
|
[ 1/ 2, -0.77],
|
||||||
];
|
];
|
||||||
generic_threaded_nut(
|
generic_threaded_nut(
|
||||||
od=od, id=id, h=h,
|
nutwidth=nutwidth, id=id, h=h,
|
||||||
pitch=pitch,
|
pitch=pitch,
|
||||||
profile=profile,
|
profile=profile,
|
||||||
shape=shape,
|
shape=shape,
|
||||||
|
@ -855,15 +855,16 @@ module square_threaded_rod(
|
||||||
|
|
||||||
// Module: square_threaded_nut()
|
// Module: square_threaded_nut()
|
||||||
// Usage:
|
// Usage:
|
||||||
// square_threaded_nut(od, id, h, pitch, ...) [ATTACHMENTS];
|
// square_threaded_nut(nutwidth, id, h, pitch, ...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a hex nut for a square profile threaded screw rod.
|
// Constructs a hexagonal or square nut for a square profile threaded screw rod.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// od = diameter of the nut.
|
// nutwidth = diameter of the nut.
|
||||||
// id = diameter of threaded rod to screw onto.
|
// id = diameter of threaded rod to screw onto.
|
||||||
// h = height/thickness of nut.
|
// h = height/thickness of nut.
|
||||||
// pitch = Length between threads.
|
// pitch = Length between threads.
|
||||||
// ---
|
// ---
|
||||||
|
// shape = specifies shape of nut, either "hex" or "square". Default: "hex"
|
||||||
// left_handed = if true, create left-handed threads. Default = false
|
// left_handed = if true, create left-handed threads. Default = false
|
||||||
// starts = The number of lead starts. Default = 1
|
// starts = The number of lead starts. Default = 1
|
||||||
// bevel = if true, bevel the thread ends. Default: false
|
// bevel = if true, bevel the thread ends. Default: false
|
||||||
|
@ -874,17 +875,18 @@ module square_threaded_rod(
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
||||||
// Examples(Med):
|
// Examples(Med):
|
||||||
// square_threaded_nut(od=16, id=10, h=10, pitch=2, starts=2, $slop=0.1, $fn=32);
|
// square_threaded_nut(nutwidth=16, id=10, h=10, pitch=2, starts=2, $slop=0.1, $fn=32);
|
||||||
function square_threaded_nut(
|
function square_threaded_nut(
|
||||||
od, id, h,
|
nutwidth, id, h,
|
||||||
pitch,
|
pitch,
|
||||||
|
shape=shape,
|
||||||
left_handed=false,
|
left_handed=false,
|
||||||
bevel,bevel1,bevel2,
|
bevel,bevel1,bevel2,
|
||||||
starts=1,
|
starts=1,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
) = no_function("square_threaded_nut");
|
) = no_function("square_threaded_nut");
|
||||||
module square_threaded_nut(
|
module square_threaded_nut(
|
||||||
od, id, h,
|
nutwidth, id, h,
|
||||||
pitch,
|
pitch,
|
||||||
left_handed=false,
|
left_handed=false,
|
||||||
bevel,bevel1,bevel2,
|
bevel,bevel1,bevel2,
|
||||||
|
@ -893,7 +895,7 @@ module square_threaded_nut(
|
||||||
) {
|
) {
|
||||||
assert(is_num(pitch) && pitch>0)
|
assert(is_num(pitch) && pitch>0)
|
||||||
trapezoidal_threaded_nut(
|
trapezoidal_threaded_nut(
|
||||||
od=od, id=id, h=h, pitch=pitch,
|
nutwidth=nutwidth, id=id, h=h, pitch=pitch,
|
||||||
thread_angle=0,
|
thread_angle=0,
|
||||||
left_handed=left_handed,
|
left_handed=left_handed,
|
||||||
bevel=bevel,bevel1=bevel1,bevel2=bevel2,
|
bevel=bevel,bevel1=bevel1,bevel2=bevel2,
|
||||||
|
@ -1213,17 +1215,18 @@ module generic_threaded_rod(
|
||||||
|
|
||||||
// Module: generic_threaded_nut()
|
// Module: generic_threaded_nut()
|
||||||
// Usage:
|
// Usage:
|
||||||
// generic_threaded_nut(od, id, h, pitch, profile, [$slop], ...) [ATTACHMENTS];
|
// generic_threaded_nut(nutwidth, id, h, pitch, profile, [$slop], ...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a hexagonal or square nut for an generic threaded rod using a user-supplied thread profile.
|
// Constructs a hexagonal or square nut for an generic threaded rod using a user-supplied thread profile.
|
||||||
// See generic_threaded_rod for details on the profile specification.
|
// See generic_threaded_rod for details on the profile specification.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// od = diameter of the nut.
|
// nutwidth = outer dimension of nut from flat to flat.
|
||||||
// id = diameter of threaded rod to screw onto.
|
// id = diameter of threaded rod to screw onto.
|
||||||
// h = height/thickness of nut.
|
// h = height/thickness of nut.
|
||||||
// pitch = Thread spacing.
|
// pitch = Thread spacing.
|
||||||
// profile = Thread profile.
|
// profile = Thread profile.
|
||||||
// ---
|
// ---
|
||||||
|
// shape = specifies shape of nut, either "hex" or "square". Default: "hex"
|
||||||
// left_handed = if true, create left-handed threads. Default = false
|
// left_handed = if true, create left-handed threads. Default = false
|
||||||
// starts = The number of lead starts. Default = 1
|
// starts = The number of lead starts. Default = 1
|
||||||
// bevel = if true, bevel the thread ends. Default: false
|
// bevel = if true, bevel the thread ends. Default: false
|
||||||
|
@ -1236,7 +1239,7 @@ module generic_threaded_rod(
|
||||||
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
// $slop = The printer-specific slop value, which adds clearance (`4*$slop`) to internal threads.
|
||||||
function generic_threaded_nut(
|
function generic_threaded_nut(
|
||||||
od,
|
nutwidth,
|
||||||
id,
|
id,
|
||||||
h,
|
h,
|
||||||
pitch,
|
pitch,
|
||||||
|
@ -1244,12 +1247,12 @@ function generic_threaded_nut(
|
||||||
shape,
|
shape,
|
||||||
left_handed=false,
|
left_handed=false,
|
||||||
starts=1,
|
starts=1,
|
||||||
bevel,bevel1,bevel2,bevang=30,
|
bevel,bevel1,bevel2,bevang=15,
|
||||||
id1,id2,
|
id1,id2,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
) = no_function("generic_threaded_nut");
|
) = no_function("generic_threaded_nut");
|
||||||
module generic_threaded_nut(
|
module generic_threaded_nut(
|
||||||
od,
|
nutwidth,
|
||||||
id,
|
id,
|
||||||
h,
|
h,
|
||||||
pitch,
|
pitch,
|
||||||
|
@ -1257,7 +1260,7 @@ module generic_threaded_nut(
|
||||||
shape="hex",
|
shape="hex",
|
||||||
left_handed=false,
|
left_handed=false,
|
||||||
starts=1,
|
starts=1,
|
||||||
bevel,bevel1,bevel2,
|
bevel,bevel1,bevel2,bevang=15,
|
||||||
id1,id2,
|
id1,id2,
|
||||||
anchor, spin, orient
|
anchor, spin, orient
|
||||||
) {
|
) {
|
||||||
|
@ -1273,12 +1276,18 @@ module generic_threaded_nut(
|
||||||
bevel2 = first_defined([bevel2,bevel,false]);
|
bevel2 = first_defined([bevel2,bevel,false]);
|
||||||
dummy1 = assert(is_num(pitch) && pitch>0);
|
dummy1 = assert(is_num(pitch) && pitch>0);
|
||||||
depth = -pitch*min(column(profile,1));
|
depth = -pitch*min(column(profile,1));
|
||||||
attachable(anchor,spin,orient, size=[od/cos(30),od,h]) {
|
bevel_d=.975;
|
||||||
|
vnf = linear_sweep(hexagon(id=nutwidth), height=h, center=true);
|
||||||
|
attachable(anchor,spin,orient, size=shape=="square" ? [nutwidth,nutwidth,h] : undef, vnf=shape=="hex" ? vnf : undef) {
|
||||||
difference() {
|
difference() {
|
||||||
if (shape=="hex")
|
intersection(){
|
||||||
cyl(d=od/cos(30), h=h, center=true, $fn=6,chamfer1=bevel1?depth:undef,chamfer2=bevel2?depth:undef);
|
if (shape=="hex")
|
||||||
else
|
vnf_polyhedron(vnf);
|
||||||
cuboid([od,od,h]);
|
else
|
||||||
|
cuboid([nutwidth,nutwidth,h]);
|
||||||
|
if (bevel2) cyl(h=h+.01, d2=nutwidth*bevel_d,d1=nutwidth*bevel_d+h/tan(bevang), $fn=64);
|
||||||
|
if (bevel1) down(.01) cyl(h=h+.01, d1=nutwidth*bevel_d,d2=nutwidth*bevel_d+h/tan(bevang), $fn=64);
|
||||||
|
}
|
||||||
generic_threaded_rod(
|
generic_threaded_rod(
|
||||||
d1=full_id1,d2=full_id2,
|
d1=full_id1,d2=full_id2,
|
||||||
l=h+extra,
|
l=h+extra,
|
||||||
|
|
Loading…
Reference in a new issue