Progress on variable roller

This commit is contained in:
Matt McWilliams 2023-04-04 15:13:47 -04:00
parent 40d67a786f
commit ec29d2bdf5
1 changed files with 109 additions and 76 deletions

View File

@ -44,80 +44,6 @@ module sprocket (pos = [0, 0, 0], rot = [0, 0, 0], bevel = false) {
}
}
module sprocketed_roller_top_sprockets (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, D, bevel = false) {
translate(pos) rotate(rot) {
cylinder(r = R(D), h = SprocketBaseH, center = true);
for (i = [0: sprockets]) {
rotate([0, 0, i * 360 / sprockets]) sprocket([(D / 2) - .01, 0, (SprocketBaseH / 2) - (SprocketL / 2)], [0, 90, 0], bevel);
}
}
}
module sprocketed_roller_body (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, bevel = false, reinforced = false) {
D = (FrameC * sprockets) / PI;
LipD = (LipC * sprockets) / PI;
TopD = (TopC * sprockets) / PI;
TopBaseD = (TopBaseC * sprockets) / PI;
InnerD = D - 5.07;
echo("D", D);
echo("LipD", LipD);
echo("InnerD", InnerD);
translate(pos) rotate(rot) {
//top
if (!reinforced) {
sprocketed_roller_top_sprockets(sprockets = sprockets, D = D, bevel = bevel);
} else {
ReinforcedRegistration = (InnerD - 5) / 2;
cube([ReinforcedRegistration + 5, ReinforcedRegistration, SprocketBaseH], center = true);
cube([ReinforcedRegistration, ReinforcedRegistration + 5, SprocketBaseH], center = true);
}
//center
translate([0, 0, (InnerH / 2) + (SprocketBaseH / 2)]) {
cylinder(r = R(InnerD), h = InnerH, center = true);
}
//lip
translate([0, 0, (TopBaseH / 2) + InnerH + (SprocketBaseH / 2) - (TopBaseH / 2) + (LipH / 2)]) {
cylinder(r = R(LipD), h = LipH, center = true);
}
//bottom
translate([0, 0, (TopH / 2) + (TopBaseH / 2) + InnerH + (SprocketBaseH / 2) + (TopBaseH / 2) - (LipH / 2)]) {
cylinder(r = R(TopD), h = TopH, center = true);
}
//bottom base
translate([0, 0, (TopBaseH / 2) + InnerH + (SprocketBaseH / 2)]) {
cylinder(r = R(TopBaseD), h = TopBaseH, center = true);
}
}
}
module sprocketed_roller (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, bevel = false, reinforced = false, model = "") {
D = (FrameC * sprockets) / PI;
difference () {
union () {
sprocketed_roller_body(pos = pos, rot = rot, sprockets = sprockets, bevel = bevel, reinforced = reinforced);
//translate(pos) rotate(rot) addition();
}
if (model == "gearbox_motor") {
translate(pos) rotate(rot) translate([0, 0, 10]) gearbox_motor_shaft_void();
translate(pos) rotate(rot) m3_nut_void(pos=[D/4, 0, 8.5], rot = [90, 0, 90], H = D/2);
}
}
}
module sprocketed_roller_reinforced(pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, bevel = true, model = "") {
D = (FrameC * sprockets) / PI;
difference () {
sprocketed_roller_top_sprockets (pos = pos, rot = rot, sprockets = sprockets, D = D, bevel = bevel);
scale([1.01, 1.01, 1]) sprocketed_roller (pos = pos, rot = rot, sprockets = sprockets, bevel = bevel, reinforced = true, model = model);
}
}
module gearbox_motor_shaft (H = 16, pad = 0) {
difference () {
cylinder(r = R(motorShaftD) + pad, h = H, center = true, $fn = 60);
@ -153,6 +79,113 @@ module m3_nut_void (pos = [0, 0, 0], rot = [0, 0, 0], H = 20) {
}
}
//sprocketed_roller(sprockets = 18, bevel = false, model = "gearbox_motor", reinforced = true);
color("red") sprocketed_roller_reinforced(sprockets = 18, bevel = false, model = "gearbox_motor");
module m3_bolt_void (pos = [0, 0, 0]) {
translate(pos) {
cylinder(r = R(3.25), h = 40, center = true, $fn = 30);
translate([0, 0, 14]) cylinder(r = R(6), h = 5, center = true, $fn = 40);
}
}
module sprocketed_wheel_m3_nut_void (pos = [0, 0, 0]) {
translate(pos) {
cylinder(r = R(3.25), h = 40, center = true, $fn = 30);
hex(R(6), 4);
}
}
module sprocketed_roller_sprocket_wheel (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, D, bevel = false, bolts = false) {
translate(pos) rotate(rot) {
cylinder(r = R(D), h = SprocketBaseH, center = true);
for (i = [0: sprockets]) {
rotate([0, 0, i * 360 / sprockets]) sprocket([(D / 2) - .01, 0, (SprocketBaseH / 2) - (SprocketL / 2)], [0, 90, 0], bevel);
}
}
}
module sprocketed_roller_body (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, bevel = false, reinforced = false, bolts = false) {
D = (FrameC * sprockets) / PI;
LipD = (LipC * sprockets) / PI;
TopD = (TopC * sprockets) / PI;
TopBaseD = (TopBaseC * sprockets) / PI;
InnerD = D - 5.07;
ReinforcedRegistration = (InnerD - 5) / 2;
BoltsY = ReinforcedRegistration + 12;
echo("D", D);
echo("LipD", LipD);
echo("InnerD", InnerD);
translate(pos) rotate(rot) difference() {
//top
union () {
if (!reinforced) {
sprocketed_roller_top_sprockets(sprockets = sprockets, D = D, bevel = bevel);
} else {
cube([ReinforcedRegistration + 5, ReinforcedRegistration, SprocketBaseH], center = true);
cube([ReinforcedRegistration, ReinforcedRegistration + 5, SprocketBaseH], center = true);
}
//center
translate([0, 0, (InnerH / 2) + (SprocketBaseH / 2)]) {
cylinder(r = R(InnerD), h = InnerH, center = true);
}
//lip
translate([0, 0, (TopBaseH / 2) + InnerH + (SprocketBaseH / 2) - (TopBaseH / 2) + (LipH / 2)]) {
cylinder(r = R(LipD), h = LipH, center = true);
}
//bottom
translate([0, 0, (TopH / 2) + (TopBaseH / 2) + InnerH + (SprocketBaseH / 2) + (TopBaseH / 2) - (LipH / 2)]) {
cylinder(r = R(TopD), h = TopH, center = true);
}
//bottom base
translate([0, 0, (TopBaseH / 2) + InnerH + (SprocketBaseH / 2)]) {
cylinder(r = R(TopBaseD), h = TopBaseH, center = true);
}
}
if (reinforced && bolts) {
m3_bolt_void([0, BoltsY/2, 0]);
m3_bolt_void([0, -BoltsY/2, 0]);
}
}
}
module sprocketed_roller (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, bevel = false, reinforced = false, , bolts = false, model = "") {
D = (FrameC * sprockets) / PI;
difference () {
union () {
sprocketed_roller_body(pos = pos, rot = rot, sprockets = sprockets, bevel = bevel, reinforced = reinforced, bolts = bolts);
//translate(pos) rotate(rot) addition();
}
if (model == "gearbox_motor") {
translate(pos) rotate(rot) translate([0, 0, 10]) gearbox_motor_shaft_void();
translate(pos) rotate(rot) m3_nut_void(pos=[D/4, 0, 8.5], rot = [90, 0, 90], H = D/2);
}
}
}
module sprocketed_roller_reinforced (pos = [0, 0, 0], rot = [0, 0, 0], sprockets = 8, bevel = true, model = "", bolts = true) {
D = (FrameC * sprockets) / PI;
InnerD = D - 5.07;
ReinforcedRegistration = (InnerD - 5) / 2;
BoltsY = ReinforcedRegistration + 12;
difference () {
sprocketed_roller_sprocket_wheel (pos = pos, rot = rot, sprockets = sprockets, D = D, bevel = bevel);
scale([1.01, 1.01, 1]) sprocketed_roller (pos = pos, rot = rot, sprockets = sprockets, bevel = bevel, reinforced = true, model = model);
if (bolts) {
sprocketed_wheel_m3_nut_void([0, BoltsY/2, -4]);
sprocketed_wheel_m3_nut_void([0, -BoltsY/2, -4]);
}
}
}
PART = "sprocketed_wheel";
if (PART == "sprocketed_roller_reinforced") {
rotate([180, 0, 0]) sprocketed_roller(sprockets = 18, bevel = false, model = "gearbox_motor", reinforced = true, bolts = true);
} else if (PART == "sprocketed_wheel") {
rotate([180, 0, 0]) color("red") sprocketed_roller_reinforced(sprockets = 18, bevel = false, model = "gearbox_motor", bolts = true);
}