X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=filamentclip.scad;h=85af4c9745fdab61f727b35a1e5aa393b80fed7b;hp=02191cb053c1cb131dff7abe24bd1b49dfad4828;hb=c6f26910d25106c742cc72a90d1e280583879874;hpb=d3b970ba05936a4d135dbf1b45a58faec1af7f83 diff --git a/filamentclip.scad b/filamentclip.scad index 02191cb..85af4c9 100644 --- a/filamentclip.scad +++ b/filamentclip.scad @@ -2,35 +2,59 @@ include rad=12; h=3.5; -w=1.2; +w=1.0; looprad=2.5; loopw=w; fdia=1.77; +//fdia=3; + +d=0.01; + +module FilamentClipTeeth(based=1.5, basew=4, teethw=0.6, + stembendd=0.5, stembendl=4, teethxl=1) { + gapw = fdia-stembendd*2; + teethbigw = gapw + teethw*2; -module FilamentClipTeeth(based=1.5, basew=4, clipw=0.6) { -// for (mirr=[0:1]) { -// mirror([0,mirr,0]) { -// linear_extrude(height=h) { -// translate(0.5, square([ -// } -// } -// } - extent1=1.5; -// jaww= translate([-based, -basew/2, 0]) cube([based, basew, h]); + difference() { + union() { + translate([-d, -teethbigw/2, 0]) + cube([d+stembendl + teethw, teethbigw, h]); // translate([ - linear_extrude(height=h) { - FlatArc(extent1+fdia/2, 0, fdia/2, fdia/2+clipw, $fn=30); +// stembigw = fdia + stembend +// translate([-d, -stemw, + linear_extrude(height=h) { + translate([stembendl-fdia/2, 0]) circle(fdia/2+teethw, $fn=30); + } + } + translate([0,0,-1]) { + translate([0,-gapw/2]) + cube([stembendl+teethxl+1, gapw, h+2]); + linear_extrude(height=h+2) { + translate([stembendl-fdia/2, 0]) circle(fdia/2, $fn=30); + } + } + } + + for (mirr=[0:1]) { + mirror([0,mirr,0]) { + translate([stembendl + teethw, gapw/2, 0]) + rotate([0,0,30]) + cube([teethxl, teethw, h]); + } } } module FilamentClip() { + k=1.5; + g=0.6; + rotate([0,0,-45]) { translate([0,rad,0]) { - ClipHook(h=h,w=w,k=1.5, ye=-1.3); - rotate([0,0,180]) ClipHook(h=h,w=w,k=1.5, ye=0.8); + ClipHook(h=h, w=w, g=0.6, k=k, g=g, ye=-1.3); + rotate([0,0,180]) ClipHook(h=h, w=w, g=g, k=k, ye=0.8); } } @@ -42,7 +66,12 @@ module FilamentClip() { FlatArc(0,rad+looprad+w, looprad,looprad+loopw); } } + + for (rot=[0,180]) { + rotate([0,0,rot]) + translate([rad, 0, 0]) FilamentClipTeeth(); + } } FilamentClip(); -//FilamentClipTeeth(); +