mirror of
https://github.com/revarbat/BOSL2.git
synced 2025-01-16 21:58:27 +01:00
commit
8383d360cc
52
gears.scad
52
gears.scad
@ -2341,7 +2341,7 @@ module crown_gear(
|
|||||||
// teeth = Number of teeth on the gear
|
// teeth = Number of teeth on the gear
|
||||||
// mate_teeth = Number of teeth on the gear that will mate to this gear
|
// mate_teeth = Number of teeth on the gear that will mate to this gear
|
||||||
// shaft_angle = Angle between the shafts of the two gears. Default: 90
|
// shaft_angle = Angle between the shafts of the two gears. Default: 90
|
||||||
// --
|
// ---
|
||||||
// mod = The module of the gear (pitch diameter / teeth)
|
// mod = The module of the gear (pitch diameter / teeth)
|
||||||
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
|
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
|
||||||
// circ_pitch = The circular pitch, the distance between teeth centers around the pitch circle.
|
// circ_pitch = The circular pitch, the distance between teeth centers around the pitch circle.
|
||||||
@ -2398,6 +2398,22 @@ module crown_gear(
|
|||||||
// shaft_diam=5, slices=12, backing=3, spin=180/t2, cone_backing=false
|
// shaft_diam=5, slices=12, backing=3, spin=180/t2, cone_backing=false
|
||||||
// );
|
// );
|
||||||
// }
|
// }
|
||||||
|
// Example(NoAxes,VPT=[-12.7062,12.914,17.7517],VPR=[71.1,0,35.5],VPD=213.382): Placing bevel gears onto a frame using the `bottom=` parameter to get the correct position, and with holes cut in the frame for the shafts.
|
||||||
|
// t1=17; t2=29; mod=2; bot=4; wall=2; shaft=5;
|
||||||
|
// r1 = pitch_radius(mod=mod, teeth=t1);
|
||||||
|
// r2 = pitch_radius(mod=mod, teeth=t2);
|
||||||
|
// difference(){
|
||||||
|
// move([0,bot,-bot]){
|
||||||
|
// cuboid([60,40,wall], anchor=TOP+BACK);
|
||||||
|
// down(wall)cuboid([60,wall,70], anchor=BOT+FWD);
|
||||||
|
// }
|
||||||
|
// up(r2) ycyl(d=shaft, l=100);
|
||||||
|
// fwd(r1) zcyl(d=shaft, l=100);
|
||||||
|
// }
|
||||||
|
// fwd(r1) color("lightblue")
|
||||||
|
// bevel_gear(mod=mod, teeth=t1,mate_teeth=t2, bottom=bot, shaft_diam=shaft, slices=12);
|
||||||
|
// up(r2) color("orange")
|
||||||
|
// bevel_gear(mod=mod, teeth=t2,mate_teeth=t1, bottom=bot, right_handed=true, orient=FWD, shaft_diam=shaft, slices=12);
|
||||||
// Example(NoAxes,VPT=[24.4306,-9.20912,-29.3331],VPD=292.705,VPR=[71.8,0,62.5]): Bevel gears at a non right angle, positioned by aligning the pitch cone apexes.
|
// Example(NoAxes,VPT=[24.4306,-9.20912,-29.3331],VPD=292.705,VPR=[71.8,0,62.5]): Bevel gears at a non right angle, positioned by aligning the pitch cone apexes.
|
||||||
// ang=65;
|
// ang=65;
|
||||||
// bevel_gear(mod=3,35,15,ang,spiral=0,backing=5,anchor="apex")
|
// bevel_gear(mod=3,35,15,ang,spiral=0,backing=5,anchor="apex")
|
||||||
@ -2406,13 +2422,38 @@ module crown_gear(
|
|||||||
// xrot(ang)
|
// xrot(ang)
|
||||||
// bevel_gear(mod=3,15,35,ang,spiral=0,right_handed=true,anchor="apex")
|
// bevel_gear(mod=3,15,35,ang,spiral=0,right_handed=true,anchor="apex")
|
||||||
// cyl(h=65,d=3,$fn=16,anchor=BOT);
|
// cyl(h=65,d=3,$fn=16,anchor=BOT);
|
||||||
// Example(VPT=[6.39483,26.2195,8.93229],VPD=192.044,VPR=[76.7,0,63.3],NoAxes): At this extreme 135 degree angle the yellow gear has internal teeth. This is a rare configuration.
|
// Example(NoAxes,VPT=[-6.28233,3.60349,15.6594],VPR=[71.1,0,52.1],VPD=213.382): Non-right angled bevel gear pair positioned in a frame, with holes cut in the frame for the shafts.
|
||||||
|
// include<BOSL2/rounding.scad>
|
||||||
|
// angle = 60;
|
||||||
|
// t1=17; t2=29; mod=2; bot=4; wall=2; shaft=5;
|
||||||
|
// r1 = pitch_radius(mod=mod, teeth=t1);
|
||||||
|
// r2 = pitch_radius(mod=mod, teeth=t2);
|
||||||
|
// difference(){
|
||||||
|
// move(bot*[0, 1/tan(90-angle/2),-1])
|
||||||
|
// rot(90)xrot(90)
|
||||||
|
// linear_extrude(height=60,center=true,convexity=5)
|
||||||
|
// offset_stroke([[-40,0],[0,0], polar_to_xy(60,angle)], width=[-wall,0]);
|
||||||
|
// move(r2*[0,cos(angle),sin(angle)])
|
||||||
|
// xrot(angle)zcyl(d=shaft, l=50);
|
||||||
|
// fwd(r1)
|
||||||
|
// zcyl(d=shaft, l=50);
|
||||||
|
// }
|
||||||
|
// fwd(r1) color("lightblue")
|
||||||
|
// bevel_gear(mod=mod, teeth=t1,mate_teeth=t2, bottom=bot, shaft_angle=angle, shaft_diam=shaft, slices=12);
|
||||||
|
// xrot(angle) back(r2) color("orange")
|
||||||
|
// bevel_gear(mod=mod, teeth=t2,mate_teeth=t1, bottom=bot, shaft_angle=angle, shaft_diam=shaft, right_handed=true, slices=12);
|
||||||
|
// Example(NoAxes,VPT=[-0.482968,-0.51139,-4.48142],VPR=[69.7,0,40.9],VPD=263.435): At this extreme 135 degree angle the yellow gear has internal teeth. This is a rare configuration.
|
||||||
// ang=135;
|
// ang=135;
|
||||||
// bevel_gear(mod=3,35,15,ang);
|
// bevel_gear(mod=3,35,15,ang);
|
||||||
// color("lightblue")
|
// color("lightblue")
|
||||||
// back(pitch_radius(mod=3,teeth=35)+pitch_radius(mod=3,teeth=15))
|
// back(pitch_radius(mod=3,teeth=35)+pitch_radius(mod=3,teeth=15))
|
||||||
// xrot(ang,cp=[0,-pitch_radius(mod=3,teeth=15),0])
|
// xrot(ang,cp=[0,-pitch_radius(mod=3,teeth=15),0])
|
||||||
// bevel_gear(mod=3,15,35,ang,right_handed=true);
|
// bevel_gear(mod=3,15,35,ang,right_handed=true);
|
||||||
|
|
||||||
|
echo(VPT=$vpt,VPR=$vpr,VPD=$vpd);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function bevel_gear(
|
function bevel_gear(
|
||||||
teeth,
|
teeth,
|
||||||
mate_teeth,
|
mate_teeth,
|
||||||
@ -3831,7 +3872,6 @@ function pitch_radius(
|
|||||||
assert(is_finite(circ_pitch))
|
assert(is_finite(circ_pitch))
|
||||||
circ_pitch * teeth / PI / 2 / cos(helical);
|
circ_pitch * teeth / PI / 2 / cos(helical);
|
||||||
|
|
||||||
|
|
||||||
// Function: outer_radius()
|
// Function: outer_radius()
|
||||||
// Synopsis: Returns the outer radius for a gear.
|
// Synopsis: Returns the outer radius for a gear.
|
||||||
// Topics: Gears, Parts
|
// Topics: Gears, Parts
|
||||||
@ -4123,7 +4163,7 @@ function worm_dist(d,starts,teeth,mod,profile_shift=0,diam_pitch,circ_pitch,pres
|
|||||||
// helical = The value of the helical angle (from vertical) of the teeth on the two gears (either sign). Default: 0
|
// helical = The value of the helical angle (from vertical) of the teeth on the two gears (either sign). Default: 0
|
||||||
// profile_shift1 = Profile shift factor x for the first gear. Default: 0
|
// profile_shift1 = Profile shift factor x for the first gear. Default: 0
|
||||||
// profile_shift2 = Profile shift factor x for the second gear. Default: 0
|
// profile_shift2 = Profile shift factor x for the second gear. Default: 0
|
||||||
// --
|
// ---
|
||||||
// mod = The module of the gear (pitch diameter / teeth)
|
// mod = The module of the gear (pitch diameter / teeth)
|
||||||
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
|
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
|
||||||
// circ_pitch = The circular pitch, the distance between teeth centers around the pitch circle.
|
// circ_pitch = The circular pitch, the distance between teeth centers around the pitch circle.
|
||||||
@ -4241,7 +4281,7 @@ function _working_pressure_angle(teeth1,profile_shift1, teeth2, profile_shift2,
|
|||||||
// helical1 = The helical angle (from vertical) of the teeth on the second gear.
|
// helical1 = The helical angle (from vertical) of the teeth on the second gear.
|
||||||
// profile_shift1 = Profile shift factor x for the first gear. Default: "auto"
|
// profile_shift1 = Profile shift factor x for the first gear. Default: "auto"
|
||||||
// profile_shift2 = Profile shift factor x for the second gear. Default: "auto"
|
// profile_shift2 = Profile shift factor x for the second gear. Default: "auto"
|
||||||
// --
|
// ---
|
||||||
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
|
// diam_pitch = The diametral pitch, or number of teeth per inch of pitch diameter. Note that the diametral pitch is a completely different thing than the pitch diameter.
|
||||||
// mod = The module of the gear (pitch diameter / teeth)
|
// mod = The module of the gear (pitch diameter / teeth)
|
||||||
// circ_pitch = The circular pitch, the distance between teeth centers around the pitch circle.
|
// circ_pitch = The circular pitch, the distance between teeth centers around the pitch circle.
|
||||||
@ -4297,7 +4337,7 @@ function _working_normal_pressure_angle_skew(teeth1,profile_shift1,helical1, tee
|
|||||||
// helical1 = The helical angle (from vertical) of the teeth on the second gear.
|
// helical1 = The helical angle (from vertical) of the teeth on the second gear.
|
||||||
// profile_shift1 = Profile shift factor x for the first gear. Default: "auto"
|
// profile_shift1 = Profile shift factor x for the first gear. Default: "auto"
|
||||||
// profile_shift2 = Profile shift factor x for the second gear. Default: "auto"
|
// profile_shift2 = Profile shift factor x for the second gear. Default: "auto"
|
||||||
// --
|
// ---
|
||||||
// pressure_angle = The pressure angle of the gear.
|
// pressure_angle = The pressure angle of the gear.
|
||||||
// Example(3D,Med,NoAxes,VPT=[-2.62091,2.01048,-1.31405],VPR=[55,0,25],VPD=74.4017): These gears are auto profile shifted and as a result, do not mesh at the sum of their helical angles, but at 2.5 degrees more.
|
// Example(3D,Med,NoAxes,VPT=[-2.62091,2.01048,-1.31405],VPR=[55,0,25],VPD=74.4017): These gears are auto profile shifted and as a result, do not mesh at the sum of their helical angles, but at 2.5 degrees more.
|
||||||
// circ_pitch=5; teeth1=12; teeth2=7; ha1=25; ha2=30; thick=10;
|
// circ_pitch=5; teeth1=12; teeth2=7; ha1=25; ha2=30; thick=10;
|
||||||
|
@ -664,7 +664,7 @@ module dovetail(gender, width, height, slide, h, w, angle, slope, thickness, tap
|
|||||||
|
|
||||||
// Need taper angle for computing width adjustment, but not used elsewhere
|
// Need taper angle for computing width adjustment, but not used elsewhere
|
||||||
taper_ang = is_def(taper) ? taper
|
taper_ang = is_def(taper) ? taper
|
||||||
: is_def(back_width) ? atan((back_width-width)/2/slide)
|
: is_def(back_width) ? atan((back_width-w)/2/slide)
|
||||||
: 0;
|
: 0;
|
||||||
// This is the adjustment factor for width to grow in the direction normal to the dovetail face
|
// This is the adjustment factor for width to grow in the direction normal to the dovetail face
|
||||||
wfactor = sqrt( 1/slope^2 + 1/cos(taper_ang)^2 );
|
wfactor = sqrt( 1/slope^2 + 1/cos(taper_ang)^2 );
|
||||||
@ -708,7 +708,7 @@ module dovetail(gender, width, height, slide, h, w, angle, slope, thickness, tap
|
|||||||
|
|
||||||
bigenough = all_nonnegative(column(smallend_half,0)) && all_nonnegative(column(bigend_points,0));
|
bigenough = all_nonnegative(column(smallend_half,0)) && all_nonnegative(column(bigend_points,0));
|
||||||
|
|
||||||
assert(bigenough, "Width of dovetail is not large enough for its geometry (angle and taper");
|
assert(bigenough, "Width (or back_width) of dovetail is not large enough for its geometry (angle and taper");
|
||||||
|
|
||||||
//adjustment = $overlap * (gender == "male" ? -1 : 1); // Adjustment for default overlap in attach()
|
//adjustment = $overlap * (gender == "male" ? -1 : 1); // Adjustment for default overlap in attach()
|
||||||
adjustment = 0; // Default overlap is assumed to be zero
|
adjustment = 0; // Default overlap is assumed to be zero
|
||||||
|
@ -972,8 +972,8 @@ module screw_hole(spec, head, thread, oversize, hole_oversize, head_oversize,
|
|||||||
: in_list(downcase(tolerance), ["loose", "coarse"]) ? 2
|
: in_list(downcase(tolerance), ["loose", "coarse"]) ? 2
|
||||||
: in_list(tolerance, ["H12","H13","H14"]) ?
|
: in_list(tolerance, ["H12","H13","H14"]) ?
|
||||||
assert(struct_val(screwspec,"system")=="ISO", str("Hole tolerance ", tolerance, " only allowed with ISO screws"))
|
assert(struct_val(screwspec,"system")=="ISO", str("Hole tolerance ", tolerance, " only allowed with ISO screws"))
|
||||||
parse_int(substr(tolerance,1))
|
parse_int(substr(tolerance,1))-12
|
||||||
: assert(false,str("Unknown tolerance ",tolerance, " for clearance hole"));
|
: assert(false,str("Unknown tolerance ",tolerance, " for unthreaded clearance hole. Use one of \"close\", \"normal\", or \"loose\""));
|
||||||
tol_table = struct_val(screwspec,"system")=="UTS" ? UTS_clearance[tol_ind] : ISO_clearance[tol_ind];
|
tol_table = struct_val(screwspec,"system")=="UTS" ? UTS_clearance[tol_ind] : ISO_clearance[tol_ind];
|
||||||
tol_gap = lookup(_nominal_diam(screwspec), tol_table);
|
tol_gap = lookup(_nominal_diam(screwspec), tol_table);
|
||||||
// If we got here, hole_oversize is undefined and oversize is undefined
|
// If we got here, hole_oversize is undefined and oversize is undefined
|
||||||
@ -1274,8 +1274,8 @@ function _ISO_thread_tolerance(diameter, pitch, internal=false, tolerance=undef)
|
|||||||
&& str_find("3456789", tol_str[0]) != undef
|
&& str_find("3456789", tol_str[0]) != undef
|
||||||
&& str_find("468", tol_str[2]) !=undef)
|
&& str_find("468", tol_str[2]) !=undef)
|
||||||
)
|
)
|
||||||
assert(internalok,str("Invalid internal thread tolerance, ",tolerance,". Must have form <digit><letter>"))
|
assert(internalok,str("Invalid ISO internal thread tolerance, ",tolerance,". Must have form <digit><letter>"))
|
||||||
assert(externalok,str("invalid external thread tolerance, ",tolerance,". Must have form <digit><letter> or <digit><letter><digit><letter>"))
|
assert(externalok,str("invalid ISO external thread tolerance, ",tolerance,". Must have form <digit><letter> or <digit><letter><digit><letter>"))
|
||||||
let(
|
let(
|
||||||
tol_num_pitch = parse_num(tol_str[0]),
|
tol_num_pitch = parse_num(tol_str[0]),
|
||||||
tol_num_crest = parse_num(tol_str[2]),
|
tol_num_crest = parse_num(tol_str[2]),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user