author | Michael Krelin <hacker@klever.net> | 2016-06-13 16:50:42 (UTC) |
---|---|---|
committer | Michael Krelin <hacker@klever.net> | 2016-06-13 16:50:42 (UTC) |
commit | 4ac6f9232e1bc986e9898eb76abb6c317b712be5 (patch) (side-by-side diff) | |
tree | 0e19b0fff371103218f7403d13054c72a6ff7c6a | |
parent | 1afb1ce3d5afc54358f94b19e45d73f382a8246a (diff) | |
download | fanductory-4ac6f9232e1bc986e9898eb76abb6c317b712be5.zip fanductory-4ac6f9232e1bc986e9898eb76abb6c317b712be5.tar.gz fanductory-4ac6f9232e1bc986e9898eb76abb6c317b712be5.tar.bz2 |
dualism: airguides
-rw-r--r-- | fanduct.scad | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/fanduct.scad b/fanduct.scad index fc57c57..c402312 100644 --- a/fanduct.scad +++ b/fanduct.scad @@ -106,49 +106,49 @@ module fanduct(type=type,ductshape=ductshape,dual=dual) { else single(); } // *** bumps for easier position adjustments in line with hotend module marks(what) { if(what=="in") { for(y=[-1,1]) translate([0,dual?y*nozzles_apart/2:0,0]) hull() for(z=[0,-fanduct_shell-fanduct_h/2]) translate([0,y*(fanduct_ir+fanduct_shell+fanduct_w/2),fanduct_shell*2+fanduct_h+z]) rotate([90,0,0]) { cylinder(r=fanduct_shell,h=fanduct_w,center=true,$fn=30); for(z=[-1,1]) translate([0,0,z*fanduct_w/2]) sphere(r=fanduct_shell,$fn=30); } } } // *** output module output(what,type=type) { module guideline(xyxy) { module pin(xy) { translate([xy[0],xy[1],0]) cylinder(d=2*extrusion_width,h=2*fanduct_shell+inlet_h,$fn=6); } - xyxyxy=concat(xyxy,[[0,0]]); + xyxyxy=concat(xyxy,[[0,dual?nozzles_apart/2:0]]); for(i=[0:1:len(xyxyxy)-2]) hull() for(j=[i,i+1]) pin(xyxyxy[j]); } module circus(what) { if(what=="in") { difference() { rotate_extrude($fn=smooth_f) polygon([ [0,-fanduct_elevation+fanduct_blowtarget+epsilon], [fanduct_ir+fanduct_shell,fanduct_shell+fanduct_h/2], [fanduct_ir+fanduct_shell+fanduct_w/2,0], [0,-fanduct_elevation+fanduct_blowtarget-epsilon]]); translate([0,0,-1]) cylinder(r=hotend_clearance,h=fanduct_h+2*fanduct_shell+2,$fn=smooth_f); mirror([0,0,1]) translate([0,0,-epsilon]) cylinder(r=fanduct_ir+2*fanduct_shell+fanduct_w+1,h=fanduct_elevation+.1+2); } }else if(what=="out") { rotate_extrude($fn=smooth_f) polygon([ [0,-fanduct_elevation+fanduct_blowtarget+epsilon], [fanduct_ir+fanduct_shell+1,fanduct_h/2], @@ -214,48 +214,60 @@ module fanduct(type=type,ductshape=ductshape,dual=dual) { module dual(what=what) { module hulls(spots=dual_spots) { for(my=[0,1]) mirror([0,my,0]) for(pn=[0:1:len(spots)-2]) hull() { for(p=[spots[pn],spots[pn+1]]) translate(p) children(0); children([1:$children-1]); } } if(what=="in") { difference() { hulls() { cylinder(d=fanduct_w+2*fanduct_shell,h=2*fanduct_shell+fanduct_h/2); translate([0,-nozzles_apart/2,-fanduct_elevation-fanduct_blowtarget]) sphere(d=.1); } translate([0,0,epsilon]) hull() for(my=[0:1]) mirror([0,my,0]) for(s=dual_spots) translate(s) mirror([0,0,1]) cylinder(d=fanduct_w+2*fanduct_shell+2,h=fanduct_elevation-fanduct_blowtarget+1); for(s=[-1,1]) translate([0,s*nozzles_apart/2,-1]) cylinder(r=hotend_clearance,h=fanduct_h+2*fanduct_shell+2,$fn=smooth_f); } }else if(what=="out") { hulls() { translate([0,0,fanduct_shell]) cylinder(d=fanduct_w,h=fanduct_h/2-fanduct_shell/2); translate([0,-nozzles_apart/2,-fanduct_elevation+fanduct_blowtarget]) sphere(d=.1); } + }else if(what=="airguides") { + far = fanduct_ir+fanduct_shell+fanduct_w; + near = fanduct_ir; + union() { + for(my=[0,1]) mirror([0,my,0]) { + guideline([ [-far ,0], [0,0] ]); + guideline([ [-far ,inlet_w/2/4], + [-near ,nozzles_apart/2] ]); + guideline([ [-near-fanduct_w/3,nozzles_apart/2+near+fanduct_w/3] ]); + guideline([ [0 ,nozzles_apart/2+near+fanduct_w/2] ]); + } + } } } if(dual) dual(what); else if(type=="circular") circus(what); else if(type=="3jets") jets(what); } // *** air intake module intake(what) { module placeit() { translate([-fanduct_ir-2*fanduct_shell-fanduct_w-inlet_away,0,fanduct_shell]) rotate([0,-90,0]) children(); } if(what=="in") { placeit() translate([0,-inlet_w/2,0]) { difference() { cube(size=[inlet_h,inlet_w,inlet_long_l+fanduct_shell]); translate([inlet_h+fanduct_shell,0,inlet_long_l+fanduct_shell]) rotate([-90,0,0]) translate([0,0,-1]) cylinder(r=inlet_h,h=inlet_w+2*fanduct_shell+2,$fn=inlet_h*4); } |