summaryrefslogtreecommitdiff
path: root/another.scad
Unidiff
Diffstat (limited to 'another.scad') (more/less context) (show whitespace changes)
-rw-r--r--another.scad1
1 files changed, 0 insertions, 1 deletions
diff --git a/another.scad b/another.scad
index b2e6c74..2331003 100644
--- a/another.scad
+++ b/another.scad
@@ -136,376 +136,375 @@ module the_extruder(
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 difference() {
202 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]) 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]) 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]); 205 cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]);
206 } 206 }
207 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 207 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
208 translate([0,0,lever_thickness/2-idler_screwhead_h]) 208 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); 209 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d);
210 } 210 }
211 // mounting screw hole 211 // mounting screw hole
212 translate([mount_d/2,0,0]) 212 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); 213 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d);
214 214
215 // lever end 215 // lever end
216 translate([mount_d/2,0,0]) rotate([0,90,0]) { 216 translate([mount_d/2,0,0]) rotate([0,90,0]) {
217 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); 217 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15);
218 translate([0,-longwing,0]) 218 translate([0,-longwing,0])
219 mirror([0,0,1]) 219 mirror([0,0,1])
220 difference() { 220 difference() {
221 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); 221 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); 222 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
223 } 223 }
224 }//rotate-translate 224 }//rotate-translate
225 }//difference 225 }//difference
226 // bridging patch 226 // bridging patch
227 if(bridges) place_idler() 227 if(bridges) place_idler()
228 translate([0,0,lever_thickness/2-mount_screwhead_h]) 228 translate([0,0,lever_thickness/2-mount_screwhead_h])
229 mirror([0,0,1]) 229 mirror([0,0,1])
230 cylinder(d=mount_screwhead_d,h=layer_height); 230 cylinder(d=mount_screwhead_d,h=layer_height);
231 }//translate 231 }//translate
232 }//lever module 232 }//lever module
233 233
234 module body() { 234 module body() {
235 difference() { 235 difference() {
236 union() { 236 union() {
237 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); 237 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d);
238 // spring tensioner part 238 // spring tensioner part
239 translate([-gearbox_d/2,0,0]) hull() { 239 translate([-gearbox_d/2,0,0]) hull() {
240 translate([0,-longwing,ls_z]) 240 translate([0,-longwing,ls_z])
241 rotate([0,90,0]) 241 rotate([0,90,0])
242 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); 242 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness);
243 hh=body_h-ls_z; 243 hh=body_h-ls_z;
244 translate([0,0,ls_z]) 244 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]); 245 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; 246 hhh=ls_z;
247 translate([0,0,0]) 247 translate([0,0,0])
248 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); 248 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]);
249 }//hull translate 249 }//hull translate
250 250
251 // pushfit bracket 251 // pushfit bracket
252 translate([0,0,filament_elevation]) 252 translate([0,0,filament_elevation])
253 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 253 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
254 rotate([-90,0,0]) 254 rotate([-90,0,0])
255 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) { 255 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) {
256 pfbl = pf_h(pf)+gearbox_d/2; //TODO: 256 pfbl = pf_h(pf)+gearbox_d/2; //TODO:
257 if(pf_smooth) { 257 if(pf_smooth) {
258 pfbd = pf_d(pf)+2*pf_shell; 258 pfbd = pf_d(pf)+2*pf_shell;
259 hull() { 259 hull() {
260 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd); 260 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd);
261 translate([-epsilon/2,0,0]) { 261 translate([-epsilon/2,0,0]) {
262 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]); 262 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]);
263 mirror([0,1,0]) 263 mirror([0,1,0])
264 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]); 264 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]);
265 }//translate 265 }//translate
266 }//hull 266 }//hull
267 }else{ 267 }else{
268 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; 268 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2;
269 pfbd = pfb2a/cos(30); 269 pfbd = pfb2a/cos(30);
270 pfbs = pfb2a*tan(30); 270 pfbs = pfb2a*tan(30);
271 cylinder(d=pfbd,h=pfbl,$fn=6); 271 cylinder(d=pfbd,h=pfbl,$fn=6);
272 translate([-pfbs/2,0,0]) { 272 translate([-pfbs/2,0,0]) {
273 hull() { 273 hull() {
274 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); 274 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]);
275 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); 275 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]);
276 mirror([0,1,0]) 276 mirror([0,1,0])
277 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); 277 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]);
278 }//hull 278 }//hull
279 }//translate*/ 279 }//translate*/
280 }//if(pf_smooth) 280 }//if(pf_smooth)
281 }//translate rotate translate rotate translate 281 }//translate rotate translate rotate translate
282 }//union (first child of difference) 282 }//union (first child of difference)
283 283
284 // protrusion 284 // protrusion
285 translate([0,0,-1]) 285 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)); 286 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 287 // mount screw holes
288 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { 288 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)]) 289 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)])
290 mirror([0,0,1]) 290 mirror([0,0,1])
291 cylinder(d=mount_screw_d+mount_screw_d_tolerance, 291 cylinder(d=mount_screw_d+mount_screw_d_tolerance,
292 h=mount_screw_l-mount_depth+1, 292 h=mount_screw_l-mount_depth+1,
293 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); 293 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance));
294 translate([0,0,mount_screw_l-mount_depth]) 294 translate([0,0,mount_screw_l-mount_depth])
295 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); 295 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d);
296 }//for 296 }//for
297 // pushfit 297 // pushfit
298 pf_offset = mount_d/sqrt(2)/2+mount_screw_d; 298 pf_offset = mount_d/sqrt(2)/2+mount_screw_d;
299 translate([0,0,filament_elevation]) 299 translate([0,0,filament_elevation])
300 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 300 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
301 rotate([-90,0,0]) 301 rotate([-90,0,0])
302 translate([0,0,pf_offset]) 302 translate([0,0,pf_offset])
303 rotate([0,0,180]) { 303 rotate([0,0,180]) {
304 pushfit(pf); 304 pushfit(pf);
305 mirror([0,0,1]) { 305 mirror([0,0,1]) {
306 fh = 1.5* (filament_guide_d-filament_path_d)/2; 306 fh = 1.5* (filament_guide_d-filament_path_d)/2;
307 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh; 307 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); 308 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); 309 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225);
310 translate([0,0,fo+epsilon]) 310 translate([0,0,fo+epsilon])
311 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d); 311 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d);
312 }//mirror 312 }//mirror
313 }//rotate translate rotate translate rotate translate 313 }//rotate translate rotate translate rotate translate
314 // pulley 314 // pulley
315 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); 315 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)); 316 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance));
317 317
318 translate([0,0,ls_z-ls_h/2]) { 318 translate([0,0,ls_z-ls_h/2]) {
319 // idler travel 319 // idler travel
320 translate([mount_d/2,0,0]) 320 translate([mount_d/2,0,0])
321 rotate([0,0,45]) 321 rotate([0,0,45])
322 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2)) 322 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2))
323 square([shortwing+(idler_d+idler_clearance)/2,ls_h]); 323 square([shortwing+(idler_d+idler_clearance)/2,ls_h]);
324 // idler itself 324 // idler itself
325 place_idler() 325 place_idler()
326 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); 326 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance));
327 // lever space 327 // lever space
328 echo(atan(1-2*fsw/gearbox_d));
329 rotate([0,0,45]) 328 rotate([0,0,45])
330 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1))) 329 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1)))
331 square([gearbox_d/2+1,ls_h]); 330 square([gearbox_d/2+1,ls_h]);
332 } 331 }
333 332
334 // back side cutout 333 // back side cutout
335 // XXX: this is somewhat ugly and potentially bugged, 334 // XXX: this is somewhat ugly and potentially bugged,
336 // but I want to sleep. 335 // but I want to sleep.
337 a0_ = atan( 336 a0_ = atan(
338 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2) 337 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2)
339 / 338 /
340 ( 339 (
341 pulley_d/2+filament_offset- 340 pulley_d/2+filament_offset-
342 (pf_d(pf)+2*pf_shell)/2/cos(30) 341 (pf_d(pf)+2*pf_shell)/2/cos(30)
343 ) 342 )
344 ); 343 );
345 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ ); 344 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ );
346 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); 345 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2));
347 translate([0,0,ls_z]) difference() { 346 translate([0,0,ls_z]) difference() {
348 rotate([0,0,-180+a0]) 347 rotate([0,0,-180+a0])
349 rotate_extrude(angle=a1-a0) 348 rotate_extrude(angle=a1-a0)
350 translate([0,-ls_h/2]) 349 translate([0,-ls_h/2])
351 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, 350 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1,
352 ls_h]); 351 ls_h]);
353 translate([-mount_d/2,0,0]) 352 translate([-mount_d/2,0,0])
354 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d)); 353 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d));
355 }//difference translate 354 }//difference translate
356 355
357 //translate([-mount_d/2,-longwing,filament_elevation]) 356 //translate([-mount_d/2,-longwing,filament_elevation])
358 if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ 357 if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */
359 translate([mount_d/2,-longwing,filament_elevation]) 358 translate([mount_d/2,-longwing,filament_elevation])
360 rotate([0,-90,0]) difference() { 359 rotate([0,-90,0]) difference() {
361 cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); 360 cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance));
362 translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 361 translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
363 } 362 }
364 363
365 // spring tensioner 364 // spring tensioner
366 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) { 365 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) {
367 if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { 366 if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else {
368 mirror([0,0,1]) { 367 mirror([0,0,1]) {
369 translate([0,0,st_thickshell]) 368 translate([0,0,st_thickshell])
370 hull() for(o=[0,spring_d]) translate([0,-o,0]) 369 hull() for(o=[0,spring_d]) translate([0,-o,0])
371 rotate([0,0,30]) 370 rotate([0,0,30])
372 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); 371 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6);
373 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)); 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));
374 bigd = spring_d+spring_d_clearance; 373 bigd = spring_d+spring_d_clearance;
375 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; 374 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2;
376 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) { 375 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) {
377 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, 376 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd,
378 h=hf+epsilon, $fn=fnd*bigd); 377 h=hf+epsilon, $fn=fnd*bigd);
379 translate([0,-(st_thinshell+st_split_w_tolerance)/2,0]) 378 translate([0,-(st_thinshell+st_split_w_tolerance)/2,0])
380 cube(size=[body_h-ls_z+1,st_thinshell+st_split_w_tolerance,fsw+1]); 379 cube(size=[body_h-ls_z+1,st_thinshell+st_split_w_tolerance,fsw+1]);
381 } 380 }
382 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) 381 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon])
383 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); 382 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd);
384 } 383 }
385 } 384 }
386 } 385 }
387 386
388 }//difference 387 }//difference
389 388
390 if(supports) intersection() { 389 if(supports) intersection() {
391 difference() { 390 difference() {
392 translate([0,0,ls_z-ls_h/2-epsilon]) 391 translate([0,0,ls_z-ls_h/2-epsilon])
393 cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); 392 cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d);
394 cylinder(d=pulley_d+pulley_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); 393 cylinder(d=pulley_d+pulley_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance));
395 } 394 }
396 // supports 395 // supports
397 // TODO: hardcoded stuff below… 396 // TODO: hardcoded stuff below…
398 if(false) { // parallel 397 if(false) { // parallel
399 for(y=[-gearbox_d:4:gearbox_d]) 398 for(y=[-gearbox_d:4:gearbox_d])
400 translate([0,y-extrusion_width/2,0]) 399 translate([0,y-extrusion_width/2,0])
401 cube(size=[gearbox_d,extrusion_width,body_h]); 400 cube(size=[gearbox_d,extrusion_width,body_h]);
402 }else{ // radial 401 }else{ // radial
403 for(zr=[-65:(65+50)/7:50]) 402 for(zr=[-65:(65+50)/7:50])
404 rotate([0,0,zr]) translate([0,-extrusion_width/2,0]) 403 rotate([0,0,zr]) translate([0,-extrusion_width/2,0])
405 cube(size=[gearbox_d,extrusion_width,body_h]); 404 cube(size=[gearbox_d,extrusion_width,body_h]);
406 } 405 }
407 } 406 }
408 407
409 }//body module 408 }//body module
410 409
411 module springpad() { 410 module springpad() {
412 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; 411 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell;
413 bigd = spring_d+spring_d_clearance/2; 412 bigd = spring_d+spring_d_clearance/2;
414 hf = (bigd-smalld)/2; 413 hf = (bigd-smalld)/2;
415 h = hf*3.5; 414 h = hf*3.5;
416 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) 415 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation])
417 rotate([0,90,0]) difference() { 416 rotate([0,90,0]) difference() {
418 union() { 417 union() {
419 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); 418 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd);
420 translate([0,0,hf-epsilon]) 419 translate([0,0,hf-epsilon])
421 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); 420 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd);
422 translate([0,0,h]) 421 translate([0,0,h])
423 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 422 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
424 l = body_h-ls_z; 423 l = body_h-ls_z;
425 w = st_thinshell; 424 w = st_thinshell;
426 hull() translate([0,-st_thinshell/2,0]) mirror([1,0,0]) { 425 hull() translate([0,-st_thinshell/2,0]) mirror([1,0,0]) {
427 translate([0,0,w]) 426 translate([0,0,w])
428 cube(size=[l,st_thinshell,w]); 427 cube(size=[l,st_thinshell,w]);
429 cube(size=[l-w,st_thinshell,2*w]); 428 cube(size=[l-w,st_thinshell,2*w]);
430 } 429 }
431 } 430 }
432 translate([0,0,-epsilon]) 431 translate([0,0,-epsilon])
433 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 432 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
434 } 433 }
435 } 434 }
436 435
437 module knob() { 436 module knob() {
438 ch = knob_indent_d/2; 437 ch = knob_indent_d/2;
439 translate([0,0,body_h+epsilon]) { 438 translate([0,0,body_h+epsilon]) {
440 mirror([0,0,1]) translate([0,0,-epsilon]) { 439 mirror([0,0,1]) translate([0,0,-epsilon]) {
441 difference() { 440 difference() {
442 cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); 441 cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d);
443 translate([0,0,-1]) difference() { 442 translate([0,0,-1]) difference() {
444 cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); 443 cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2);
445 translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) 444 translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1])
446 cube([bore_d+2,bore_d/2,knob_bore_l+4]); 445 cube([bore_d+2,bore_d/2,knob_bore_l+4]);
447 } 446 }
448 } 447 }
449 } 448 }
450 difference() { 449 difference() {
451 union() { 450 union() {
452 cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); 451 cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d);
453 translate([0,0,ch]) 452 translate([0,0,ch])
454 cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); 453 cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d);
455 translate([0,0,knob_h-ch]) 454 translate([0,0,knob_h-ch])
456 cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d); 455 cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d);
457 } 456 }
458 for(a=[0:360/knob_indents:359]) rotate([0,0,a]) 457 for(a=[0:360/knob_indents:359]) rotate([0,0,a])
459 translate([0,gearbox_d/2,-1]) 458 translate([0,gearbox_d/2,-1])
460 cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); 459 cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d);
461 } 460 }
462 } 461 }
463 }//knob module 462 }//knob module
464 463
465 module debug() { 464 module debug() {
466 difference() { 465 difference() {
467 children(); 466 children();
468 if(debug) { 467 if(debug) {
469 // spring tensioner debug cutout 468 // spring tensioner debug cutout
470 if(tensioner) // TODO: collapse copypasted transformations 469 if(tensioner) // TODO: collapse copypasted transformations
471 translate([-gearbox_d/2,0,0]) 470 translate([-gearbox_d/2,0,0])
472 translate([0,-longwing,ls_z]) rotate([0,-90,0]) 471 translate([0,-longwing,ls_z]) rotate([0,-90,0])
473 translate([0,-lever_thickness/2-1,-gearbox_d]) 472 translate([0,-lever_thickness/2-1,-gearbox_d])
474 cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); 473 cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]);
475 // lever axis debug cutout 474 // lever axis debug cutout
476 translate([mount_d/2,0,-1]) 475 translate([mount_d/2,0,-1])
477 rotate([0,0,-45]) 476 rotate([0,0,-45])
478 cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]); 477 cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]);
479 // idler debug cutout 478 // idler debug cutout
480 translate([0,0,ls_z]) 479 translate([0,0,ls_z])
481 place_idler() 480 place_idler()
482 rotate([0,0,-45]) 481 rotate([0,0,-45])
483 translate([0,0,-lever_thickness/2-epsilon]) 482 translate([0,0,-lever_thickness/2-epsilon])
484 cube(size=[(idler_d+idler_clearance)/2,(idler_d+idler_clearance)/2, 483 cube(size=[(idler_d+idler_clearance)/2,(idler_d+idler_clearance)/2,
485 lever_thickness+2*epsilon]); 484 lever_thickness+2*epsilon]);
486 // pushfit debug cutout 485 // pushfit debug cutout
487 place_idler() 486 place_idler()
488 translate([-idler_d/2+filament_offset,0,ls_z]) 487 translate([-idler_d/2+filament_offset,0,ls_z])
489 cube(size=[gearbox_d/2,gearbox_d/2+pf_h(pf),body_h-ls_z+1]); 488 cube(size=[gearbox_d/2,gearbox_d/2+pf_h(pf),body_h-ls_z+1]);
490 }//if debug 489 }//if debug
491 }//difference 490 }//difference
492 } 491 }
493 492
494 mirrorleft() 493 mirrorleft()
495 debug() 494 debug()
496 if(what=="lever") color("green",0.7) lever(); 495 if(what=="lever") color("green",0.7) lever();
497 else if(what=="body") color("yellow",0.7) body(); 496 else if(what=="body") color("yellow",0.7) body();
498 else if(what=="knob") color("red",0.7) knob(); 497 else if(what=="knob") color("red",0.7) knob();
499 else if(what=="springpad") color("blue",0.7) springpad(); 498 else if(what=="springpad") color("blue",0.7) springpad();
500 else if(what=="both") { 499 else if(what=="both") {
501 color("green",0.7) lever(); 500 color("green",0.7) lever();
502 color("yellow",0.7) body(); 501 color("yellow",0.7) body();
503 }else{ 502 }else{
504 color("green",0.7) lever(); 503 color("green",0.7) lever();
505 color("yellow",0.7) body(); 504 color("yellow",0.7) body();
506 color("red",0.7) knob(); 505 color("red",0.7) knob();
507 color("blue",0.7) springpad(); 506 color("blue",0.7) springpad();
508 } 507 }
509} 508}
510 509
511the_extruder(what="*",left=false,debug=true); 510the_extruder(what="*",left=false,debug=true);