author | Michael Krelin <hacker@klever.net> | 2018-08-02 19:27:56 (UTC) |
---|---|---|
committer | Michael Krelin <hacker@klever.net> | 2018-08-02 19:27:56 (UTC) |
commit | 0ece6b3161f5cdbe1cdcf961fb77a8c95ab3def0 (patch) (unidiff) | |
tree | 40a93fa9b5fdf5cd73dde685be981885e98691e7 | |
parent | cdf558c4db0725192311d437a74a60090c984634 (diff) | |
download | extrudery-0ece6b3161f5cdbe1cdcf961fb77a8c95ab3def0.zip extrudery-0ece6b3161f5cdbe1cdcf961fb77a8c95ab3def0.tar.gz extrudery-0ece6b3161f5cdbe1cdcf961fb77a8c95ab3def0.tar.bz2 |
comments
-rw-r--r-- | another.scad | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/another.scad b/another.scad index ddca898..5a590db 100644 --- a/another.scad +++ b/another.scad | |||
@@ -229,73 +229,74 @@ module the_extruder( | |||
229 | // pushfit bracket | 229 | // pushfit bracket |
230 | translate([0,0,filament_elevation]) | 230 | translate([0,0,filament_elevation]) |
231 | rotate([0,0,45]) translate([pulley_d/2,0,0]) | 231 | rotate([0,0,45]) translate([pulley_d/2,0,0]) |
232 | rotate([-90,0,0]) | 232 | rotate([-90,0,0]) |
233 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) | 233 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) |
234 | cylinder(r=min(body_h-filament_elevation,filament_elevation)/sin(60)-epsilon,h=pf_h(pf)+gearbox_d/2/*TODO:*/,$fn=6); | 234 | cylinder(r=min(body_h-filament_elevation,filament_elevation)/sin(60)-epsilon,h=pf_h(pf)+gearbox_d/2/*TODO:*/,$fn=6); |
235 | }//union (first child of difference) | 235 | }//union (first child of difference) |
236 | 236 | ||
237 | // protrusion | 237 | // protrusion |
238 | translate([0,0,-1]) | 238 | translate([0,0,-1]) |
239 | cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); | 239 | cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); |
240 | // mount screw holes | 240 | // mount screw holes |
241 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { | 241 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { |
242 | translate([0,0,mount_screw_l-mounthole_depth/2-layer_height-1]) | 242 | translate([0,0,mount_screw_l-mounthole_depth/2-layer_height-1]) |
243 | mirror([0,0,1]) | 243 | mirror([0,0,1]) |
244 | cylinder(d=mount_screw_d+mount_screw_d_tolerance, | 244 | cylinder(d=mount_screw_d+mount_screw_d_tolerance, |
245 | h=mount_screw_l-mounthole_depth/2-layer_height+1, | 245 | h=mount_screw_l-mounthole_depth/2-layer_height+1, |
246 | $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); | 246 | $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); |
247 | translate([0,0,mount_screw_l-mounthole_depth/2]) | 247 | translate([0,0,mount_screw_l-mounthole_depth/2]) |
248 | cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); | 248 | cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); |
249 | }//for | 249 | }//for |
250 | // pushfit | 250 | // pushfit |
251 | translate([0,0,filament_elevation]) | 251 | translate([0,0,filament_elevation]) |
252 | rotate([0,0,45]) translate([pulley_d/2,0,0]) | 252 | rotate([0,0,45]) translate([pulley_d/2,0,0]) |
253 | rotate([-90,0,0]) | 253 | rotate([-90,0,0]) |
254 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d+epsilon]) | 254 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d+epsilon]) |
255 | rotate([0,0,180]) { | 255 | rotate([0,0,180]) { |
256 | pushfit(pf); | 256 | pushfit(pf); |
257 | cylinder(d=filament_guide_d,h=gearbox_d,center=true,$fn=fnd*filament_guide_d); | 257 | cylinder(d=filament_guide_d,h=gearbox_d,center=true,$fn=fnd*filament_guide_d); |
258 | translate([0,-filament_guide_d/2/sqrt(2),0]) | 258 | translate([0,-filament_guide_d/2/sqrt(2),0]) |
259 | rotate([0,0,45]) | 259 | rotate([0,0,45]) |
260 | cube(size=[filament_guide_d/2,filament_guide_d/2,gearbox_d],center=true); | 260 | cube(size=[filament_guide_d/2,filament_guide_d/2,gearbox_d],center=true); |
261 | } | 261 | }//rotate translate rotate translate rotate translate |
262 | // pulley | 262 | // pulley |
263 | cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); | 263 | cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); |
264 | // leverspace | 264 | // leverspace |
265 | hull() for(x=[0,gearbox_d]) | 265 | hull() for(x=[0,gearbox_d]) |
266 | rotate([0,0,45]) | 266 | rotate([0,0,45]) |
267 | translate([x,0,ls_z-ls_h/2]) | 267 | translate([x,0,ls_z-ls_h/2]) |
268 | cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); | 268 | cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); |
269 | 269 | ||
270 | // idler clearance | ||
270 | a=cos(45)*(pulley_d+idler_d)/2; | 271 | a=cos(45)*(pulley_d+idler_d)/2; |
271 | b=mount_d/2-a; | 272 | b=mount_d/2-a; |
272 | x=sqrt(pow(a,2)+pow(b,2)); | 273 | x=sqrt(pow(a,2)+pow(b,2)); |
273 | translate([mount_d/2,0,ls_z]) | 274 | translate([mount_d/2,0,ls_z]) |
274 | intersection() { | 275 | intersection() { |
275 | r = x+idler_d/2+1;/* TODO: */ | 276 | r = x+idler_d/2+1;/* TODO: */ |
276 | cylinder(r=r,h=ls_h,center=true); | 277 | cylinder(r=r,h=ls_h,center=true); |
277 | translate([-r-1,0,-1]) cube(size=[2*r+2,r+1,ls_h+2]); | 278 | translate([-r-1,0,-1]) cube(size=[2*r+2,r+1,ls_h+2]); |
278 | } | 279 | } |
279 | 280 | ||
280 | rotate([0,0,-45]) | 281 | rotate([0,0,-45]) |
281 | translate([0,0,ls_z-ls_h/2]) | 282 | translate([0,0,ls_z-ls_h/2]) |
282 | cube(size=[gearbox_d,gearbox_d,lever_thickness+lever_v_clearance]); | 283 | cube(size=[gearbox_d,gearbox_d,lever_thickness+lever_v_clearance]); |
283 | translate([0,0,ls_z-ls_h/2]) { | 284 | translate([0,0,ls_z-ls_h/2]) { |
284 | translate([mount_screwhead_d/2,0,0]) | 285 | translate([mount_screwhead_d/2,0,0]) |
285 | mirror([0,1,0]) | 286 | mirror([0,1,0]) |
286 | cube(size=[gearbox_d,gearbox_d/2+1,lever_thickness+lever_v_clearance]); | 287 | cube(size=[gearbox_d,gearbox_d/2+1,lever_thickness+lever_v_clearance]); |
287 | } | 288 | } |
288 | //translate([-mount_d/2,-longwing,filament_elevation]) | 289 | //translate([-mount_d/2,-longwing,filament_elevation]) |
289 | if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ | 290 | if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ |
290 | translate([mount_d/2,-longwing,filament_elevation]) | 291 | translate([mount_d/2,-longwing,filament_elevation]) |
291 | rotate([0,-90,0]) difference() { | 292 | rotate([0,-90,0]) difference() { |
292 | cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); | 293 | cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); |
293 | translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 294 | translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
294 | } | 295 | } |
295 | 296 | ||
296 | }//difference | 297 | }//difference |
297 | 298 | ||
298 | if(supports) intersection() { | 299 | if(supports) intersection() { |
299 | difference() { | 300 | difference() { |
300 | translate([0,0,ls_z-ls_h/2-epsilon]) | 301 | translate([0,0,ls_z-ls_h/2-epsilon]) |
301 | cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); | 302 | cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); |