summaryrefslogtreecommitdiffabout
authorMichael Krelin <hacker@klever.net>2016-06-11 14:21:48 (UTC)
committer Michael Krelin <hacker@klever.net>2016-06-11 14:21:48 (UTC)
commit188652e0dbde274f1e4f24c6a02f4564921feb27 (patch) (side-by-side diff)
treec42f9f4abeda7817813c164fb69acc269f65e99e
parent0398dd6a4e41ec26d48ad02caffc319f34cbfcb1 (diff)
downloadfanductory-188652e0dbde274f1e4f24c6a02f4564921feb27.zip
fanductory-188652e0dbde274f1e4f24c6a02f4564921feb27.tar.gz
fanductory-188652e0dbde274f1e4f24c6a02f4564921feb27.tar.bz2
fix duct inner shape
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--fanduct.scad7
1 files changed, 4 insertions, 3 deletions
diff --git a/fanduct.scad b/fanduct.scad
index 746f753..fa14b7a 100644
--- a/fanduct.scad
+++ b/fanduct.scad
@@ -40,51 +40,52 @@ module fanduct(type=type,ductshape=ductshape) {
// *** duct is all around!
module duct(what) {
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([fanduct_w,fanduct_h/2]);
- translate([fanduct_w/2,fanduct_h-fanduct_w/2])
- rotate([0,0,90]) circle(d=fanduct_w,$fn=36);
+ square([sh,sv/2]);
+ translate([sh/2,sv/2])
+ scale([sh/smax,sv/smax])
+ circle(d=smax,$fn=36);
}
}
}
// *** bumps for easier position adjustments in line with hotend
module marks(what) {
if(what=="in") {
for(y=[-1,1])
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);