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>
16 plugwmin = min(8, DoveClipPairSane_width(2));
19 plugwmax = plugwmin + plugh * plugslope * 2;
33 translate([-d,0,0]) rotate([90,0,90]) linear_extrude(height=plugl+0.1+d*2){
34 polygon([[-(plugwmax/2 + bdx), 0],
35 [-(plugwmin/2 + tdx), plugh + tdy],
36 [+(plugwmin/2 + tdx), plugh + tdy],
37 [+(plugwmax/2 + bdx), 0]]);
39 translate([plugl + DoveClip_depth()*0.7 + d, 0, 0])
40 DoveClipPairSane(count=1, h=plugh-0.1);
44 spoolw = spoolwidth + spoolwidthgap*2;
46 biggestw = spoolw + 50;
51 translate([0,0,barz]) {
52 scale([1,barrady,barradz]) translate([-1,0,0])
53 rotate([0,90,0]) cylinder(r=1, h=spoolw/2+2, $fn=30);
54 translate([spoolw/2,0,0])
55 rotate([0,90,0]) cylinder(r=guiderad, h=guidewidth, $fn=60);
57 translate([spoolw/2 + guidewidth, 0, 0])
61 translate([-biggestw/2, -50, 0])
62 cube([biggestw, 100, 100]);
67 legang = atan2(trestlebase/2, trestleheight);
68 eplen = sqrt(trestleheight*trestleheight + trestlebase*trestlebase*0.25);
69 topcylr = max(plugwmax/2,
71 sqrt(plugwmin*2/4 + plugh*plugh)
72 ) + topcylthick + trestleplugd;
78 rotate([0,0, -90-legang])
79 ExtenderPillars(length=eplen+trestlelegw,
84 translate([-trestlebase/2, -trestleheight, 0])
85 cylinder(r=trestlelegw/2*1.2, h=plugl);
89 cylinder(r=topcylr, h=plugl);
90 translate([-50, -topcylbasedepth, -1])
91 cube([100, 50, plugl+2]);
94 translate([-trestlebase/2, -trestleheight, 0])
95 ExtenderPillars(length=trestlebase, width=trestlebaseh*2, height=plugl);
97 translate([-300, -trestleheight-50, -1])
98 cube([600, 50, plugl+2]);
101 Plug(d=trestleplugd);
108 //ExtenderPillars(80,12,8, baseweb=true);