Merge pull request #1194 from BelfrySCAD/revarbat_dev

Fixed edge_profile() orientations.
This commit is contained in:
Revar Desmera 2023-06-20 01:15:38 -07:00 committed by GitHub
commit 4ff3d16605
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 5 deletions

View file

@ -1723,11 +1723,26 @@ module face_profile(faces=[], r, d, excess=0.01, convexity=10) {
// `$idx` is set to the index number of each edge. // `$idx` is set to the index number of each edge.
// `$attach_anchor` is set for each edge given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor. // `$attach_anchor` is set for each edge given, to the `[ANCHOR, POSITION, ORIENT, SPIN]` information for that anchor.
// `$profile_type` is set to `"edge"`. // `$profile_type` is set to `"edge"`.
// `$edge_angle` is set to the inner angle of the current edge.
// Example: // Example:
// diff() // diff()
// cube([50,60,70],center=true) // cube([50,60,70],center=true)
// edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT]) // edge_profile([TOP,"Z"],except=[BACK,TOP+LEFT])
// mask2d_roundover(r=10, inset=2); // mask2d_roundover(r=10, inset=2);
// Example: Using $edge_angle on a Conoid
// diff()
// cyl(d1=50, d2=30, l=40, anchor=BOT) {
// edge_profile([TOP,BOT], excess=10, convexity=6) {
// mask2d_roundover(r=8, inset=1, excess=1, mask_angle=$edge_angle);
// }
// }
// Example: Using $edge_angle on a Prismoid
// diff()
// prismoid([60,50],[30,20],h=40,shift=[-25,15]) {
// edge_profile(excess=10, convexity=20) {
// mask2d_roundover(r=5,inset=1,mask_angle=$edge_angle);
// }
// }
module edge_profile(edges=EDGES_ALL, except=[], excess=0.01, convexity=10) { module edge_profile(edges=EDGES_ALL, except=[], excess=0.01, convexity=10) {
req_children($children); req_children($children);
@ -1769,9 +1784,9 @@ module edge_profile(edges=EDGES_ALL, except=[], excess=0.01, convexity=10) {
if (!approx(pt1,pt2)) { if (!approx(pt1,pt2)) {
seglen = norm(pt2-pt1) + 2 * excess; seglen = norm(pt2-pt1) + 2 * excess;
move(cp) { move(cp) {
frame_map(y=-v1, z=unit(pt2-pt1)) { frame_map(x=-v2, z=unit(pt2-pt1)) {
linear_extrude(height=seglen, center=true, convexity=convexity) linear_extrude(height=seglen, center=true, convexity=convexity)
children(); mirror([-1,1]) children();
} }
} }
} }

View file

@ -203,7 +203,7 @@ function spur_gear(
p = pitch_radius(pitch, teeth), p = pitch_radius(pitch, teeth),
c = outer_radius(pitch, teeth, clearance, internal), c = outer_radius(pitch, teeth, clearance, internal),
r = _root_radius(pitch, teeth, clearance, internal), r = _root_radius(pitch, teeth, clearance, internal),
twist = atan2(thickness*tan(helical),p), twist = 360*thickness*tan(helical)/(2*PI*p),
rgn = [ rgn = [
spur_gear2d( spur_gear2d(
pitch = pitch, pitch = pitch,
@ -245,7 +245,7 @@ module spur_gear(
p = pitch_radius(pitch, teeth); p = pitch_radius(pitch, teeth);
c = outer_radius(pitch, teeth, clearance, internal); c = outer_radius(pitch, teeth, clearance, internal);
r = _root_radius(pitch, teeth, clearance, internal); r = _root_radius(pitch, teeth, clearance, internal);
twist = atan2(thickness*tan(helical),p); twist = 360*thickness*tan(helical)/(2*PI*p);
default_tag("remove", internal) default_tag("remove", internal)
attachable(anchor,spin,orient, r=p, l=thickness) { attachable(anchor,spin,orient, r=p, l=thickness) {
zrot(twist/2) zrot(twist/2)