mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-07 12:49:46 +00:00
Merge pull request #288 from revarbat/revarbat_dev
Fixed involute gear examples and docs.
This commit is contained in:
commit
bd24c3bead
2 changed files with 62 additions and 67 deletions
|
@ -128,7 +128,7 @@ function base_radius(pitch=5, teeth=11, PA=28) =
|
||||||
|
|
||||||
// Function bevel_pitch_angle()
|
// Function bevel_pitch_angle()
|
||||||
// Usage:
|
// Usage:
|
||||||
// bevel_pitch_angle(teeth, mate_teeth, [drive_angle]);
|
// x = bevel_pitch_angle(teeth, mate_teeth, [drive_angle]);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the correct pitch angle (bevelang) for a bevel gear with a given number of tooth, that is
|
// Returns the correct pitch angle (bevelang) for a bevel gear with a given number of tooth, that is
|
||||||
// matched to another bevel gear with a (possibly different) number of teeth.
|
// matched to another bevel gear with a (possibly different) number of teeth.
|
||||||
|
@ -150,6 +150,10 @@ function _gear_q7(f,r,b,r2,t,s) = _gear_q6(b,s,t,(1-f)*max(b,r)+f*r2); //
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: gear_tooth_profile()
|
// Function&Module: gear_tooth_profile()
|
||||||
|
// Usage: As Module
|
||||||
|
// gear_tooth_profile(pitch, teeth, <PA>, <clearance>, <backlash>, <interior>, <valleys>);
|
||||||
|
// Usage: As Function
|
||||||
|
// path = gear_tooth_profile(pitch, teeth, <PA>, <clearance>, <backlash>, <interior>, <valleys>);
|
||||||
// Description:
|
// Description:
|
||||||
// When called as a function, returns the 2D profile path for an individual gear tooth.
|
// When called as a function, returns the 2D profile path for an individual gear tooth.
|
||||||
// When called as a module, creates the 2D profile shape for an individual gear tooth.
|
// When called as a module, creates the 2D profile shape for an individual gear tooth.
|
||||||
|
@ -157,8 +161,8 @@ function _gear_q7(f,r,b,r2,t,s) = _gear_q6(b,s,t,(1-f)*max(b,r)+f*r2); //
|
||||||
// pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
|
// pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
|
||||||
// teeth = Total number of teeth along the rack
|
// teeth = Total number of teeth along the rack
|
||||||
// PA = Controls how straight or bulged the tooth sides are. In degrees.
|
// PA = Controls how straight or bulged the tooth sides are. In degrees.
|
||||||
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle
|
|
||||||
// clearance = Gap between top of a tooth on one gear and bottom of valley on a meshing gear (in millimeters)
|
// clearance = Gap between top of a tooth on one gear and bottom of valley on a meshing gear (in millimeters)
|
||||||
|
// backlash = Gap between two meshing teeth, in the direction along the circumference of the pitch circle
|
||||||
// interior = If true, create a mask for difference()ing from something else.
|
// interior = If true, create a mask for difference()ing from something else.
|
||||||
// valleys = If true, add the valley bottoms on either side of the tooth.
|
// valleys = If true, add the valley bottoms on either side of the tooth.
|
||||||
// Example(2D):
|
// Example(2D):
|
||||||
|
@ -169,8 +173,8 @@ function gear_tooth_profile(
|
||||||
pitch = 3,
|
pitch = 3,
|
||||||
teeth = 11,
|
teeth = 11,
|
||||||
PA = 28,
|
PA = 28,
|
||||||
backlash = 0.0,
|
|
||||||
clearance = undef,
|
clearance = undef,
|
||||||
|
backlash = 0.0,
|
||||||
interior = false,
|
interior = false,
|
||||||
valleys = true
|
valleys = true
|
||||||
) = let(
|
) = let(
|
||||||
|
@ -227,6 +231,10 @@ module gear_tooth_profile(
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: gear2d()
|
// Function&Module: gear2d()
|
||||||
|
// Usage: As Module
|
||||||
|
// gear2d(pitch, teeth, <hide>, <PA>, <clearance>, <backlash>, <interior>);
|
||||||
|
// Usage: As Function
|
||||||
|
// poly = gear2d(pitch, teeth, <hide>, <PA>, <clearance>, <backlash>, <interior>);
|
||||||
// Description:
|
// Description:
|
||||||
// When called as a module, creates a 2D involute spur gear. When called as a function, returns a
|
// When called as a module, creates a 2D involute spur gear. When called as a function, returns a
|
||||||
// 2D path for the perimeter of a 2D involute spur gear. Normally, you should just specify the
|
// 2D path for the perimeter of a 2D involute spur gear. Normally, you should just specify the
|
||||||
|
@ -310,37 +318,29 @@ module gear2d(
|
||||||
|
|
||||||
|
|
||||||
// Module: gear()
|
// Module: gear()
|
||||||
|
// Usage:
|
||||||
|
// gear(pitch, teeth, thickness, <shaft_diam>, <hide>, <PA>, <clearance>, <backlash>, <helical>, <slices>, <interior>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a (potentially helical) involute spur gear.
|
// Creates a (potentially helical) involute spur gear. The module `gear()` gives an involute spur
|
||||||
// The module `gear()` gives an involute spur gear, with reasonable
|
// gear, with reasonable defaults for all the parameters. Normally, you should just choose the
|
||||||
// defaults for all the parameters. Normally, you should just choose
|
// first 4 parameters, and let the rest be default values. The module `gear()` gives a gear in the
|
||||||
// the first 4 parameters, and let the rest be default values. The
|
// XY plane, centered on the origin, with one tooth centered on the positive Y axis. The various
|
||||||
// module `gear()` gives a gear in the XY plane, centered on the origin,
|
// functions below it take the same parameters, and return various measurements for the gear. The
|
||||||
// with one tooth centered on the positive Y axis. The various functions
|
// most important is `pitch_radius()`, which tells how far apart to space gears that are meshing,
|
||||||
// below it take the same parameters, and return various measurements
|
// and `outer_radius()`, which gives the size of the region filled by the gear. A gear has a "pitch
|
||||||
// for the gear. The most important is `pitch_radius()`, which tells
|
// circle", which is an invisible circle that cuts through the middle of each tooth (though not the
|
||||||
// how far apart to space gears that are meshing, and `outer_radius()`,
|
// exact center). In order for two gears to mesh, their pitch circles should just touch. So the
|
||||||
// which gives the size of the region filled by the gear. A gear has
|
// distance between their centers should be `pitch_radius()` for one, plus `pitch_radius()` for the
|
||||||
// a "pitch circle", which is an invisible circle that cuts through
|
// other, which gives the radii of their pitch circles. In order for two gears to mesh, they must
|
||||||
// the middle of each tooth (though not the exact center). In order
|
// have the same `pitch` and `PA` parameters. `pitch` gives the number of millimeters of arc around
|
||||||
// for two gears to mesh, their pitch circles should just touch. So
|
// the pitch circle covered by one tooth and one space between teeth. The `PA` controls how flat or
|
||||||
// the distance between their centers should be `pitch_radius()` for
|
// bulged the sides of the teeth are. Common values include 14.5 degrees and 20 degrees, and
|
||||||
// one, plus `pitch_radius()` for the other, which gives the radii of
|
// occasionally 25. Though I've seen 28 recommended for plastic gears. Larger numbers bulge out
|
||||||
// their pitch circles.
|
// more, giving stronger teeth, so 28 degrees is the default here. The ratio of `teeth` for two
|
||||||
// In order for two gears to mesh, they must have the same `pitch`
|
// meshing gears gives how many times one will make a full revolution when the the other makes one
|
||||||
// and `PA` parameters. `pitch` gives the number
|
// full revolution. If the two numbers are coprime (i.e. are not both divisible by the same number
|
||||||
// of millimeters of arc around the pitch circle covered by one tooth
|
// greater than 1), then every tooth on one gear will meet every tooth on the other, for more even
|
||||||
// and one space between teeth. The `PA` controls how flat or
|
// wear. So coprime numbers of teeth are good.
|
||||||
// bulged the sides of the teeth are. Common values include 14.5
|
|
||||||
// degrees and 20 degrees, and occasionally 25. Though I've seen 28
|
|
||||||
// recommended for plastic gears. Larger numbers bulge out more, giving
|
|
||||||
// stronger teeth, so 28 degrees is the default here.
|
|
||||||
// The ratio of `teeth` for two meshing gears gives how many
|
|
||||||
// times one will make a full revolution when the the other makes one
|
|
||||||
// full revolution. If the two numbers are coprime (i.e. are not
|
|
||||||
// both divisible by the same number greater than 1), then every tooth
|
|
||||||
// on one gear will meet every tooth on the other, for more even wear.
|
|
||||||
// So coprime numbers of teeth are good.
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
|
// pitch = The circular pitch, or distance between teeth around the pitch circle, in mm.
|
||||||
// teeth = Total number of teeth around the entire perimeter
|
// teeth = Total number of teeth around the entire perimeter
|
||||||
|
@ -361,13 +361,33 @@ module gear2d(
|
||||||
// gear(pitch=5, teeth=20, thickness=8, shaft_diam=5);
|
// gear(pitch=5, teeth=20, thickness=8, shaft_diam=5);
|
||||||
// Example: Beveled Gear
|
// Example: Beveled Gear
|
||||||
// gear(pitch=5, teeth=20, thickness=10, shaft_diam=5, helical=-30, slices=12, $fa=1, $fs=1);
|
// gear(pitch=5, teeth=20, thickness=10, shaft_diam=5, helical=-30, slices=12, $fa=1, $fs=1);
|
||||||
|
// Example: Assembly of Gears
|
||||||
|
// n1 = 11; //red gear number of teeth
|
||||||
|
// n2 = 20; //green gear
|
||||||
|
// n3 = 5; //blue gear
|
||||||
|
// n4 = 20; //orange gear
|
||||||
|
// n5 = 8; //gray rack
|
||||||
|
// pitch = 9; //all meshing gears need the same `pitch` (and the same `PA`)
|
||||||
|
// thickness = 6;
|
||||||
|
// hole = 3;
|
||||||
|
// height = 12;
|
||||||
|
// d1 =pitch_radius(pitch,n1);
|
||||||
|
// d12=pitch_radius(pitch,n1) + pitch_radius(pitch,n2);
|
||||||
|
// d13=pitch_radius(pitch,n1) + pitch_radius(pitch,n3);
|
||||||
|
// d14=pitch_radius(pitch,n1) + pitch_radius(pitch,n4);
|
||||||
|
// translate([ 0, 0, 0]) rotate([0,0, $t*360/n1]) color([1.00,0.75,0.75]) gear(pitch,n1,thickness,hole);
|
||||||
|
// translate([ 0, d12, 0]) rotate([0,0,-($t+n2/2-0*n1+1/2)*360/n2]) color([0.75,1.00,0.75]) gear(pitch,n2,thickness,hole);
|
||||||
|
// translate([ d13, 0, 0]) rotate([0,0,-($t-n3/4+n1/4+1/2)*360/n3]) color([0.75,0.75,1.00]) gear(pitch,n3,thickness,hole);
|
||||||
|
// translate([ d13, 0, 0]) rotate([0,0,-($t-n3/4+n1/4+1/2)*360/n3]) color([0.75,0.75,1.00]) gear(pitch,n3,thickness,hole);
|
||||||
|
// translate([-d14, 0, 0]) rotate([0,0,-($t-n4/4-n1/4+1/2-floor(n4/4)-3)*360/n4]) color([1.00,0.75,0.50]) gear(pitch,n4,thickness,hole,hide=n4-3);
|
||||||
|
// translate([(-floor(n5/2)-floor(n1/2)+$t+n1/2)*9, -d1+0.0, 0]) color([0.75,0.75,0.75]) rack(pitch=pitch,teeth=n5,thickness=thickness,height=height,anchor=CENTER);
|
||||||
module gear(
|
module gear(
|
||||||
pitch = 3,
|
pitch = 3,
|
||||||
teeth = 11,
|
teeth = 11,
|
||||||
PA = 28,
|
|
||||||
thickness = 6,
|
thickness = 6,
|
||||||
hide = 0,
|
|
||||||
shaft_diam = 3,
|
shaft_diam = 3,
|
||||||
|
hide = 0,
|
||||||
|
PA = 28,
|
||||||
clearance = undef,
|
clearance = undef,
|
||||||
backlash = 0.0,
|
backlash = 0.0,
|
||||||
helical = 0,
|
helical = 0,
|
||||||
|
@ -405,6 +425,8 @@ module gear(
|
||||||
|
|
||||||
|
|
||||||
// Module: bevel_gear()
|
// Module: bevel_gear()
|
||||||
|
// Usage:
|
||||||
|
// bevel_gear(pitch, teeth, face_width, bevelang, <shaft_diam>, <hide>, <PA>, <clearance>, <backlash>, <spiral_rad>, <spiral_ang>, <slices>, <interior>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a (potentially spiral) bevel gear.
|
// Creates a (potentially spiral) bevel gear.
|
||||||
// The module `bevel_gear()` gives an bevel gear, with reasonable
|
// The module `bevel_gear()` gives an bevel gear, with reasonable
|
||||||
|
@ -459,11 +481,11 @@ module gear(
|
||||||
module bevel_gear(
|
module bevel_gear(
|
||||||
pitch = 3,
|
pitch = 3,
|
||||||
teeth = 11,
|
teeth = 11,
|
||||||
PA = 20,
|
|
||||||
face_width = 6,
|
face_width = 6,
|
||||||
bevelang = 45,
|
bevelang = 45,
|
||||||
hide = 0,
|
|
||||||
shaft_diam = 3,
|
shaft_diam = 3,
|
||||||
|
hide = 0,
|
||||||
|
PA = 20,
|
||||||
clearance = undef,
|
clearance = undef,
|
||||||
backlash = 0.0,
|
backlash = 0.0,
|
||||||
spiral_rad = 0,
|
spiral_rad = 0,
|
||||||
|
@ -586,6 +608,8 @@ module bevel_gear(
|
||||||
|
|
||||||
|
|
||||||
// Module: rack()
|
// Module: rack()
|
||||||
|
// Usage:
|
||||||
|
// rack(pitch, teeth, thickness, height, <PA>, <backlash>);
|
||||||
// Description:
|
// Description:
|
||||||
// The module `rack()` gives a rack, which is a bar with teeth. A
|
// The module `rack()` gives a rack, which is a bar with teeth. A
|
||||||
// rack can mesh with any gear that has the same `pitch` and
|
// rack can mesh with any gear that has the same `pitch` and
|
||||||
|
@ -668,35 +692,6 @@ module rack(
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////////
|
|
||||||
//example gear train.
|
|
||||||
//Try it with OpenSCAD View/Animate command with 20 steps and 24 FPS.
|
|
||||||
//The gears will continue to be rotated to mesh correctly if you change the number of teeth.
|
|
||||||
|
|
||||||
/*
|
|
||||||
n1 = 11; //red gear number of teeth
|
|
||||||
n2 = 20; //green gear
|
|
||||||
n3 = 5; //blue gear
|
|
||||||
n4 = 20; //orange gear
|
|
||||||
n5 = 8; //gray rack
|
|
||||||
pitch = 9; //all meshing gears need the same `pitch` (and the same `PA`)
|
|
||||||
thickness = 6;
|
|
||||||
hole = 3;
|
|
||||||
height = 12;
|
|
||||||
|
|
||||||
d1 =pitch_radius(pitch,n1);
|
|
||||||
d12=pitch_radius(pitch,n1) + pitch_radius(pitch,n2);
|
|
||||||
d13=pitch_radius(pitch,n1) + pitch_radius(pitch,n3);
|
|
||||||
d14=pitch_radius(pitch,n1) + pitch_radius(pitch,n4);
|
|
||||||
|
|
||||||
translate([ 0, 0, 0]) rotate([0,0, $t*360/n1]) color([1.00,0.75,0.75]) gear(pitch,n1,thickness,hole);
|
|
||||||
translate([ 0, d12, 0]) rotate([0,0,-($t+n2/2-0*n1+1/2)*360/n2]) color([0.75,1.00,0.75]) gear(pitch,n2,thickness,hole);
|
|
||||||
translate([ d13, 0, 0]) rotate([0,0,-($t-n3/4+n1/4+1/2)*360/n3]) color([0.75,0.75,1.00]) gear(pitch,n3,thickness,hole);
|
|
||||||
translate([ d13, 0, 0]) rotate([0,0,-($t-n3/4+n1/4+1/2)*360/n3]) color([0.75,0.75,1.00]) gear(pitch,n3,thickness,hole);
|
|
||||||
translate([-d14, 0, 0]) rotate([0,0,-($t-n4/4-n1/4+1/2-floor(n4/4)-3)*360/n4]) color([1.00,0.75,0.50]) gear(pitch,n4,thickness,hole,hide=n4-3);
|
|
||||||
translate([(-floor(n5/2)-floor(n1/2)+$t+n1/2-1/2)*9, -d1+0.0, 0]) rotate([0,0,0]) color([0.75,0.75,0.75]) rack(pitch,n5,thickness,height);
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
BOSL_VERSION = [2,0,439];
|
BOSL_VERSION = [2,0,440];
|
||||||
|
|
||||||
|
|
||||||
// Section: BOSL Library Version Functions
|
// Section: BOSL Library Version Functions
|
||||||
|
|
Loading…
Reference in a new issue