21. perfect full caster-standoff
[challenge-bot] / 3d-printables / caster-standoff.scad
index dae0ccfbd147973e5abe9476559a02bc3adb08ef..322f502be8f33027f49178ea3357dee1aa2f4d0b 100644 (file)
@@ -7,8 +7,21 @@
 // use 10 ish for development, 60 or so for printing
 $fn = 60;
 
-standoff_radius = 14.732 / 2; // 0.580 / 2 inches from spec sheet
-standoff_height = 48; // eyeballed
+/* measured with calipers */
+ball_diameter = 12.7 + 0.80; // extra bit added for printing imprecision
+ball_radius = ball_diameter / 2;
+
+wall_thickness = 1;
+holder_floor = 3;
+holder_arms_length = 10;
+holder_height =
+  holder_floor + holder_arms_length + (11 / 16) * ball_diameter;
+
+holder_radius = ball_radius + wall_thickness;
+holder_diameter = holder_radius * 2;
+
+standoff_radius = holder_radius; // 0.580 / 2 inches from spec sheet
+standoff_height = 48 - holder_height; // eyeballed
 
 // eyeballed caster flange height, (0.580/5) inches, times 2 to be stronger
 caster_flange_height = 5;
@@ -44,35 +57,24 @@ module deck_flange_reinforcement(){
                 deck_flange_height * 1.1, // 1.1 is bigger than 1
                 deck_flange_radius]);}}}}}
 
+module ball_holder(){
+  gap = wall_thickness * 4;
+  difference (){
+    cylinder(r = holder_radius, h = holder_height);
+    translate([0, 0, ball_radius + holder_floor + holder_arms_length]){
+      sphere(r = ball_radius);}
+    translate([0, 0, holder_floor + (holder_height - holder_floor) / 2 + 0.5]){
+      cube([holder_diameter + 0.1, gap, holder_height - holder_floor + 0.1],
+           center = true);}}}
+
 module caster_standoff(){
-  cylinder(h = standoff_height - caster_flange_height,
+  cylinder(h = standoff_height,
            r = standoff_radius);
   deck_flange();
   for(ii = [0:3]){
     rotate([0, 0, 45 + 90 * ii])
       deck_flange_reinforcement();}
-  caster_deck_interlock_solid();}
-
-module ball_holder(){
-  /* measured with calipers */
-  ball_diameter = 12.7 + 0.5;
-  ball_radius = ball_diameter / 2;
-
-  wall_thickness = 1.5;
-  holder_height = ball_radius + wall_thickness * 2;
-
-  holder_outer_radius = ball_radius + wall_thickness;
-  holder_outer_diameter = holder_outer_radius * 2;
-
-  difference (){
-    cylinder(r = holder_outer_radius, h = holder_height);
-    translate([0, 0, ball_radius + wall_thickness]){
-      sphere(r = ball_radius);}
-    translate([0, 0, holder_height / 2 + wall_thickness]){
-      cube([holder_outer_diameter + 0.1,
-            wall_thickness * 2,
-            holder_height],
-           center = true);}}}
+  translate([0, 0, standoff_height]){
+    ball_holder();}}
 
-ball_holder();
-//caster_standoff();
+caster_standoff();