summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--another.scad28
1 files changed, 2 insertions, 26 deletions
diff --git a/another.scad b/another.scad
index 2331003..9ff7f6a 100644
--- a/another.scad
+++ b/another.scad
@@ -1,503 +1,479 @@
1draft=true; 1draft=true;
2layer_height=0.2; extrusion_width=0.4; 2layer_height=0.2; extrusion_width=0.4;
3epsilon=0.01; 3epsilon=0.01;
4$fs=0.0125; 4$fs=0.0125;
5 5
6use <pushfittery.scad>; 6use <pushfittery.scad>;
7include <pushfit_data.scad>; 7include <pushfit_data.scad>;
8 8
9module the_extruder( 9module the_extruder(
10 // motor properties 10 // motor properties
11 gearbox_d = 36, 11 gearbox_d = 36,
12 mount_d = 28, // the distance between opposite mounting holes 12 mount_d = 28, // the distance between opposite mounting holes
13 mounthole_depth = 5, 13 mounthole_depth = 5,
14 mounthole_min_depth = 3, mounthole_max_depth = 4, 14 mounthole_min_depth = 3, mounthole_max_depth = 4,
15 protrusion_d = 22, protrusion_h = 2.2, // the dimensions of the protrusion on top of gearbox 15 protrusion_d = 22, protrusion_h = 2.2, // the dimensions of the protrusion on top of gearbox
16 bore_d = 8, bore_l = 17.6, 16 bore_d = 8, bore_l = 17.6,
17 bore_dd = 7, 17 bore_dd = 7,
18 // pulley properties 18 // pulley properties
19 pulley_d = 11.5, pulley_h=10, 19 pulley_d = 11.5, pulley_h=10,
20 pulley_elevation = 1, // pulley elevation above the protrusion 20 pulley_elevation = 1, // pulley elevation above the protrusion
21 teeth_elevation = 7.5, // distance from the bottom of the pulley to its teeth 21 teeth_elevation = 7.5, // distance from the bottom of the pulley to its teeth
22 filament_offset = (8.25-(3.0+3.5)/2) - 11.5/2 + 1.75/2, 22 filament_offset = (8.25-(3.0+3.5)/2) - 11.5/2 + 1.75/2,
23 // idler properties 23 // idler properties
24 idler_d = 9.5, idler_h = 4, idler_id = 3,// idler dimensions: outer and inner diameters and height 24 idler_d = 9.5, idler_h = 4, idler_id = 3,// idler dimensions: outer and inner diameters and height
25 // spring properties 25 // spring properties
26 spring_d = 10, spring_lc = 9.6, // spring diameter and compressed length 26 spring_d = 10, spring_lc = 9.6, // spring diameter and compressed length
27 // filament path properties 27 // filament path properties
28 filament_d = 1.75, 28 filament_d = 1.75,
29 filament_path_d = 2, 29 filament_path_d = 2,
30 filament_guide_d = 4, // PTFE filament guide diameter 30 filament_guide_d = 4, // PTFE filament guide diameter
31 // knob properties 31 // knob properties
32 knob_h = 10, 32 knob_h = 10,
33 knob_bore_l = 4, 33 knob_bore_l = 4,
34 knob_indent_d = 4, 34 knob_indent_d = 4,
35 knob_indents = 12, 35 knob_indents = 12,
36 // spring tensioner 36 // spring tensioner
37 st_nut_d = 9, st_nut_h = 4, 37 st_nut_d = 9, st_nut_h = 4,
38 st_screw_d = 5, 38 st_screw_d = 5,
39 st_thickshell = 8*extrusion_width, st_thinshell = 4*extrusion_width, 39 st_thickshell = 8*extrusion_width, st_thinshell = 4*extrusion_width,
40 40
41 // screw it 41 // screw it
42 mount_screw_d = 3.1, mount_screw_l = 20, 42 mount_screw_d = 3.1, mount_screw_l = 20,
43 mount_screwhead_d=6, mount_screwhead_h=3, 43 mount_screwhead_d=6, mount_screwhead_h=3,
44 idler_screw_d = 3, 44 idler_screw_d = 3,
45 idler_screwhead_d=6, idler_screwhead_h=3, 45 idler_screwhead_d=6, idler_screwhead_h=3,
46 46
47 pf = pushfit_embeddest, 47 pf = pushfit_embeddest,
48 pf_shell = max(3*layer_height,3*extrusion_width), 48 pf_shell = max(3*layer_height,3*extrusion_width),
49 pf_smooth = true, 49 pf_smooth = true,
50 50
51 // empty spaces 51 // empty spaces
52 idler_travel = 3, // how far should idler travel when pressed 52 idler_travel = 3, // how far should idler travel when pressed
53 idler_clearance=1, 53 idler_clearance=1,
54 pulley_d_clearance=2, 54 pulley_d_clearance=2,
55 pulley_small_d_clearance=0.5, 55 pulley_small_d_clearance=0.5,
56 lever_v_clearance=.7, // vertical clearance for the lever 56 lever_v_clearance=.7, // vertical clearance for the lever
57 spring_d_clearance=1, 57 spring_d_clearance=1,
58 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion 58 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion
59 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion 59 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion
60 mount_screw_d_tolerance=.4, 60 mount_screw_d_tolerance=.4,
61 idler_v_tolerance=.5, 61 idler_v_tolerance=.5,
62 knob_bore_d_tolerance=.6, 62 knob_bore_d_tolerance=.6,
63 st_nut_h_tolerance=.2, 63 st_nut_h_tolerance=.2,
64 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */ 64 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */
65 st_screw_d_tolerance=.5, 65 st_screw_d_tolerance=.5,
66 st_split_w_tolerance = .3, 66 st_split_w_tolerance = .3,
67 67
68 min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis. 68 min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis.
69 min_xy_shell = 2*extrusion_width, 69 min_xy_shell = 2*extrusion_width,
70 70
71 what="lever", // lever|body|knob|springpad|* 71 what="lever", // lever|body|knob|springpad|*
72 left=false, 72 left=false,
73 vitamins = true, 73 vitamins = true,
74 supports = false, bridges = true, 74 bridges = true,
75 tensioner = true, 75 tensioner = true,
76 debug = false 76 debug = false
77) { 77) {
78 fnd = 2*PI; fnr = 2*fnd; 78 fnd = 2*PI; fnr = 2*fnd;
79 79
80 idler_filament_offset = filament_path_d/2; // -filament_offset; 80 idler_filament_offset = filament_path_d/2; // -filament_offset;
81 lever_shell = mount_screwhead_h+0.5; 81 lever_shell = mount_screwhead_h+0.5;
82 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell); 82 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell);
83 lsd = idler_d-idler_clearance*2; // the diameter of lever thingie 83 lsd = idler_d-idler_clearance*2; // the diameter of lever thingie
84 longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell; 84 longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell;
85 shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2)) 85 shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2))
86 sqrt(c*c+pow(a-c,2)); 86 sqrt(c*c+pow(a-c,2));
87 longwing_travel = idler_travel*longwing/shortwing; 87 longwing_travel = idler_travel*longwing/shortwing;
88 h_ = (pulley_d+idler_d)/(2*sqrt(2)); 88 h_ = (pulley_d+idler_d)/(2*sqrt(2));
89 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) ); 89 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) );
90 spring_dl = idler_travel*longwing/ri; 90 spring_dl = idler_travel*longwing/ri;
91 // finger and spring support 91 // finger and spring support
92 fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2); 92 fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2);
93 93
94 mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1; 94 mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1;
95 mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1; 95 mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1;
96 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation; 96 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation;
97 ls_z = filament_elevation; // leverspace mid-z 97 ls_z = filament_elevation; // leverspace mid-z
98 ls_h = lever_thickness+lever_v_clearance; // leverspace height 98 ls_h = lever_thickness+lever_v_clearance; // leverspace height
99 mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell); 99 mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell);
100 body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2); 100 body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2);
101 echo("mount depth",mount_depth); 101 echo("mount depth",mount_depth);
102 102
103 module teardrop(r,d,h,center=false,angle=45) { 103 module teardrop(r,d,h,center=false,angle=45) {
104 dd = d ? d : (2*r); 104 dd = d ? d : (2*r);
105 $fn = dd*fnd; 105 $fn = dd*fnd;
106 cylinder(d=dd,h=h,center=center); 106 cylinder(d=dd,h=h,center=center);
107 if(angle>0) translate([0,0,center?-h/2:0]) 107 if(angle>0) translate([0,0,center?-h/2:0])
108 rotate([0,0,angle]) 108 rotate([0,0,angle])
109 cube(size=[d/2,d/2,h]); 109 cube(size=[d/2,d/2,h]);
110 } 110 }
111 111
112 module mirrorleft() { 112 module mirrorleft() {
113 mirror([left?0:1,0,0]) children(); 113 mirror([left?0:1,0,0]) children();
114 } 114 }
115 module place_idler() { 115 module place_idler() {
116 rotate([0,0,45]) 116 rotate([0,0,45])
117 translate([(pulley_d+idler_d)/2,0,0]) 117 translate([(pulley_d+idler_d)/2,0,0])
118 children(); 118 children();
119 } 119 }
120 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) { 120 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) {
121 if(depth) { 121 if(depth) {
122 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth); 122 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth);
123 rr = depth+hh; 123 rr = depth+hh;
124 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr); 124 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr);
125 }else if(r) { 125 }else if(r) {
126 hh=sqrt(pow(r,2)-pow(d,2)/4); 126 hh=sqrt(pow(r,2)-pow(d,2)/4);
127 translate([0,0,hh]) sphere(r=r,$fn=fnr*r); 127 translate([0,0,hh]) sphere(r=r,$fn=fnr*r);
128 } 128 }
129 } 129 }
130 130
131 % if(vitamins) mirrorleft() { 131 % if(vitamins) mirrorleft() {
132 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60); 132 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60);
133 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) 133 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0])
134 cylinder(d=mount_screw_d,h=20,$fn=30); 134 cylinder(d=mount_screw_d,h=20,$fn=30);
135 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30); 135 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30);
136 translate([0,0,protrusion_h]) { 136 translate([0,0,protrusion_h]) {
137 difference() { 137 difference() {
138 cylinder(d=bore_d,h=bore_l,$fn=30); 138 cylinder(d=bore_d,h=bore_l,$fn=30);
139 translate([-bore_d/2-1,bore_dd-bore_d/2,-1]) 139 translate([-bore_d/2-1,bore_dd-bore_d/2,-1])
140 cube([bore_d+2,bore_d/2,bore_l+2]); 140 cube([bore_d+2,bore_d/2,bore_l+2]);
141 } 141 }
142 translate([0,0,pulley_elevation]) { 142 translate([0,0,pulley_elevation]) {
143 cylinder(d=pulley_d,h=pulley_h,$fn=30); 143 cylinder(d=pulley_d,h=pulley_h,$fn=30);
144 translate([0,0,teeth_elevation]) { 144 translate([0,0,teeth_elevation]) {
145 place_idler() { 145 place_idler() {
146 cylinder(d=idler_d,h=idler_h,center=true,$fn=30); 146 cylinder(d=idler_d,h=idler_h,center=true,$fn=30);
147 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 147 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
148 }//place idler 148 }//place idler
149 // filament path 149 // filament path
150 rotate([0,0,45]) { 150 rotate([0,0,45]) {
151 translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) { 151 translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) {
152 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); 152 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15);
153 }//rotate translate 153 }//rotate translate
154 translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) { 154 translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) {
155 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); 155 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15);
156 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d]) 156 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d])
157 pushfit(pf); 157 pushfit(pf);
158 }//rotate translate 158 }//rotate translate
159 }//rotate 159 }//rotate
160 }//translate teeth 160 }//translate teeth
161 }//translate pulley 161 }//translate pulley
162 }//translate protrusion 162 }//translate protrusion
163 }//vitamins 163 }//vitamins
164 164
165 module lever() { 165 module lever() {
166 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) { 166 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) {
167 difference() { 167 difference() {
168 union() { 168 union() {
169 hull() { 169 hull() {
170 place_idler() 170 place_idler()
171 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 171 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
172 translate([mount_d/2,0,0]) 172 translate([mount_d/2,0,0])
173 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 173 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
174 }//hull 174 }//hull
175 hull() { 175 hull() {
176 translate([mount_d/2,0,0]) 176 translate([mount_d/2,0,0])
177 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 177 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
178 translate([mount_d/2,-longwing,0]) rotate([0,90,0]) 178 translate([mount_d/2,-longwing,0]) rotate([0,90,0])
179 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60); 179 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60);
180 }//hull 180 }//hull
181 }//union 181 }//union
182 182
183 // filament path 183 // filament path
184 place_idler() 184 place_idler()
185 translate([-idler_d/2-idler_filament_offset,0,0]) 185 translate([-idler_d/2-idler_filament_offset,0,0])
186 rotate([90,0,0]) { 186 rotate([90,0,0]) {
187 mirror([0,1,0]) 187 mirror([0,1,0])
188 teardrop(d=filament_path_d,h=3*gearbox_d,center=true); 188 teardrop(d=filament_path_d,h=3*gearbox_d,center=true);
189 translate([0,0, 189 translate([0,0,
190 sqrt(2)*(mount_d-pulley_d+lsd)/2 190 sqrt(2)*(mount_d-pulley_d+lsd)/2
191 ]) { 191 ]) {
192 cylinder(d1=filament_path_d,d2=2*filament_path_d, 192 cylinder(d1=filament_path_d,d2=2*filament_path_d,
193 h=filament_path_d,$fn=2*filament_path_d*fnd); 193 h=filament_path_d,$fn=2*filament_path_d*fnd);
194 translate([0,0,filament_path_d-epsilon]) 194 translate([0,0,filament_path_d-epsilon])
195 cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd); 195 cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd);
196 }//translate 196 }//translate
197 }//rotate translate place_idler 197 }//rotate translate place_idler
198 198
199 // idler space and mounting hole 199 // idler space and mounting hole
200 place_idler() { 200 place_idler() {
201 difference() { 201 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60);
202 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60);
203 if(supports) for(y=[-lsd/2+extrusion_width:(lsd-2*extrusion_width)/3:lsd/2-extrusion_width])
204 translate([-lsd/2-1,y-extrusion_width/2,-idler_h/2-idler_v_tolerance/2-1])
205 cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]);
206 }
207 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 202 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
208 translate([0,0,lever_thickness/2-idler_screwhead_h]) 203 translate([0,0,lever_thickness/2-idler_screwhead_h])
209 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d); 204 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d);
210 } 205 }
211 // mounting screw hole 206 // mounting screw hole
212 translate([mount_d/2,0,0]) 207 translate([mount_d/2,0,0])
213 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); 208 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d);
214 209
215 // lever end 210 // lever end
216 translate([mount_d/2,0,0]) rotate([0,90,0]) { 211 translate([mount_d/2,0,0]) rotate([0,90,0]) {
217 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); 212 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15);
218 translate([0,-longwing,0]) 213 translate([0,-longwing,0])
219 mirror([0,0,1]) 214 mirror([0,0,1])
220 difference() { 215 difference() {
221 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); 216 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance));
222 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 217 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
223 } 218 }
224 }//rotate-translate 219 }//rotate-translate
225 }//difference 220 }//difference
226 // bridging patch 221 // bridging patch
227 if(bridges) place_idler() 222 if(bridges) place_idler()
228 translate([0,0,lever_thickness/2-mount_screwhead_h]) 223 translate([0,0,lever_thickness/2-mount_screwhead_h])
229 mirror([0,0,1]) 224 mirror([0,0,1])
230 cylinder(d=mount_screwhead_d,h=layer_height); 225 cylinder(d=mount_screwhead_d,h=layer_height);
231 }//translate 226 }//translate
232 }//lever module 227 }//lever module
233 228
234 module body() { 229 module body() {
235 difference() { 230 difference() {
236 union() { 231 union() {
237 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); 232 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d);
238 // spring tensioner part 233 // spring tensioner part
239 translate([-gearbox_d/2,0,0]) hull() { 234 translate([-gearbox_d/2,0,0]) hull() {
240 translate([0,-longwing,ls_z]) 235 translate([0,-longwing,ls_z])
241 rotate([0,90,0]) 236 rotate([0,90,0])
242 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); 237 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness);
243 hh=body_h-ls_z; 238 hh=body_h-ls_z;
244 translate([0,0,ls_z]) 239 translate([0,0,ls_z])
245 mirror([0,1,0]) cube(size=[fsw,longwing+(st_thinshell+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]); 240 mirror([0,1,0]) cube(size=[fsw,longwing+(st_thinshell+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]);
246 hhh=ls_z; 241 hhh=ls_z;
247 translate([0,0,0]) 242 translate([0,0,0])
248 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); 243 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]);
249 }//hull translate 244 }//hull translate
250 245
251 // pushfit bracket 246 // pushfit bracket
252 translate([0,0,filament_elevation]) 247 translate([0,0,filament_elevation])
253 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 248 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
254 rotate([-90,0,0]) 249 rotate([-90,0,0])
255 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) { 250 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) {
256 pfbl = pf_h(pf)+gearbox_d/2; //TODO: 251 pfbl = pf_h(pf)+gearbox_d/2; //TODO:
257 if(pf_smooth) { 252 if(pf_smooth) {
258 pfbd = pf_d(pf)+2*pf_shell; 253 pfbd = pf_d(pf)+2*pf_shell;
259 hull() { 254 hull() {
260 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd); 255 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd);
261 translate([-epsilon/2,0,0]) { 256 translate([-epsilon/2,0,0]) {
262 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]); 257 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]);
263 mirror([0,1,0]) 258 mirror([0,1,0])
264 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]); 259 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]);
265 }//translate 260 }//translate
266 }//hull 261 }//hull
267 }else{ 262 }else{
268 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; 263 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2;
269 pfbd = pfb2a/cos(30); 264 pfbd = pfb2a/cos(30);
270 pfbs = pfb2a*tan(30); 265 pfbs = pfb2a*tan(30);
271 cylinder(d=pfbd,h=pfbl,$fn=6); 266 cylinder(d=pfbd,h=pfbl,$fn=6);
272 translate([-pfbs/2,0,0]) { 267 translate([-pfbs/2,0,0]) {
273 hull() { 268 hull() {
274 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); 269 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]);
275 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); 270 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]);
276 mirror([0,1,0]) 271 mirror([0,1,0])
277 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); 272 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]);
278 }//hull 273 }//hull
279 }//translate*/ 274 }//translate*/
280 }//if(pf_smooth) 275 }//if(pf_smooth)
281 }//translate rotate translate rotate translate 276 }//translate rotate translate rotate translate
282 }//union (first child of difference) 277 }//union (first child of difference)
283 278
284 // protrusion 279 // protrusion
285 translate([0,0,-1]) 280 translate([0,0,-1])
286 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); 281 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h));
287 // mount screw holes 282 // mount screw holes
288 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { 283 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) {
289 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)]) 284 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)])
290 mirror([0,0,1]) 285 mirror([0,0,1])
291 cylinder(d=mount_screw_d+mount_screw_d_tolerance, 286 cylinder(d=mount_screw_d+mount_screw_d_tolerance,
292 h=mount_screw_l-mount_depth+1, 287 h=mount_screw_l-mount_depth+1,
293 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); 288 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance));
294 translate([0,0,mount_screw_l-mount_depth]) 289 translate([0,0,mount_screw_l-mount_depth])
295 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); 290 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d);
296 }//for 291 }//for
297 // pushfit 292 // pushfit
298 pf_offset = mount_d/sqrt(2)/2+mount_screw_d; 293 pf_offset = mount_d/sqrt(2)/2+mount_screw_d;
299 translate([0,0,filament_elevation]) 294 translate([0,0,filament_elevation])
300 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 295 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
301 rotate([-90,0,0]) 296 rotate([-90,0,0])
302 translate([0,0,pf_offset]) 297 translate([0,0,pf_offset])
303 rotate([0,0,180]) { 298 rotate([0,0,180]) {
304 pushfit(pf); 299 pushfit(pf);
305 mirror([0,0,1]) { 300 mirror([0,0,1]) {
306 fh = 1.5* (filament_guide_d-filament_path_d)/2; 301 fh = 1.5* (filament_guide_d-filament_path_d)/2;
307 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh; 302 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh;
308 translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225); 303 translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225);
309 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225); 304 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225);
310 translate([0,0,fo+epsilon]) 305 translate([0,0,fo+epsilon])
311 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d); 306 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d);
312 }//mirror 307 }//mirror
313 }//rotate translate rotate translate rotate translate 308 }//rotate translate rotate translate rotate translate
314 // pulley 309 // pulley
315 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); 310 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance));
316 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance)); 311 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance));
317 312
318 translate([0,0,ls_z-ls_h/2]) { 313 translate([0,0,ls_z-ls_h/2]) {
319 // idler travel 314 // idler travel
320 translate([mount_d/2,0,0]) 315 translate([mount_d/2,0,0])
321 rotate([0,0,45]) 316 rotate([0,0,45])
322 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2)) 317 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2))
323 square([shortwing+(idler_d+idler_clearance)/2,ls_h]); 318 square([shortwing+(idler_d+idler_clearance)/2,ls_h]);
324 // idler itself 319 // idler itself
325 place_idler() 320 place_idler()
326 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); 321 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance));
327 // lever space 322 // lever space
328 rotate([0,0,45]) 323 rotate([0,0,45])
329 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1))) 324 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1)))
330 square([gearbox_d/2+1,ls_h]); 325 square([gearbox_d/2+1,ls_h]);
331 } 326 }
332 327
333 // back side cutout 328 // back side cutout
334 // XXX: this is somewhat ugly and potentially bugged, 329 // XXX: this is somewhat ugly and potentially bugged,
335 // but I want to sleep. 330 // but I want to sleep.
336 a0_ = atan( 331 a0_ = atan(
337 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2) 332 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2)
338 / 333 /
339 ( 334 (
340 pulley_d/2+filament_offset- 335 pulley_d/2+filament_offset-
341 (pf_d(pf)+2*pf_shell)/2/cos(30) 336 (pf_d(pf)+2*pf_shell)/2/cos(30)
342 ) 337 )
343 ); 338 );
344 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ ); 339 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ );
345 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); 340 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2));
346 translate([0,0,ls_z]) difference() { 341 translate([0,0,ls_z]) difference() {
347 rotate([0,0,-180+a0]) 342 rotate([0,0,-180+a0])
348 rotate_extrude(angle=a1-a0) 343 rotate_extrude(angle=a1-a0)
349 translate([0,-ls_h/2]) 344 translate([0,-ls_h/2])
350 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, 345 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1,
351 ls_h]); 346 ls_h]);
352 translate([-mount_d/2,0,0]) 347 translate([-mount_d/2,0,0])
353 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d)); 348 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d));
354 }//difference translate 349 }//difference translate
355 350
356 //translate([-mount_d/2,-longwing,filament_elevation]) 351 //translate([-mount_d/2,-longwing,filament_elevation])
357 if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ 352 if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */
358 translate([mount_d/2,-longwing,filament_elevation]) 353 translate([mount_d/2,-longwing,filament_elevation])
359 rotate([0,-90,0]) difference() { 354 rotate([0,-90,0]) difference() {
360 cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); 355 cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance));
361 translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 356 translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
362 } 357 }
363 358
364 // spring tensioner 359 // spring tensioner
365 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) { 360 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) {
366 if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { 361 if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else {
367 mirror([0,0,1]) { 362 mirror([0,0,1]) {
368 translate([0,0,st_thickshell]) 363 translate([0,0,st_thickshell])
369 hull() for(o=[0,spring_d]) translate([0,-o,0]) 364 hull() for(o=[0,spring_d]) translate([0,-o,0])
370 rotate([0,0,30]) 365 rotate([0,0,30])
371 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); 366 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6);
372 translate([0,0,-1]) cylinder(d=st_screw_d+st_screw_d_tolerance,h=fsw+2,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 367 translate([0,0,-1]) cylinder(d=st_screw_d+st_screw_d_tolerance,h=fsw+2,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
373 bigd = spring_d+spring_d_clearance; 368 bigd = spring_d+spring_d_clearance;
374 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; 369 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2;
375 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) { 370 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) {
376 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, 371 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd,
377 h=hf+epsilon, $fn=fnd*bigd); 372 h=hf+epsilon, $fn=fnd*bigd);
378 translate([0,-(st_thinshell+st_split_w_tolerance)/2,0]) 373 translate([0,-(st_thinshell+st_split_w_tolerance)/2,0])
379 cube(size=[body_h-ls_z+1,st_thinshell+st_split_w_tolerance,fsw+1]); 374 cube(size=[body_h-ls_z+1,st_thinshell+st_split_w_tolerance,fsw+1]);
380 } 375 }
381 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) 376 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon])
382 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); 377 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd);
383 } 378 }
384 } 379 }
385 } 380 }
386 381
387 }//difference 382 }//difference
388 383
389 if(supports) intersection() {
390 difference() {
391 translate([0,0,ls_z-ls_h/2-epsilon])
392 cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d);
393 cylinder(d=pulley_d+pulley_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance));
394 }
395 // supports
396 // TODO: hardcoded stuff below…
397 if(false) { // parallel
398 for(y=[-gearbox_d:4:gearbox_d])
399 translate([0,y-extrusion_width/2,0])
400 cube(size=[gearbox_d,extrusion_width,body_h]);
401 }else{ // radial
402 for(zr=[-65:(65+50)/7:50])
403 rotate([0,0,zr]) translate([0,-extrusion_width/2,0])
404 cube(size=[gearbox_d,extrusion_width,body_h]);
405 }
406 }
407
408 }//body module 384 }//body module
409 385
410 module springpad() { 386 module springpad() {
411 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; 387 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell;
412 bigd = spring_d+spring_d_clearance/2; 388 bigd = spring_d+spring_d_clearance/2;
413 hf = (bigd-smalld)/2; 389 hf = (bigd-smalld)/2;
414 h = hf*3.5; 390 h = hf*3.5;
415 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) 391 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation])
416 rotate([0,90,0]) difference() { 392 rotate([0,90,0]) difference() {
417 union() { 393 union() {
418 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); 394 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd);
419 translate([0,0,hf-epsilon]) 395 translate([0,0,hf-epsilon])
420 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); 396 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd);
421 translate([0,0,h]) 397 translate([0,0,h])
422 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 398 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
423 l = body_h-ls_z; 399 l = body_h-ls_z;
424 w = st_thinshell; 400 w = st_thinshell;
425 hull() translate([0,-st_thinshell/2,0]) mirror([1,0,0]) { 401 hull() translate([0,-st_thinshell/2,0]) mirror([1,0,0]) {
426 translate([0,0,w]) 402 translate([0,0,w])
427 cube(size=[l,st_thinshell,w]); 403 cube(size=[l,st_thinshell,w]);
428 cube(size=[l-w,st_thinshell,2*w]); 404 cube(size=[l-w,st_thinshell,2*w]);
429 } 405 }
430 } 406 }
431 translate([0,0,-epsilon]) 407 translate([0,0,-epsilon])
432 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 408 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
433 } 409 }
434 } 410 }
435 411
436 module knob() { 412 module knob() {
437 ch = knob_indent_d/2; 413 ch = knob_indent_d/2;
438 translate([0,0,body_h+epsilon]) { 414 translate([0,0,body_h+epsilon]) {
439 mirror([0,0,1]) translate([0,0,-epsilon]) { 415 mirror([0,0,1]) translate([0,0,-epsilon]) {
440 difference() { 416 difference() {
441 cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); 417 cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d);
442 translate([0,0,-1]) difference() { 418 translate([0,0,-1]) difference() {
443 cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); 419 cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2);
444 translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) 420 translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1])
445 cube([bore_d+2,bore_d/2,knob_bore_l+4]); 421 cube([bore_d+2,bore_d/2,knob_bore_l+4]);
446 } 422 }
447 } 423 }
448 } 424 }
449 difference() { 425 difference() {
450 union() { 426 union() {
451 cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); 427 cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d);
452 translate([0,0,ch]) 428 translate([0,0,ch])
453 cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); 429 cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d);
454 translate([0,0,knob_h-ch]) 430 translate([0,0,knob_h-ch])
455 cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d); 431 cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d);
456 } 432 }
457 for(a=[0:360/knob_indents:359]) rotate([0,0,a]) 433 for(a=[0:360/knob_indents:359]) rotate([0,0,a])
458 translate([0,gearbox_d/2,-1]) 434 translate([0,gearbox_d/2,-1])
459 cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); 435 cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d);
460 } 436 }
461 } 437 }
462 }//knob module 438 }//knob module
463 439
464 module debug() { 440 module debug() {
465 difference() { 441 difference() {
466 children(); 442 children();
467 if(debug) { 443 if(debug) {
468 // spring tensioner debug cutout 444 // spring tensioner debug cutout
469 if(tensioner) // TODO: collapse copypasted transformations 445 if(tensioner) // TODO: collapse copypasted transformations
470 translate([-gearbox_d/2,0,0]) 446 translate([-gearbox_d/2,0,0])
471 translate([0,-longwing,ls_z]) rotate([0,-90,0]) 447 translate([0,-longwing,ls_z]) rotate([0,-90,0])
472 translate([0,-lever_thickness/2-1,-gearbox_d]) 448 translate([0,-lever_thickness/2-1,-gearbox_d])
473 cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); 449 cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]);
474 // lever axis debug cutout 450 // lever axis debug cutout
475 translate([mount_d/2,0,-1]) 451 translate([mount_d/2,0,-1])
476 rotate([0,0,-45]) 452 rotate([0,0,-45])
477 cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]); 453 cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]);
478 // idler debug cutout 454 // idler debug cutout
479 translate([0,0,ls_z]) 455 translate([0,0,ls_z])
480 place_idler() 456 place_idler()
481 rotate([0,0,-45]) 457 rotate([0,0,-45])
482 translate([0,0,-lever_thickness/2-epsilon]) 458 translate([0,0,-lever_thickness/2-epsilon])
483 cube(size=[(idler_d+idler_clearance)/2,(idler_d+idler_clearance)/2, 459 cube(size=[(idler_d+idler_clearance)/2,(idler_d+idler_clearance)/2,
484 lever_thickness+2*epsilon]); 460 lever_thickness+2*epsilon]);
485 // pushfit debug cutout 461 // pushfit debug cutout
486 place_idler() 462 place_idler()
487 translate([-idler_d/2+filament_offset,0,ls_z]) 463 translate([-idler_d/2+filament_offset,0,ls_z])
488 cube(size=[gearbox_d/2,gearbox_d/2+pf_h(pf),body_h-ls_z+1]); 464 cube(size=[gearbox_d/2,gearbox_d/2+pf_h(pf),body_h-ls_z+1]);
489 }//if debug 465 }//if debug
490 }//difference 466 }//difference
491 } 467 }
492 468
493 mirrorleft() 469 mirrorleft()
494 debug() 470 debug()
495 if(what=="lever") color("green",0.7) lever(); 471 if(what=="lever") color("green",0.7) lever();
496 else if(what=="body") color("yellow",0.7) body(); 472 else if(what=="body") color("yellow",0.7) body();
497 else if(what=="knob") color("red",0.7) knob(); 473 else if(what=="knob") color("red",0.7) knob();
498 else if(what=="springpad") color("blue",0.7) springpad(); 474 else if(what=="springpad") color("blue",0.7) springpad();
499 else if(what=="both") { 475 else if(what=="both") {
500 color("green",0.7) lever(); 476 color("green",0.7) lever();
501 color("yellow",0.7) body(); 477 color("yellow",0.7) body();
502 }else{ 478 }else{
503 color("green",0.7) lever(); 479 color("green",0.7) lever();