Added convexity= to skin() and vnf_polyhedron()

This commit is contained in:
Revar Desmera 2020-01-09 20:10:46 -08:00
parent 3fdc58fded
commit 5ccf1e26bd
4 changed files with 67 additions and 56 deletions

View file

@ -512,7 +512,7 @@ module joiner_quad(spacing1=undef, spacing2=undef, xspacing=undef, yspacing=unde
// diff("remove") // diff("remove")
// cuboid([50,30,10]) // cuboid([50,30,10])
// position(TOP+BACK) xspread(10,5) dovetail("female", length=10, width=7, height=4, spin=90,$tags="remove",anchor=BOTTOM+RIGHT); // position(TOP+BACK) xspread(10,5) dovetail("female", length=10, width=7, height=4, spin=90,$tags="remove",anchor=BOTTOM+RIGHT);
module dovetail(gender, length, l, width, w, height, h, angle, slope, taper, width2, chamfer, extra=0.01,orient,spin=0,r,radius,round=false,anchor=BOTTOM) module dovetail(gender, length, l, width, w, height, h, angle, slope, taper, width2, chamfer, extra=0.01, r, radius, round=false, anchor=BOTTOM, spin=0, orient)
{ {
radius = get_radius(r1=radius,r2=r); radius = get_radius(r1=radius,r2=r);
lcount = num_defined([l,length]); lcount = num_defined([l,length]);
@ -520,7 +520,7 @@ module dovetail(gender, length, l, width, w, height, h, angle, slope, taper, wid
wcount = num_defined([w,width]); wcount = num_defined([w,width]);
assert(lcount==1, "Must define exactly one of l and length"); assert(lcount==1, "Must define exactly one of l and length");
assert(wcount==1, "Must define exactly one of w and width"); assert(wcount==1, "Must define exactly one of w and width");
assert(lcount==1, "Must define exactly one of h and height"); assert(hcount==1, "Must define exactly one of h and height");
h = first_defined([h,height]); h = first_defined([h,height]);
w = first_defined([w,width]); w = first_defined([w,width]);
length = first_defined([l,length]); length = first_defined([l,length]);
@ -548,13 +548,17 @@ module dovetail(gender, length, l, width, w, height, h, angle, slope, taper, wid
gender == "male" ? [0,size,0] : [0,0,size]; gender == "male" ? [0,size,0] : [0,0,size];
smallend_half = round_corners( smallend_half = round_corners(
move([-length/2-extra,0,0], move(
p=[[0,0 , height], [-length/2-extra,0,0],
p=[
[0,0 , height],
[0,width/2-front_offset , height], [0,width/2-front_offset , height],
[0,width/2 - height/slope - front_offset, 0 ], [0,width/2 - height/slope - front_offset, 0 ],
[0,width/2 - front_offset + height, 0] [0,width/2 - front_offset + height, 0]
]), ]
curve=type, size = fullsize,closed=false); ),
curve=type, size=fullsize, closed=false
);
smallend_points = concat(select(smallend_half, 1, -2), [down(extra,p=select(smallend_half, -2))]); smallend_points = concat(select(smallend_half, 1, -2), [down(extra,p=select(smallend_half, -2))]);
offset = is_def(taper) ? (length+extra) * tan(taper) : offset = is_def(taper) ? (length+extra) * tan(taper) :
is_def(width2) ? (width2-width) / 2 : 0; is_def(width2) ? (width2-width) / 2 : 0;
@ -562,15 +566,20 @@ module dovetail(gender, length, l, width, w, height, h, angle, slope, taper, wid
adjustment = gender == "male" ? -0.01 : 0.01; // Adjustment for default overlap in attach() adjustment = gender == "male" ? -0.01 : 0.01; // Adjustment for default overlap in attach()
orient_and_anchor([length, width+2*offset, height],anchor=anchor,orient=orient,spin=spin, chain=true) orient_and_anchor([length, width+2*offset, height],anchor=anchor,orient=orient,spin=spin, chain=true) {
down(height/2+adjustment) down(height/2+adjustment) {
skin([ skin(
[
concat(smallend_points, yflip(p=reverse(smallend_points))), concat(smallend_points, yflip(p=reverse(smallend_points))),
concat(bigend_points, yflip(p=reverse(bigend_points)))] concat(bigend_points, yflip(p=reverse(bigend_points)))
],
convexity=4
); );
}
children();
}
} }
// vim: noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap // vim: noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap

View file

@ -39,6 +39,7 @@ include <vnf.scad>
// closed = If true, the last profile is skinned to the first profile, to allow for making a closed loop. Assumes `caps=false`. Default: false // closed = If true, the last profile is skinned to the first profile, to allow for making a closed loop. Assumes `caps=false`. Default: false
// caps = If true, endcap faces are created. Assumes `closed=false`. Default: true // caps = If true, endcap faces are created. Assumes `closed=false`. Default: true
// method = Specifies the method used to match up vertices between profiles, to create faces. Given as a string, one of `"distance"`, `"angle"`, or `"uniform"`. If given as a list of strings, equal in number to the number of profile transitions, lets you specify the method used for each transition. Default: "uniform" // method = Specifies the method used to match up vertices between profiles, to create faces. Given as a string, one of `"distance"`, `"angle"`, or `"uniform"`. If given as a list of strings, equal in number to the number of profile transitions, lets you specify the method used for each transition. Default: "uniform"
// convexity = Max number of times a line could intersect a wall of the shape. (Module use only.) Default: 2.
// Example(FlatSpin): // Example(FlatSpin):
// skin([ // skin([
// scale([2,1,1], p=path3d(circle(d=100,$fn=48))), // scale([2,1,1], p=path3d(circle(d=100,$fn=48))),
@ -172,8 +173,8 @@ include <vnf.scad>
// move([0,0, 0], p=path3d(circle(d=100,$fn=36))), // move([0,0, 0], p=path3d(circle(d=100,$fn=36))),
// move([0,0,50], p=path3d(circle(d=100,$fn=6))) // move([0,0,50], p=path3d(circle(d=100,$fn=6)))
// ], caps=false); // ], caps=false);
module skin(profiles, closed=false, caps=true, method="uniform") { module skin(profiles, closed=false, caps=true, method="uniform", convexity=2) {
vnf_polyhedron(skin(profiles, caps=caps, closed=closed, method=method)); vnf_polyhedron(skin(profiles, caps=caps, closed=closed, method=method), convexity=convexity);
} }

View file

@ -8,7 +8,7 @@
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////
BOSL_VERSION = [2,0,79]; BOSL_VERSION = [2,0,80];
// Section: BOSL Library Version Functions // Section: BOSL Library Version Functions

View file

@ -301,9 +301,10 @@ function vnf_vertex_array(
// Given a VNF structure, or a list of VNF structures, creates a polyhedron from them. // Given a VNF structure, or a list of VNF structures, creates a polyhedron from them.
// Arguments: // Arguments:
// vnf = A VNF structure, or list of VNF structures. // vnf = A VNF structure, or list of VNF structures.
module vnf_polyhedron(vnf) { // convexity = Max number of times a line could intersect a wall of the shape.
module vnf_polyhedron(vnf, convexity=2) {
vnf = is_vnf_list(vnf)? vnf_merge(vnf) : vnf; vnf = is_vnf_list(vnf)? vnf_merge(vnf) : vnf;
polyhedron(vnf[0], vnf[1]); polyhedron(vnf[0], vnf[1], convexity=convexity);
} }