chiark / gitweb /
364e9318ad951703e076850617447be8b6597196
[reprap-play.git] / filamentclip.scad
1 include <cliphook.scad>
2
3 rad=19;
4 h=3.5;
5 w=2.0;
6 teethw=1.5;
7
8 looprad=2.5;
9 loopw=w;
10
11 fdia=1.77;
12 //fdia=3;
13
14 d=0.01;
15
16 module FilamentClipTeeth(teethw=teethw,
17                          stembendd=0.5, stembendl=7, teethxl=1.5) {
18   gapw = fdia-stembendd*2;
19   teethbigw = gapw + teethw*2;
20   basew = fdia+teethw*2-stembendd*2;
21   based = basew/3;
22
23   translate([-based, -basew/2, 0]) cube([based, basew, h]);
24   difference() {
25     union() {
26       translate([-d, -teethbigw/2, 0])
27         cube([d+stembendl + teethw, teethbigw, h]);
28 //  translate([
29 //  stembigw = fdia + stembend
30 //  translate([-d, -stemw, 
31       linear_extrude(height=h) {
32         translate([stembendl-fdia/2, 0]) circle(fdia/2+teethw, $fn=30);
33       }
34     }
35     translate([0,0,-1]) {
36       translate([0,-gapw/2])
37         cube([stembendl+teethxl+1, gapw, h+2]);
38       linear_extrude(height=h+2) {
39         translate([stembendl-fdia/2, 0]) circle(fdia/2, $fn=30);
40       }
41     }
42   }
43
44   for (mirr=[0:1]) {
45     mirror([0,mirr,0]) {
46       translate([stembendl + teethw, gapw/2, 0])
47         rotate([0,0,30])
48         cube([teethxl, teethw, h]);
49     }
50   }
51 }
52
53 module our_ClipHook(ye){
54   ClipHook(h=h, w=w, g=0.6, k=1.5, g=0.6, ye=ye, cupcaph=0.5, cupcapg=0.8);
55 }
56
57 module FilamentClip() {
58   rotate([0,0,-62.5]) {
59     translate([0,rad-1.5,0]) {
60       rotate([0,0,8])
61         our_ClipHook(ye=-1.3);
62     }
63   }
64
65   rotate([0,0,-30]) {
66     translate([0,rad,0]) {
67       rotate([0,0,180])
68         our_ClipHook(ye=0.8);
69     }
70   }
71
72   linear_extrude(height=h) {
73     assign($fn=80) {
74       FlatArc(0,0, rad-w/2,rad+w/2, 80,365);
75     }
76     assign($fn=30) {
77       FlatArc(0,rad+looprad+w, looprad,looprad+loopw);
78     }
79   }
80
81   for (mir=[0,1]) {
82     mirror([mir,0,0])
83       rotate([0,0,-20])
84       translate([rad+w/2+teethw/2+fdia/2, 0, 0])
85       rotate([0,0,100])
86       FilamentClipTeeth();
87   }
88 }
89
90 FilamentClip();