mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
add sp400 etc caps
This commit is contained in:
parent
d003a96d23
commit
48292d9e8f
2 changed files with 124 additions and 53 deletions
|
@ -978,6 +978,11 @@ function bottle_adapter_neck_to_neck(
|
||||||
|
|
||||||
// Thread specs from https://www.isbt.com/threadspecs-downloads.asp
|
// Thread specs from https://www.isbt.com/threadspecs-downloads.asp
|
||||||
|
|
||||||
|
// T = peak to peak diameter (outer diameter)
|
||||||
|
// I = Inner diameter
|
||||||
|
// S = space above top thread
|
||||||
|
// H = total height of neck
|
||||||
|
|
||||||
_sp_specs = [
|
_sp_specs = [
|
||||||
[400, //diam T I H S tpi
|
[400, //diam T I H S tpi
|
||||||
[[ 18, [ 17.68, 8.26, 9.42, 0.94, 8]],
|
[[ 18, [ 17.68, 8.26, 9.42, 0.94, 8]],
|
||||||
|
@ -1042,7 +1047,7 @@ _sp_thread_width= [
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
function _sp_thread_profile(tpi, a, S, style) =
|
function _sp_thread_profile(tpi, a, S, style, flip=false) =
|
||||||
let(
|
let(
|
||||||
pitch = 1/tpi*INCH,
|
pitch = 1/tpi*INCH,
|
||||||
cL = a*(1-1/sqrt(3)),
|
cL = a*(1-1/sqrt(3)),
|
||||||
|
@ -1052,7 +1057,7 @@ function _sp_thread_profile(tpi, a, S, style) =
|
||||||
: style=="M" && tpi < 12 ? [0.25, 0.25, 0.75, 0.75]
|
: style=="M" && tpi < 12 ? [0.25, 0.25, 0.75, 0.75]
|
||||||
: style=="L" ? [0.38, 0.13, 0.13, 0.38]
|
: style=="L" ? [0.38, 0.13, 0.13, 0.38]
|
||||||
: /* style=="M" */ [0.25, 0.25, 0.2, 0.5],
|
: /* style=="M" */ [0.25, 0.25, 0.2, 0.5],
|
||||||
path = style=="L"
|
path1 = style=="L"
|
||||||
? round_corners([[-1/2*pitch,-a/2],
|
? round_corners([[-1/2*pitch,-a/2],
|
||||||
[-a/2,-a/2],
|
[-a/2,-a/2],
|
||||||
[-cL/2,0],
|
[-cL/2,0],
|
||||||
|
@ -1065,10 +1070,11 @@ function _sp_thread_profile(tpi, a, S, style) =
|
||||||
[-cM, 0],
|
[-cM, 0],
|
||||||
[0,0],
|
[0,0],
|
||||||
[a/2,-a/2],
|
[a/2,-a/2],
|
||||||
[1/2*pitch,-a/2]], radius=roundings, closed=false, $fn=24)
|
[1/2*pitch,-a/2]], radius=roundings, closed=false, $fn=24),
|
||||||
|
path2 = flip ? reverse(xflip(path1)) : path1
|
||||||
)
|
)
|
||||||
// Shift so that the profile is S mm from the right end to create proper length S top gap
|
// Shift so that the profile is S mm from the right end to create proper length S top gap
|
||||||
select(right(-a/2+1/2-S,p=path),1,-2)/pitch;
|
select(right(-a/2+1/2-S,p=path2),1,-2)/pitch;
|
||||||
|
|
||||||
|
|
||||||
function sp_neck(diam,type,wall,id,style="L",bead=false, anchor, spin, orient) = no_function("sp_neck");
|
function sp_neck(diam,type,wall,id,style="L",bead=false, anchor, spin, orient) = no_function("sp_neck");
|
||||||
|
@ -1135,6 +1141,88 @@ module sp_neck(diam,type,wall,id,style="L",bead=false, anchor, spin, orient)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Module: sp_cap()
|
||||||
|
// Usage:
|
||||||
|
// sp_neck(cap, type, wall, [style=], [top_adj=]) [ATTACHMENTS];
|
||||||
|
// Description:
|
||||||
|
// Make a SPI (Society of Plastics Industry) threaded bottle neck. You must
|
||||||
|
// supply the nominal outer diameter of the threads and the thread type, one of
|
||||||
|
// 400, 410 and 415. The 400 type neck has 360 degrees of thread, the 410
|
||||||
|
// neck has 540 degrees of thread, and the 415 neck has 720 degrees of thread.
|
||||||
|
// You can also choose between the L style thread, which is symmetric and
|
||||||
|
// the M style thread, which is an asymmetric buttress thread. Note that it
|
||||||
|
// is OK to mix styles, so you can put an L-style cap onto an M-style neck.
|
||||||
|
// .
|
||||||
|
// These caps often contain a cardboard or foam sealer disk, which can be as much as 1mm thick.
|
||||||
|
// If you don't include this, your cap may bottom out on the bead on the neck instead of sealing
|
||||||
|
// against the top. If you set top_adj to 1 it will make the top space 1mm smaller so that the
|
||||||
|
// cap will not bottom out. The 410 and 415 caps have very long unthreaded sections at the bottom.
|
||||||
|
// The bot_adj parameter specifies am amount to reduce that bottom extension. Be careful that
|
||||||
|
// you don't shrink past the threads.
|
||||||
|
// .
|
||||||
|
// Note: there is a published SPI standard for necks, but absolutely nothing for caps. This
|
||||||
|
// cap module was designed based on the neck standard to mate reasonably well, but if you
|
||||||
|
// find ways that it does the wrong thing, file a report.
|
||||||
|
// Arguments:
|
||||||
|
// diam = nominal outer diameter of threads
|
||||||
|
// type = thread type, one of 400, 410 and 415
|
||||||
|
// wall = wall thickness
|
||||||
|
// ---
|
||||||
|
// style = Either "L" or "M" to specify the thread style. Default: "L"
|
||||||
|
// top_adj = Amount to reduce top space in the cap, which means it doesn't screw down as far. Default: 0
|
||||||
|
// bot_adj = Amount to reduce extension of cap at the bottom, which also means it doesn't screw down as far. Default: 0
|
||||||
|
// 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`
|
||||||
|
// Examples:
|
||||||
|
// sp_cap(48,400,2);
|
||||||
|
// sp_cap(22,410,2);
|
||||||
|
// sp_cap(28,415,1.5,style="M");
|
||||||
|
module sp_cap(diam,type,wall,style="L",top_adj=0, bot_adj=0, anchor, spin, orient)
|
||||||
|
{
|
||||||
|
table = struct_val(_sp_specs,type);
|
||||||
|
dum1=assert(is_def(table),"Unknown SP closure type. Type must be one of 400, 410, or 415");
|
||||||
|
entry = struct_val(table, diam);
|
||||||
|
dum2=assert(is_def(entry), str("Unknown closure nominal diameter. Allowed diameters for SP",type,": ",struct_keys(table)))
|
||||||
|
assert(style=="L" || style=="M", "style must be \"L\" or \"M\"");
|
||||||
|
|
||||||
|
T = entry[0];
|
||||||
|
I = entry[1];
|
||||||
|
H = entry[2]-1;
|
||||||
|
S = entry[3];
|
||||||
|
tpi = entry[4];
|
||||||
|
a = (style=="M" && tpi==12) ? 1.3 : struct_val(_sp_thread_width,tpi);
|
||||||
|
|
||||||
|
twist = struct_val(_sp_twist, type);
|
||||||
|
|
||||||
|
dum3=assert(top_adj<S+0.75*a, str("The top_adj value is too large so the thread won't fit. It must be smaller than ",S+0.75*a));
|
||||||
|
oprofile = _sp_thread_profile(tpi,a,S+0.75*a-top_adj,style,flip=true);
|
||||||
|
bounds=pointlist_bounds(oprofile);
|
||||||
|
profile = fwd(-bounds[0].y,yflip(oprofile));
|
||||||
|
|
||||||
|
depth = a/2;
|
||||||
|
higlen = 2*a;
|
||||||
|
higang = higlen / ((T-2*depth)*PI) * 360;
|
||||||
|
|
||||||
|
echo(a=a,depth=depth,halfdepth=depth/2, tpi*pointlist_bounds(profile));
|
||||||
|
|
||||||
|
space=2*depth/10+4*get_slop();
|
||||||
|
attachable(anchor,spin,orient,r= (T+space)/2+wall, l=H-bot_adj+wall){
|
||||||
|
xrot(180)
|
||||||
|
up((H-bot_adj)/2-wall/2){
|
||||||
|
difference(){
|
||||||
|
up(wall)cyl(d=T+space+2*wall,l=H+wall-bot_adj,anchor=TOP,chamfer2=.8);
|
||||||
|
cyl(d=T+space, l=H-bot_adj+1, anchor=TOP);
|
||||||
|
}
|
||||||
|
thread_helix(d=T+space-.01, profile=profile, pitch = INCH/tpi, turns=(twist+2*higang)/360, higbee=higlen, anchor=TOP, internal=true);
|
||||||
|
}
|
||||||
|
children();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Function: sp_diameter()
|
// Function: sp_diameter()
|
||||||
// Usage:
|
// Usage:
|
||||||
// true_diam = sp_diameter(diam,type)
|
// true_diam = sp_diameter(diam,type)
|
||||||
|
|
79
screws.scad
79
screws.scad
|
@ -1663,7 +1663,7 @@ module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orie
|
||||||
|
|
||||||
// Function: screw_info()
|
// Function: screw_info()
|
||||||
// Usage:
|
// Usage:
|
||||||
// info = screw_info(spec, [head], [drive], [thread=], [drive_size=], [oversize=], [head_oversize=])
|
// info = screw_info(name, [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 and nut parameters](#section-screw-and-nut-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.
|
||||||
|
@ -1715,7 +1715,7 @@ module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orie
|
||||||
// If you want to define a custom drive for a screw you will need to provide the drive size and drive depth.
|
// If you want to define a custom drive for a screw you will need to provide the drive size and drive depth.
|
||||||
//
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// spec = screw specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming).
|
// name = screw specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming).
|
||||||
// head = head type. See [screw heads](#subsection-screw-heads) Default: none
|
// head = head type. See [screw heads](#subsection-screw-heads) Default: none
|
||||||
// drive = drive type. See [screw heads](#subsection-screw-heads) Default: none
|
// drive = drive type. See [screw heads](#subsection-screw-heads) Default: none
|
||||||
// ---
|
// ---
|
||||||
|
@ -1724,14 +1724,14 @@ module nut_trap_inline(length, spec, shape, l, height, h, nutwidth, anchor, orie
|
||||||
// oversize = amount to increase screw diameter for clearance holes. Default: 0
|
// oversize = amount to increase screw diameter for clearance holes. Default: 0
|
||||||
// head_oversize = amount to increase head diameter for countersink holes. Default: 0
|
// head_oversize = amount to increase head diameter for countersink holes. Default: 0
|
||||||
|
|
||||||
function screw_info(spec, head, drive, thread, drive_size, threads_oversize=0, head_oversize=0, _origin) =
|
function screw_info(name, head, drive, thread, drive_size, threads_oversize=0, head_oversize=0, _origin) =
|
||||||
assert(is_string(spec), "Screw specification must be a string")
|
assert(is_string(name), "Screw specification must be a string")
|
||||||
let(
|
let(
|
||||||
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,
|
||||||
head = default(head,"none"),
|
head = default(head,"none"),
|
||||||
type=_parse_screw_name(spec),
|
type=_parse_screw_name(name),
|
||||||
drive_info = _parse_drive(drive, drive_size),
|
drive_info = _parse_drive(drive, drive_size),
|
||||||
drive=drive_info[0],
|
drive=drive_info[0],
|
||||||
screwdata = type[0] == "english" ? _screw_info_english(type[1],type[2], head, thread, drive)
|
screwdata = type[0] == "english" ? _screw_info_english(type[1],type[2], head, thread, drive)
|
||||||
|
@ -1743,7 +1743,7 @@ function screw_info(spec, head, drive, thread, drive_size, threads_oversize=0, h
|
||||||
["drive_depth", drive_info[2]],
|
["drive_depth", drive_info[2]],
|
||||||
["length", type[3]],
|
["length", type[3]],
|
||||||
["drive_size", drive_info[1]],
|
["drive_size", drive_info[1]],
|
||||||
["name", spec],
|
["name", name],
|
||||||
["threads_oversize", threads_oversize],
|
["threads_oversize", threads_oversize],
|
||||||
["head_oversize", head_oversize],
|
["head_oversize", head_oversize],
|
||||||
["origin",_origin]
|
["origin",_origin]
|
||||||
|
@ -1752,7 +1752,7 @@ function screw_info(spec, head, drive, thread, drive_size, threads_oversize=0, h
|
||||||
|
|
||||||
// Function: nut_info()
|
// Function: nut_info()
|
||||||
// Usage:
|
// Usage:
|
||||||
// nut_spec = nut_info(spec, [shape], [thickness=], [thread=], [width=], [hole_oversize=]);
|
// nut_spec = nut_info(name, [shape], [thickness=], [thread=], [width=], [hole_oversize=]);
|
||||||
// Description:
|
// Description:
|
||||||
// Produces a nut specification structure that describes a nut. You can specify the width
|
// Produces a nut specification structure that describes a nut. You can specify the width
|
||||||
// and thickness numerically, or you can let the width be calculated automatically from
|
// and thickness numerically, or you can let the width be calculated automatically from
|
||||||
|
@ -1775,7 +1775,7 @@ function screw_info(spec, head, drive, thread, drive_size, threads_oversize=0, h
|
||||||
// "thickness" | Thickness of the nut
|
// "thickness" | Thickness of the nut
|
||||||
// "threads_oversize" | amount to oversize the threads (not including $slop)
|
// "threads_oversize" | amount to oversize the threads (not including $slop)
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// spec = screw specification, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming).
|
// name = screw name, e.g. "M5x1" or "#8-32". See [screw naming](#subsection-screw-naming).
|
||||||
// shape = shape of the nut, either "hex" or "square". Default: "hex"
|
// shape = shape of the nut, either "hex" or "square". Default: "hex"
|
||||||
// ---
|
// ---
|
||||||
// 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"
|
||||||
|
@ -1783,7 +1783,7 @@ function screw_info(spec, head, drive, thread, drive_size, threads_oversize=0, h
|
||||||
// width = width of nut in mm. Default: computed from thread specification
|
// width = width of nut in mm. Default: computed from thread specification
|
||||||
// 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(name, shape, thickness, thread, hole_oversize=0, width, _origin) =
|
||||||
assert(is_undef(thickness) || (is_num(thickness) && thickness>0) ||
|
assert(is_undef(thickness) || (is_num(thickness) && thickness>0) ||
|
||||||
in_list(_downcase_if_str(thickness),["thin","normal","thick","undersized","din"]),
|
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\"")
|
"thickness must be a positive number of one of \"thin\", \"thick\", \"normal\", \"undersized\", or \"DIN\"")
|
||||||
|
@ -1791,11 +1791,11 @@ function nut_info(spec, shape, thickness, thread, hole_oversize=0, width, _origi
|
||||||
shape = _downcase_if_str(default(shape,"hex")),
|
shape = _downcase_if_str(default(shape,"hex")),
|
||||||
thickness = _downcase_if_str(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(name), str("Nut nameification must be a string ",name))
|
||||||
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\"")
|
||||||
assert(is_undef(width) || (is_num(width) && width>0), "Specified width must be a positive number")
|
assert(is_undef(width) || (is_num(width) && width>0), "Specified width must be a positive number")
|
||||||
let(
|
let(
|
||||||
type = _parse_screw_name(spec),
|
type = _parse_screw_name(name),
|
||||||
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,
|
||||||
|
@ -1803,7 +1803,7 @@ function nut_info(spec, shape, thickness, thread, hole_oversize=0, width, _origi
|
||||||
: type[0]=="metric" ? _nut_info_metric(type[1],type[2], thread, shape, thickness, width)
|
: type[0]=="metric" ? _nut_info_metric(type[1],type[2], thread, shape, thickness, width)
|
||||||
: []
|
: []
|
||||||
)
|
)
|
||||||
_struct_reset(nutdata, [["name", spec],
|
_struct_reset(nutdata, [["name", name],
|
||||||
["threads_oversize",hole_oversize],
|
["threads_oversize",hole_oversize],
|
||||||
["width", width],
|
["width", width],
|
||||||
["origin",_origin]
|
["origin",_origin]
|
||||||
|
@ -2856,11 +2856,7 @@ http://files.engineering.com/getfile.aspx?folder=76fb0d5e-1fff-4c49-87a5-0597947
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
// To do list
|
|
||||||
//
|
//
|
||||||
// Is there no way to create a mask for making threaded holes? This seems to be missing.
|
|
||||||
//
|
|
||||||
// Metric hex engagement:
|
|
||||||
// https://www.bayoucitybolt.com/socket-head-cap-screws-metric.html
|
// https://www.bayoucitybolt.com/socket-head-cap-screws-metric.html
|
||||||
//
|
//
|
||||||
// Torx drive depth for UTS and ISO (at least missing for "flat small", which means you can't select torx for this head type)
|
// Torx drive depth for UTS and ISO (at least missing for "flat small", which means you can't select torx for this head type)
|
||||||
|
@ -2868,9 +2864,6 @@ http://files.engineering.com/getfile.aspx?folder=76fb0d5e-1fff-4c49-87a5-0597947
|
||||||
|
|
||||||
// https://www.fasteners.eu/tech-info/ISO/7721-2/
|
// https://www.fasteners.eu/tech-info/ISO/7721-2/
|
||||||
//
|
//
|
||||||
// How do you insert a threaded hole into a model?
|
|
||||||
// Default nut thickness
|
|
||||||
//
|
|
||||||
// JIS
|
// JIS
|
||||||
//https://www.garagejournal.com/forum/media/jis-b-4633-vs-iso-8764-1-din-5260-ph.84492/
|
//https://www.garagejournal.com/forum/media/jis-b-4633-vs-iso-8764-1-din-5260-ph.84492/
|
||||||
|
|
||||||
|
@ -2882,38 +2875,28 @@ http://files.engineering.com/getfile.aspx?folder=76fb0d5e-1fff-4c49-87a5-0597947
|
||||||
// thread standards:
|
// thread standards:
|
||||||
// https://www.gewinde-normen.de/en/index.html
|
// https://www.gewinde-normen.de/en/index.html
|
||||||
|
|
||||||
///////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////*
|
||||||
//
|
/////////////////////////////////////////////////////////////////////////////////////////*
|
||||||
// how to make screw mask: examples (e.g. for clearance hole w/ countersink)
|
/////////////////////////////////////////////////////////////////////////////////////////*
|
||||||
// how to make a screw hole (a mask function?)
|
///
|
||||||
//
|
/// TODO list:
|
||||||
|
///
|
||||||
|
/// need to make holes at actual size instead of nominal?
|
||||||
|
/// or relative to actual size?
|
||||||
|
/// That means I need to preserve thread= to specify this
|
||||||
|
/// torx depth for UTS pan head
|
||||||
|
/// $fn control
|
||||||
|
/// phillips driver spec with ph# is confusing since it still looks up depth in tables
|
||||||
|
/// and can give an error if it's not found
|
||||||
|
/// torx depths missing for pan head
|
||||||
|
/// support for square drive? (It's in the ASME standard)
|
||||||
|
///
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////*
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////*
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////*
|
||||||
|
|
||||||
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
||||||
|
|
||||||
/*
|
|
||||||
TODO list:
|
|
||||||
|
|
||||||
anchoring for counterbores OK?: counterbore ignored for flatheads
|
|
||||||
counterbore is treated as the head for regular heads
|
|
||||||
for flathead counterbore is ignored. Need an anchor that gives
|
|
||||||
access to counterbore for the flathead case but also the top of the head(?)
|
|
||||||
anchoring for other heads: using bounding cylinder
|
|
||||||
hex head anchoring OK?
|
|
||||||
need to make holes at actual size instead of nominal?
|
|
||||||
or relative to actual size?
|
|
||||||
That means I need to preserve thread= to specify this
|
|
||||||
shoulder screws: generally how to handle these?
|
|
||||||
torx depth for UTS pan head
|
|
||||||
$fn control
|
|
||||||
phillips driver spec with ph# is confusing since it still looks up depth in tables
|
|
||||||
and can give an error if it's not found
|
|
||||||
phillips code just uses depth, not width and slot width; maybe remove excess data?
|
|
||||||
torx depths missing for pan head
|
|
||||||
support for square drive? (It's in the ASME standard)
|
|
||||||
proper support for nuts, nut traps
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue