mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
Merge pull request #1414 from adrianVmariano/master
bottlecap fix & doc tweaks
This commit is contained in:
commit
fddfd13f2c
4 changed files with 39 additions and 32 deletions
|
@ -1448,7 +1448,7 @@ function bezier_patch_normals(patch, u, v) =
|
||||||
|
|
||||||
|
|
||||||
// Module: debug_bezier()
|
// Module: debug_bezier()
|
||||||
// Synopsis: Shows a bezier path and it's associated control points.
|
// Synopsis: Shows a bezier path and its associated control points.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Bezier Paths, Debugging
|
// Topics: Bezier Paths, Debugging
|
||||||
// See Also: bezpath_curve()
|
// See Also: bezpath_curve()
|
||||||
|
@ -1518,7 +1518,7 @@ module debug_bezier(bezpath, width=1, N=3) {
|
||||||
// showcps = If true, show the controlpoints as well as the surface. Default: true.
|
// showcps = If true, show the controlpoints as well as the surface. Default: true.
|
||||||
// showdots = If true, shows the calculated surface vertices. Default: false.
|
// showdots = If true, shows the calculated surface vertices. Default: false.
|
||||||
// showpatch = If true, shows the surface faces. Default: true.
|
// showpatch = If true, shows the surface faces. Default: true.
|
||||||
// size = Size to show control points and lines.
|
// size = Size to show control points and lines. Default: 1% of the maximum side length of a box bounding the patch.
|
||||||
// style = The style of subdividing the quads into faces. Valid options are "default", "alt", and "quincunx".
|
// style = The style of subdividing the quads into faces. Valid options are "default", "alt", and "quincunx".
|
||||||
// convexity = Max number of times a line could intersect a wall of the shape.
|
// convexity = Max number of times a line could intersect a wall of the shape.
|
||||||
// Example:
|
// Example:
|
||||||
|
|
|
@ -544,37 +544,40 @@ function generic_bottle_neck(
|
||||||
// Synopsis: Creates a generic cap for a bottle.
|
// Synopsis: Creates a generic cap for a bottle.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Bottles, Threading
|
// Topics: Bottles, Threading
|
||||||
// See Also: generic_bottle_neck()
|
// See Also: generic_bottle_neck(), sp_cap()
|
||||||
// Usage:
|
// Usage:
|
||||||
// generic_bottle_cap(wall, [texture], ...) [ATTACHMENTS];
|
// generic_bottle_cap(wall, [texture], ...) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a basic threaded cap given specifications.
|
// Creates a basic threaded cap given specifications. You must give exactly two of `thread_od`, `neck_od` and `thread_depth` to
|
||||||
|
// specify the thread geometry. Note that most glass bottles conform to the SPI standard and caps for them may be more easily produced using {{sp_cap()}}.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// wall = Wall thickness in mm.
|
// wall = Wall thickness. Default: 2
|
||||||
// texture = The surface texture of the cap. Valid values are "none", "knurled", or "ribbed". Default: "none"
|
// texture = The surface texture of the cap. Valid values are "none", "knurled", or "ribbed". Default: "none"
|
||||||
// ---
|
// ---
|
||||||
// height = Interior height of the cap in mm.
|
// height = Interior height of the cap
|
||||||
// thread_od = Outer diameter of the threads in mm.
|
// thread_od = Outer diameter of the threads
|
||||||
// tolerance = Extra space to add to the outer diameter of threads and neck in mm. Applied to radius.
|
// neck_od = Outer diameter of neck
|
||||||
// neck_od = Outer diameter of neck in mm.
|
// thread_depth = Depth of the threads
|
||||||
// flank_angle = Angle of taper on threads.
|
// tolerance = Extra space to add to the outer diameter of threads and neck. Applied to radius. Default: 0.2
|
||||||
// pitch = Thread pitch in mm.
|
// flank_angle = Angle of taper on threads. Default: 15
|
||||||
|
// pitch = Thread pitch. Default: 4
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#subsection-anchor). Default: `CENTER`
|
// 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`
|
// 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`
|
// orient = Vector to rotate top towards, after spin. See [orient](attachments.scad#subsection-orient). Default: `UP`
|
||||||
// Extra Anchors:
|
// Extra Anchors:
|
||||||
// "inside-top" = Centered on the inside top of the cap.
|
// "inside-top" = Centered on the inside top of the cap.
|
||||||
// Examples:
|
// Examples:
|
||||||
// generic_bottle_cap();
|
// generic_bottle_cap(thread_depth=2,neck_od=INCH,height=INCH/2);
|
||||||
// generic_bottle_cap(texture="knurled");
|
// generic_bottle_cap(texture="knurled",neck_od=25,thread_od=30,height=10);
|
||||||
// generic_bottle_cap(texture="ribbed");
|
// generic_bottle_cap(texture="ribbed",thread_depth=3,thread_od=25,height=13);
|
||||||
module generic_bottle_cap(
|
module generic_bottle_cap(
|
||||||
wall = 2,
|
wall = 2,
|
||||||
texture = "none",
|
texture = "none",
|
||||||
height = 11.2,
|
height,
|
||||||
thread_depth = 2.34,
|
thread_depth,
|
||||||
|
thread_od,
|
||||||
tolerance = .2,
|
tolerance = .2,
|
||||||
neck_od = 25.5,
|
neck_od,
|
||||||
flank_angle = 15,
|
flank_angle = 15,
|
||||||
pitch = 4,
|
pitch = 4,
|
||||||
anchor = BOTTOM,
|
anchor = BOTTOM,
|
||||||
|
@ -582,8 +585,14 @@ module generic_bottle_cap(
|
||||||
orient = UP
|
orient = UP
|
||||||
) {
|
) {
|
||||||
$fn = segs(33 / 2);
|
$fn = segs(33 / 2);
|
||||||
threadOuterDTol = neck_od + 2*(thread_depth - 0.8) + 2 * tolerance; // WTF; Engineered for consistency with old code, but
|
dummy = assert(num_defined([thread_od,neck_od,thread_depth])==2, "Must define exactly two of thread_od, neck_od and thread_depth")
|
||||||
w = threadOuterDTol + 2 * wall; // no clue why this was chosen
|
assert(is_def(thread_depth) || (all_positive([neck_od,thread_od]) && thread_od>neck_od), "thread_od must be larger than neck_od")
|
||||||
|
assert(is_undef(thread_depth) || all_positive([thread_depth,first_defined([neck_od,thread_od])]), "thread_depth, and neck_od/thread_od must be positive");
|
||||||
|
thread_depth = !is_undef(thread_depth) ? thread_depth : (thread_od - neck_od)/2;
|
||||||
|
neck_od = !is_undef(neck_od) ? neck_od : thread_od-2*thread_depth;
|
||||||
|
thread_od = !is_undef(thread_od) ? thread_od : neck_od+2*thread_depth;
|
||||||
|
threadOuterDTol = thread_od + 2*tolerance;
|
||||||
|
w = threadOuterDTol + 2 * wall;
|
||||||
h = height + wall;
|
h = height + wall;
|
||||||
neckOuterDTol = neck_od + 2 * tolerance;
|
neckOuterDTol = neck_od + 2 * tolerance;
|
||||||
|
|
||||||
|
@ -600,21 +609,18 @@ module generic_bottle_cap(
|
||||||
// For the knurled and ribbed caps the PCO caps in BOSL2 cut into the wall
|
// For the knurled and ribbed caps the PCO caps in BOSL2 cut into the wall
|
||||||
// thickness so the wall+texture are the specified wall thickness. That
|
// thickness so the wall+texture are the specified wall thickness. That
|
||||||
// seems wrong so this does specified thickness+texture
|
// seems wrong so this does specified thickness+texture
|
||||||
if (texture == "knurled") {
|
if (texture == "knurled")
|
||||||
cyl(d=w + 1.5*diamMagMult, l=h, texture="diamonds", tex_size=[3,3], tex_style="concave", anchor=BOT);
|
cyl(d=w + 1.5*diamMagMult, l=h, texture="diamonds", tex_size=[3,3], tex_style="concave", anchor=BOT);
|
||||||
} else if (texture == "ribbed") {
|
else if (texture == "ribbed")
|
||||||
cyl(d=w + 1.5*diamMagMult, l=h, texture="ribs", tex_size=[3,3], tex_style="min_edge", anchor=BOT);
|
cyl(d=w + 1.5*diamMagMult, l=h, texture="ribs", tex_size=[3,3], tex_style="min_edge", anchor=BOT);
|
||||||
} else {
|
else
|
||||||
cyl(d = w, l = h, anchor = BOTTOM);
|
cyl(d = w, l = h, anchor = BOTTOM);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
up(wall) cyl(d = threadOuterDTol, h = h, anchor = BOTTOM);
|
up(wall) cyl(d = threadOuterDTol, h = h, anchor = BOTTOM);
|
||||||
}
|
}
|
||||||
difference(){
|
up(wall + pitch / 2) {
|
||||||
up(wall + pitch / 2) {
|
thread_helix(d = neckOuterDTol+.02, pitch = pitch, thread_depth = thread_depth+.01, flank_angle = flank_angle,
|
||||||
thread_helix(d = neckOuterDTol, pitch = pitch, thread_depth = thread_depth, flank_angle = flank_angle,
|
turns = ((height - pitch) / pitch), lead_in = -thread_depth, internal = true, anchor = BOTTOM);
|
||||||
turns = ((height - pitch) / pitch), lead_in = -thread_depth, internal = true, anchor = BOTTOM);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
children();
|
children();
|
||||||
|
|
|
@ -46,6 +46,7 @@ function _inset_corner(corner, mask_angle, inset, excess, flat_top) =
|
||||||
// .
|
// .
|
||||||
// The roundover can be specified by radius, diameter, height, cut, or joint length.
|
// The roundover can be specified by radius, diameter, height, cut, or joint length.
|
||||||
// ![Types of Roundovers](images/rounding/section-types-of-roundovers_fig1.png)
|
// ![Types of Roundovers](images/rounding/section-types-of-roundovers_fig1.png)
|
||||||
|
// .
|
||||||
// If you need roundings to agree on edges of different mask_angle, e.g. to round the base of a prismoid, then you need all of the
|
// If you need roundings to agree on edges of different mask_angle, e.g. to round the base of a prismoid, then you need all of the
|
||||||
// masks used to have the same height. (Note that it may appear that matching joint would also work, but it does not because the joint distances are measured
|
// masks used to have the same height. (Note that it may appear that matching joint would also work, but it does not because the joint distances are measured
|
||||||
// in different directions.) You can get the same height by setting the `height` parameter, which is an alternate way to control the size of the rounding.
|
// in different directions.) You can get the same height by setting the `height` parameter, which is an alternate way to control the size of the rounding.
|
||||||
|
|
|
@ -2806,7 +2806,7 @@ function associate_vertices(polygons, split, curpoly=0) =
|
||||||
// are based on rectangular tiling, this means adding textures to curved shapes may result in distortion of the basic texture unit. For example, if you
|
// are based on rectangular tiling, this means adding textures to curved shapes may result in distortion of the basic texture unit. For example, if you
|
||||||
// texture a cone, the scale of the texture will be larger at the wide end of the cone and smaller at the narrower end of the cone.
|
// texture a cone, the scale of the texture will be larger at the wide end of the cone and smaller at the narrower end of the cone.
|
||||||
// .
|
// .
|
||||||
// You can specify a texture using to method: a height field or a VNF. For each method you also must specify the scale of the texture, which
|
// You can specify a texture using two methods: a height field or a VNF. For each method you also must specify the scale of the texture, which
|
||||||
// gives the size of the rectangular unit in your object that will correspond to one texture tile. Note that this scale does not preserve
|
// gives the size of the rectangular unit in your object that will correspond to one texture tile. Note that this scale does not preserve
|
||||||
// aspect ratio: you can stretch the texture as desired.
|
// aspect ratio: you can stretch the texture as desired.
|
||||||
// Subsection: Height Field Texture Maps
|
// Subsection: Height Field Texture Maps
|
||||||
|
@ -2959,10 +2959,10 @@ function associate_vertices(polygons, split, curpoly=0) =
|
||||||
// extra points can be introduced in the interior of faces leading to unexpected irregularities in the textures, which appear
|
// extra points can be introduced in the interior of faces leading to unexpected irregularities in the textures, which appear
|
||||||
// as extra triangles. These artifacts can be minimized by making the VNF texture's faces as large as possible rather than using
|
// as extra triangles. These artifacts can be minimized by making the VNF texture's faces as large as possible rather than using
|
||||||
// a triangulated VNF, but depending on the specific VNF texture, it may be impossible to entirely eliminate them.
|
// a triangulated VNF, but depending on the specific VNF texture, it may be impossible to entirely eliminate them.
|
||||||
// Figure(3D,Big,NoAxes,VPR=[140.9,0,345.7],VPT=[9.48289,-0.88709,5.7837],VPD=39.5401): The left shows a normal bricks_vnf texture. The right shows a texture that was first passed through {{vnf_triangulate()}}. Note the extra triangle artifacts visible across the brick faces.
|
// Figure(3D,Big,NoAxes,VPR=[140.9,0,345.7],VPT=[9.48289,-0.88709,5.7837],VPD=39.5401): The left shows a normal bricks_vnf texture. The right shows a texture that was first passed through {{vnf_triangulate()}}. Note the extra triangle artifacts visible at the ends on the brick faces.
|
||||||
// tex = texture("bricks_vnf");
|
// tex = texture("bricks_vnf");
|
||||||
// cyl(d=10,h=15,texture=tex, tex_reps=[4,2],tex_samples=5);
|
// cyl(d=10,h=15,texture=tex, tex_reps=[4,2],tex_samples=5,rounding=2);
|
||||||
// up(7)fwd(-3)right(15)cyl(d=10,h=15,texture=vnf_triangulate(tex), tex_reps=[4,2],tex_samples=5);
|
// up(7)fwd(-3)right(15)cyl(d=10,h=15,texture=vnf_triangulate(tex), tex_reps=[4,2],tex_samples=5,rounding=2);
|
||||||
|
|
||||||
|
|
||||||
// Function: texture()
|
// Function: texture()
|
||||||
|
|
Loading…
Reference in a new issue