3 spoolwidth = 80; // fixme needs to be measured
4 trestleheight = 80; // fixme needs to be checked
5 trestlebase = 80; // fixme needs to be checked
7 include <doveclip.scad>
19 plugwmax = plugwmin + plugh * plugslope * 2;
29 pinholeminr = 1.0 + pindr;
30 pinholemaxr = 1.5 + pindr;
37 translate([-d,0,0]) rotate([90,0,90]) linear_extrude(height=plugl+0.1+d*2){
38 polygon([[-(plugwmin/2 + bdx), 0],
39 [-(plugwmax/2 + tdx), plugh + tdy],
40 [+(plugwmax/2 + tdx), plugh + tdy],
41 [+(plugwmin/2 + bdx), 0]]);
46 spoolw = spoolwidth + spoolwidthgap*2;
48 biggestw = spoolw + 50;
53 translate([0,0,barz]) {
54 scale([1,barrady,barradz]) translate([-1,0,0])
55 rotate([0,90,0]) cylinder(r=1, h=spoolw/2+2, $fn=30);
56 translate([spoolw/2,0,0])
57 rotate([0,90,0]) cylinder(r=guiderad, h=guidewidth, $fn=60);
59 translate([spoolw/2 + guidewidth, 0, 0])
63 translate([-biggestw/2, -50, 0])
64 cube([biggestw, 100, 100]);
69 legang = atan2(trestlebase/2, trestleheight);
70 eplen = sqrt(trestleheight*trestleheight + trestlebase*trestlebase*0.25);
71 topcylw = plugwmax + topcylthick*2;
77 rotate([0,0, -90-legang])
78 ExtenderPillars(length=eplen+trestlelegw,
83 translate([-trestlebase/2, -trestleheight, 0])
84 cylinder(r=trestlelegw/2*1.2, h=plugl);
87 translate([-topcylw/2, -topcylbasedepth, 0])
88 cube([topcylw, topcylbasedepth + plugh + topcylthick, plugl]);
90 translate([-trestlebase/2, -trestleheight, 0])
91 ExtenderPillars(length=trestlebase, width=trestlebaseh*2, height=plugl);
93 translate([-300, -trestleheight-50, -1])
94 cube([600, 50, plugl+2]);
100 translate([0,0,plugl/2]) rotate([0,rot,0]) translate([0,0,-plugl/2]) {
101 translate([-(topcylw/2+1), plugh, plugl/4])
103 cylinder(r1=pinholeminr, r2=pinholeminr, h=topcylw/2+2, $fn=20);
104 translate([0, plugh, plugl/4])
106 cylinder(r1=pinholeminr, r2=pinholemaxr, h=topcylw/2+1, $fn=20);
116 //ExtenderPillars(80,12,8, baseweb=true);