Compare commits
2 Commits
9adce4733c
...
ce505d83c6
Author | SHA1 | Date |
---|---|---|
|
ce505d83c6 | |
|
eb2f452431 |
74
takeup.scad
74
takeup.scad
|
@ -59,6 +59,7 @@ module magnetic_coupling (MAGNETS = 4, MAGNET_D = 8.1, MAGNET_H = 2.5) {
|
|||
union () {
|
||||
cylinder(r = COUPLING_D / 2, h = MAGNET_H + H, center = true, $fn = 100);
|
||||
translate([0, 0, -6]) cylinder(r = 12.5 / 2, h = 10, center = true, $fn = 60);
|
||||
translate([0, 0, -5]) cylinder(r = 20 / 2, h = 5, center = true, $fn = 60);
|
||||
}
|
||||
//motor shaft void
|
||||
scale([1.1, 1.1, 2]) motor_shaft();
|
||||
|
@ -66,6 +67,15 @@ module magnetic_coupling (MAGNETS = 4, MAGNET_D = 8.1, MAGNET_H = 2.5) {
|
|||
for (i = [0 : MAGNETS - 1]) {
|
||||
rotate([0, 0, i * (360 / MAGNETS)]) translate([0, OFFSET, H - MAGNET_H + 1.01]) cylinder(r = MAGNET_D / 2, h = MAGNET_H, center = true, $fn = 50);
|
||||
}
|
||||
//m3 nut
|
||||
translate([6, 0, -9]) {
|
||||
cube([2.75, 5.75, 10], center = true);
|
||||
translate([0, 0, 5]) rotate([0, 90, 0]) {
|
||||
cylinder(r = 6.75/2, h = 2.75, center = true, $fn = 6);
|
||||
translate([0, 0, 4]) cylinder(r = 3.25/2, h = 20, center = true, $fn = 30);
|
||||
translate([0, 0, 13.5]) cylinder(r = 6/2, h = 20, center = true, $fn = 30);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -117,33 +127,47 @@ module motor_mount_void (D, Z) {
|
|||
}
|
||||
|
||||
module mount_plate_void () {
|
||||
cylinder(r = 4 / 2, h = 20, center = true, $fn = 40);
|
||||
translate([0, 0, 0.5]) cylinder(r2 = 4/2, r1 = 6 / 2, h = 3, center = true, $fn = 40);
|
||||
cylinder(r = 4.25 / 2, h = 20, center = true, $fn = 40);
|
||||
translate([0, 0, 0.5]) cylinder(r = 8 / 2, h = 3, center = true, $fn = 40);
|
||||
}
|
||||
|
||||
module mount_plate () {
|
||||
Z = 1.5;
|
||||
D = 7.5 + 1.5;
|
||||
|
||||
MOUNT_X = 40;
|
||||
MOUNT_Y = 55;
|
||||
X = 60;
|
||||
Y = 60;
|
||||
|
||||
CORNER = 4;
|
||||
X_CORNER = (60 / 2) - (CORNER / 2);
|
||||
Y_CORNER = (70 / 2) - (CORNER / 2);
|
||||
MOUNT_X = 42;
|
||||
MOUNT_Y = 42;
|
||||
|
||||
CORNER = 3;
|
||||
X_CORNER = (X / 2) - (CORNER / 2);
|
||||
Y_CORNER = (Y / 2) - (CORNER / 2);
|
||||
|
||||
//center
|
||||
//color("red") cylinder(r = 15 / 2, h = 20, center = true, $fn = 60);
|
||||
|
||||
difference () {
|
||||
translate([0, 0, 3.26 - .5]) cube([60, 70, 7], center = true);
|
||||
translate([MOTOR_MOUNT_X / 2, MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([-MOTOR_MOUNT_X / 2, MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([MOTOR_MOUNT_X / 2, -MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([-MOTOR_MOUNT_X / 2, -MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([-(46 / 2) + 15 + 1, 0, 0]) cylinder(r = 15 / 2, h = 20, center = true, $fn = 60);
|
||||
translate([0, 0, 3.26 - .5]) cube([X, Y, 7], center = true);
|
||||
|
||||
//motor void (centered)
|
||||
translate([7, 0, 0]) {
|
||||
translate([-(46 / 2) + 15 + 1, 0, 0]) cylinder(r = 15 / 2, h = 20, center = true, $fn = 60);
|
||||
translate([MOTOR_MOUNT_X / 2, MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([-MOTOR_MOUNT_X / 2, MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([MOTOR_MOUNT_X / 2, -MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
translate([-MOTOR_MOUNT_X / 2, -MOTOR_MOUNT_Y / 2, 0]) motor_mount_void(D, Z);
|
||||
|
||||
translate([-8 + 12.5, 0, 0]) cube([7.5, 17, Z], center = true);
|
||||
}
|
||||
|
||||
translate([MOUNT_X / 2, MOUNT_Y / 2, 0]) mount_plate_void();
|
||||
translate([-MOUNT_X / 2, MOUNT_Y / 2, 0]) mount_plate_void();
|
||||
translate([MOUNT_X / 2, -MOUNT_Y / 2, 0]) mount_plate_void();
|
||||
translate([-MOUNT_X / 2,-MOUNT_Y / 2, 0]) mount_plate_void();
|
||||
translate([-8 + 12.5, 0, 0]) cube([7.5, 17, Z], center = true);
|
||||
|
||||
|
||||
translate([X_CORNER, Y_CORNER, 3.26 - .5]) cube([CORNER, CORNER, 8], center = true);
|
||||
translate([-X_CORNER, Y_CORNER, 3.26 - .5]) cube([CORNER, CORNER, 8], center = true);
|
||||
translate([X_CORNER, -Y_CORNER, 3.26 - .5]) cube([CORNER, CORNER, 8], center = true);
|
||||
|
@ -151,13 +175,25 @@ module mount_plate () {
|
|||
}
|
||||
translate([X_CORNER - (CORNER / 2), Y_CORNER - (CORNER / 2), 3.26 - .5]) cylinder(r = CORNER, h = 7, center = true, $fn = 40);
|
||||
translate([-X_CORNER + (CORNER / 2), Y_CORNER - (CORNER / 2), 3.26 - .5]) cylinder(r = CORNER, h = 7, center = true, $fn = 40);
|
||||
translate([X_CORNER - (CORNER / 2), -Y_CORNER + (CORNER / 2), 3.26 - .5]) cylinder(r = CORNER, h = 7, center = true, $fn = 40);
|
||||
translate([X_CORNER - (CORNER / 2), -Y_CORNER + (CORNER / 2), 3.26 - .5]) cylinder(r = CORNER, h = 7, center = true, $fn = 40);
|
||||
translate([-X_CORNER + (CORNER / 2), -Y_CORNER + (CORNER / 2), 3.26 - .5]) cylinder(r = CORNER, h = 7, center = true, $fn = 40);
|
||||
}
|
||||
|
||||
//centered, minimal geometry needed to add
|
||||
//58x52
|
||||
module minimal_mount () {
|
||||
difference () {
|
||||
mount_plate();
|
||||
translate([50 + 29, 0, 0]) cube([100, 100, 100], center = true);
|
||||
translate([-50 - 29, 0, 0]) cube([100, 100, 100], center = true);
|
||||
translate([0, 50 + 26, 0]) cube([100, 100, 100], center = true);
|
||||
translate([0, -50 - 26, 0]) cube([100, 100, 100], center = true);
|
||||
}
|
||||
}
|
||||
|
||||
module debug_assembled () {
|
||||
translate([(46 / 2) - 14.5, 0, 0]) rotate([180, 0, 0]) motor();
|
||||
color("green") translate([8, 0, 11]) mount_plate();
|
||||
color("green") translate([1, 0, 11]) mount_plate();
|
||||
color("blue") translate([0, 0, 23]) rotate([0, 0, -90]) magnetic_coupling();
|
||||
difference () {
|
||||
translate([0, 0, 26.5]) slip_coupling();
|
||||
|
@ -166,9 +202,7 @@ module debug_assembled () {
|
|||
color("red") translate([0, 0, 34]) daylight_spool_insert();
|
||||
}
|
||||
|
||||
//
|
||||
|
||||
PART = "mount_plate";
|
||||
PART = "magnetic_coupling";
|
||||
|
||||
if (PART == "slip_coupling") {
|
||||
slip_coupling();
|
||||
|
@ -180,4 +214,6 @@ if (PART == "slip_coupling") {
|
|||
daylight_spool_insert();
|
||||
} else if (PART == "debug") {
|
||||
debug_assembled();
|
||||
} else if (PART == "minimal_mount") {
|
||||
minimal_mount();
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue