-rw-r--r-- | Makefile | 1 | ||||
-rw-r--r-- | fanduct.scad | 3 |
2 files changed, 3 insertions, 1 deletions
@@ -1,15 +1,16 @@ -include Makefile.local OPENSCAD_APP?=/Applications/OpenSCAD.app OPENSCAD_BIN?=${OPENSCAD_APP}/Contents/MacOS/OpenSCAD +OPENSCAD_FLAGS=-D draft=false default: fanduct-circular.stl fanduct-3jets.stl fanduct-dual.stl clean: rm -f *.stl fanduct-%.stl: fanduct-%.scad fanduct.scad %.stl: %.scad ${OPENSCAD_BIN} ${OPENSCAD_FLAGS} -o "$@" "$<" diff --git a/fanduct.scad b/fanduct.scad index 690a4c8..8d0414f 100644 --- a/fanduct.scad +++ b/fanduct.scad @@ -1,91 +1,92 @@ use <snapper.scad>; extrusion_width=.5; layer_height=.2; // print parameters epsilon=.005; // for finer cuts type="circular"; // circular|3jets ductshape="square"; // square|round dual=true; // dual or single nozzles_apart = 18; // distance between nozzles for dual hotend space_behind_nozzle = 10; // space behind the nozzle where we're allowed to go // without the fear of hitting carriage inlet_w = 12.5; // inlet width inlet_h = 17; // inlet height inlet_short_l = 7; // inlet length of protrusion (or depth of intrusion:)) inlet_away = 15; // how far away inlet is inlet_long_l = inlet_short_l+inlet_h; function hypothenuse(a,b) = sqrt(pow(a,2)+pow(b,2)); silicone_shell = 2; heater_clearance = dual ? max(20,15.5) - 4.5 + silicone_shell : max( hypothenuse(16/2 +silicone_shell, 20-4.5 +silicone_shell), // E3D v6 hypothenuse(11.5-4.5 +silicone_shell, 15.5 +silicone_shell) // E3D volcano ); fanduct_elevation = 3; // fanduct elevation above nozzle tip fanduct_blowtarget = -2; // what to blow at fanduct_h = 6; // inner height of the duct fanduct_w = 7; // inner width of the duct fanduct_shell=1.2; // shell thickness fanduct_ir = heater_clearance+5; // inner radius jet_angle = 60-2; // angular width of the jet hotend_clearance = heater_clearance; snapper_d = 8; snapper_overlap=0.2; // snip snap -smooth_f = 120; +draft=true; +smooth_f = draft? 30 : 120; to_midduct = fanduct_ir+fanduct_shell+fanduct_w/2; dual_spots = [ [+space_behind_nozzle, -(to_midduct+nozzles_apart/2)], [- to_midduct, -(to_midduct+nozzles_apart/2)], [- to_midduct, 0] ]; module fanduct(type=type,ductshape=ductshape,dual=dual) { // *** duct is all around! module duct(what) { module single() { if(what=="in") { sh = fanduct_w+2*fanduct_shell; sv = fanduct_h+2*fanduct_shell; smax = max(sh,sv); rotate_extrude($fn=smooth_f) if(ductshape=="round") translate([sh/2+fanduct_ir,sv/2]) scale([sh/smax,sv/smax]) circle(d=smax,$fn=4*smax); else if(ductshape=="square") translate([fanduct_ir,0]) square([sh,sv]); }else if(what=="out") { sh = fanduct_w; sv = fanduct_h; smax = max(sh,sv); rotate_extrude($fn=smooth_f) if(ductshape=="round") translate([sh/2+fanduct_shell+fanduct_ir,sv/2+fanduct_shell]) scale([sh/smax,sv/smax]) circle(d=smax,$fn=4*smax); else if(ductshape=="square") translate([fanduct_ir+fanduct_shell,fanduct_shell]) union() { square([sh,sv/2]); translate([sh/2,sv/2]) scale([sh/smax,sv/smax]) circle(d=smax,$fn=36); } } } module dual() { 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(); } } if(what=="in") { hulls() cylinder(d=fanduct_w+2*fanduct_shell,h=fanduct_h+2*fanduct_shell); }else if(what=="out") { |