summaryrefslogtreecommitdiff
authorMichael Krelin <hacker@klever.net>2018-08-11 14:25:28 (UTC)
committer Michael Krelin <hacker@klever.net>2018-08-11 14:25:28 (UTC)
commit6ff4b3c2e76bbc6d37e933bcab7c47260785cab6 (patch) (unidiff)
tree4b7b408a2e5039d320fae3e15d1bf1cc912dbc2a
parent495bcda94c4b32b13044cfa9e97c8ea25b32cdfb (diff)
downloadextrudery-6ff4b3c2e76bbc6d37e933bcab7c47260785cab6.zip
extrudery-6ff4b3c2e76bbc6d37e933bcab7c47260785cab6.tar.gz
extrudery-6ff4b3c2e76bbc6d37e933bcab7c47260785cab6.tar.bz2
adjusted filament path
it used to within the pulley, but now it's only half there
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--another.scad12
1 files changed, 6 insertions, 6 deletions
diff --git a/another.scad b/another.scad
index 2ea5417..be0c887 100644
--- a/another.scad
+++ b/another.scad
@@ -27,352 +27,352 @@ module the_extruder(
27 filament_path_d = 2, 27 filament_path_d = 2,
28 filament_guide_d = 4, // PTFE filament guide diameter 28 filament_guide_d = 4, // PTFE filament guide diameter
29 // knob properties 29 // knob properties
30 knob_h = 10, 30 knob_h = 10,
31 knob_bore_l = 4, 31 knob_bore_l = 4,
32 knob_indent_d = 4, 32 knob_indent_d = 4,
33 knob_indents = 12, 33 knob_indents = 12,
34 // spring tensioner 34 // spring tensioner
35 st_nut_d = 9, st_nut_h = 4, 35 st_nut_d = 9, st_nut_h = 4,
36 st_screw_d = 5, 36 st_screw_d = 5,
37 st_thickshell = 8*extrusion_width, st_thinshell = 4*extrusion_width, 37 st_thickshell = 8*extrusion_width, st_thinshell = 4*extrusion_width,
38 38
39 // screw it 39 // screw it
40 mount_screw_d = 3.1, mount_screw_l = 20, 40 mount_screw_d = 3.1, mount_screw_l = 20,
41 mount_screwhead_d=6, mount_screwhead_h=3, 41 mount_screwhead_d=6, mount_screwhead_h=3,
42 idler_screw_d = 3, 42 idler_screw_d = 3,
43 idler_screwhead_d=6, idler_screwhead_h=3, 43 idler_screwhead_d=6, idler_screwhead_h=3,
44 44
45 pf = pushfit_embeddest, 45 pf = pushfit_embeddest,
46 pf_shell = max(3*layer_height,3*extrusion_width), 46 pf_shell = max(3*layer_height,3*extrusion_width),
47 47
48 // empty spaces 48 // empty spaces
49 idler_travel = 3, // how far should idler travel when pressed 49 idler_travel = 3, // how far should idler travel when pressed
50 idler_clearance=1, 50 idler_clearance=1,
51 pulley_clearance=2, 51 pulley_clearance=2,
52 lever_v_clearance=.7, // vertical clearance for the lever 52 lever_v_clearance=.7, // vertical clearance for the lever
53 spring_d_clearance=1, 53 spring_d_clearance=1,
54 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion 54 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion
55 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion 55 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion
56 mount_screw_d_tolerance=.4, 56 mount_screw_d_tolerance=.4,
57 idler_v_tolerance=.5, 57 idler_v_tolerance=.5,
58 knob_bore_d_tolerance=.6, 58 knob_bore_d_tolerance=.6,
59 st_nut_h_tolerance=.2, 59 st_nut_h_tolerance=.2,
60 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */ 60 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */
61 st_screw_d_tolerance=.3, 61 st_screw_d_tolerance=.3,
62 62
63 what="lever", // lever|body|knob|springpad|* 63 what="lever", // lever|body|knob|springpad|*
64 left=false, 64 left=false,
65 vitamins = true, 65 vitamins = true,
66 supports = false, bridges = true, 66 supports = false, bridges = true,
67 tensioner = true, 67 tensioner = true,
68 debug = false 68 debug = false
69) { 69) {
70 fnd = 2*PI; fnr = 2*fnd; 70 fnd = 2*PI; fnr = 2*fnd;
71 71
72 lever_shell = mount_screwhead_h+0.5; 72 lever_shell = mount_screwhead_h+0.5;
73 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell); 73 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell);
74 lsd = idler_d-idler_clearance*2; 74 lsd = idler_d-idler_clearance*2;
75 longwing=gearbox_d/2+spring_d/2+lsd/2; 75 longwing=gearbox_d/2+spring_d/2+lsd/2;
76 h_ = (pulley_d+idler_d)/(2*sqrt(2)); 76 h_ = (pulley_d+idler_d)/(2*sqrt(2));
77 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) ); 77 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) );
78 spring_dl = idler_travel*longwing/ri; 78 spring_dl = idler_travel*longwing/ri;
79 79
80 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation; 80 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation;
81 ls_z = filament_elevation; // leverspace mid-z 81 ls_z = filament_elevation; // leverspace mid-z
82 body_h = max(protrusion_h+bore_l,mount_screw_l-mounthole_depth/2+mount_screwhead_h,ls_z*2); 82 body_h = max(protrusion_h+bore_l,mount_screw_l-mounthole_depth/2+mount_screwhead_h,ls_z*2);
83 ls_h = lever_thickness+lever_v_clearance; // leverspace height 83 ls_h = lever_thickness+lever_v_clearance; // leverspace height
84 84
85 module mirrorleft() { 85 module mirrorleft() {
86 mirror([left?0:1,0,0]) children(); 86 mirror([left?0:1,0,0]) children();
87 } 87 }
88 module place_idler() { 88 module place_idler() {
89 rotate([0,0,45]) 89 rotate([0,0,45])
90 translate([(pulley_d+idler_d)/2,0,0]) 90 translate([(pulley_d+idler_d)/2,0,0])
91 children(); 91 children();
92 } 92 }
93 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) { 93 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) {
94 if(depth) { 94 if(depth) {
95 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth); 95 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth);
96 rr = depth+hh; 96 rr = depth+hh;
97 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr); 97 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr);
98 }else if(r) { 98 }else if(r) {
99 hh=sqrt(pow(r,2)-pow(d,2)/4); 99 hh=sqrt(pow(r,2)-pow(d,2)/4);
100 translate([0,0,hh]) sphere(r=r,$fn=fnr*r); 100 translate([0,0,hh]) sphere(r=r,$fn=fnr*r);
101 } 101 }
102 } 102 }
103 103
104 % if(vitamins) mirrorleft() { 104 % if(vitamins) mirrorleft() {
105 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60); 105 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60);
106 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) 106 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0])
107 cylinder(d=mount_screw_d,h=20,$fn=30); 107 cylinder(d=mount_screw_d,h=20,$fn=30);
108 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30); 108 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30);
109 translate([0,0,protrusion_h]) { 109 translate([0,0,protrusion_h]) {
110 difference() { 110 difference() {
111 cylinder(d=bore_d,h=bore_l,$fn=30); 111 cylinder(d=bore_d,h=bore_l,$fn=30);
112 translate([-bore_d/2-1,bore_dd-bore_d/2,-1]) 112 translate([-bore_d/2-1,bore_dd-bore_d/2,-1])
113 cube([bore_d+2,bore_d/2,bore_l+2]); 113 cube([bore_d+2,bore_d/2,bore_l+2]);
114 } 114 }
115 translate([0,0,pulley_elevation]) { 115 translate([0,0,pulley_elevation]) {
116 cylinder(d=pulley_d,h=pulley_h,$fn=30); 116 cylinder(d=pulley_d,h=pulley_h,$fn=30);
117 translate([0,0,teeth_elevation]) { 117 translate([0,0,teeth_elevation]) {
118 place_idler() { 118 place_idler() {
119 cylinder(d=idler_d,h=idler_h,center=true,$fn=30); 119 cylinder(d=idler_d,h=idler_h,center=true,$fn=30);
120 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 120 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
121 }//place idler 121 }//place idler
122 // filament path 122 // filament path
123 rotate([0,0,45]) translate([(pulley_d-filament_path_d)/2,0,0]) { 123 rotate([0,0,45]) translate([pulley_d/2,0,0]) {
124 rotate([90,0,0]) cylinder(d=filament_d,h=gearbox_d*2,center=true,$fn=15); 124 rotate([90,0,0]) cylinder(d=filament_d,h=gearbox_d*2,center=true,$fn=15);
125 rotate([-90,0,0]) 125 rotate([-90,0,0])
126 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d]) 126 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d])
127 pushfit(pf); 127 pushfit(pf);
128 } 128 }
129 }//translate teeth 129 }//translate teeth
130 }//translate pulley 130 }//translate pulley
131 }//translate protrusion 131 }//translate protrusion
132 }//vitamins 132 }//vitamins
133 133
134 module lever() { 134 module lever() {
135 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) { 135 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) {
136 difference() { 136 difference() {
137 union() { 137 union() {
138 hull() { 138 hull() {
139 place_idler() 139 place_idler()
140 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 140 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
141 translate([mount_d/2,0,0]) 141 translate([mount_d/2,0,0])
142 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 142 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
143 }//hull 143 }//hull
144 hull() { 144 hull() {
145 translate([mount_d/2,0,0]) 145 translate([mount_d/2,0,0])
146 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 146 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
147 translate([mount_d/2,-longwing,0]) rotate([0,90,0]) 147 translate([mount_d/2,-longwing,0]) rotate([0,90,0])
148 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60); 148 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60);
149 }//hull 149 }//hull
150 }//union 150 }//union
151 151
152 // filament path 152 // filament path
153 place_idler() { 153 place_idler() {
154 translate([-(idler_d+filament_path_d)/2,0,0]) rotate([90,0,0]) { 154 translate([-idler_d/2,0,0]) rotate([90,0,0]) {
155 cylinder(d=filament_path_d,h=3*gearbox_d,center=true,$fn=30); 155 cylinder(d=filament_path_d,h=3*gearbox_d,center=true,$fn=30);
156 translate([0,-filament_path_d/2/sqrt(2),0]) rotate([0,0,45]) 156 translate([0,-filament_path_d/2/sqrt(2),0]) rotate([0,0,45])
157 cube(size=[filament_path_d/2,filament_path_d/2,3*gearbox_d],center=true); 157 cube(size=[filament_path_d/2,filament_path_d/2,3*gearbox_d],center=true);
158 }//rotate translate 158 }//rotate translate
159 translate([-(idler_d+filament_path_d)/2,0,0]) 159 translate([-idler_d/2,0,0])
160 rotate([90,0,0]) 160 rotate([90,0,0])
161 translate([0,0, 161 translate([0,0,
162 sqrt(2)*(mount_d-pulley_d+filament_path_d+lsd)/2 162 sqrt(2)*(mount_d-pulley_d+lsd)/2
163 ]) { 163 ]) {
164 cylinder(d1=filament_path_d,d2=2*filament_path_d, 164 cylinder(d1=filament_path_d,d2=2*filament_path_d,
165 h=filament_path_d,$fn=2*filament_path_d*fnd); 165 h=filament_path_d,$fn=2*filament_path_d*fnd);
166 translate([0,0,filament_path_d-epsilon]) 166 translate([0,0,filament_path_d-epsilon])
167 cylinder(d=2*filament_path_d,h=lsd,$fn=2*filament_path_d*fnd); 167 cylinder(d=2*filament_path_d,h=lsd,$fn=2*filament_path_d*fnd);
168 } 168 }
169 }//place_idler 169 }//place_idler
170 170
171 // idler space and mounting hole 171 // idler space and mounting hole
172 place_idler() { 172 place_idler() {
173 difference() { 173 difference() {
174 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); 174 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60);
175 if(supports) for(y=[-lsd/2+extrusion_width:(lsd-2*extrusion_width)/3:lsd/2-extrusion_width]) 175 if(supports) for(y=[-lsd/2+extrusion_width:(lsd-2*extrusion_width)/3:lsd/2-extrusion_width])
176 translate([-lsd/2-1,y-extrusion_width/2,-idler_h/2-idler_v_tolerance/2-1]) 176 translate([-lsd/2-1,y-extrusion_width/2,-idler_h/2-idler_v_tolerance/2-1])
177 cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]); 177 cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]);
178 } 178 }
179 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 179 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
180 translate([0,0,lever_thickness/2-idler_screwhead_h]) 180 translate([0,0,lever_thickness/2-idler_screwhead_h])
181 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d); 181 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d);
182 } 182 }
183 // mounting screw hole 183 // mounting screw hole
184 translate([mount_d/2,0,0]) 184 translate([mount_d/2,0,0])
185 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); 185 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d);
186 186
187 // lever end 187 // lever end
188 translate([mount_d/2,0,0]) rotate([0,90,0]) { 188 translate([mount_d/2,0,0]) rotate([0,90,0]) {
189 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); 189 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15);
190 translate([0,-longwing,0]) 190 translate([0,-longwing,0])
191 mirror([0,0,1]) 191 mirror([0,0,1])
192 difference() { 192 difference() {
193 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); 193 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance));
194 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 194 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
195 } 195 }
196 }//rotate-translate 196 }//rotate-translate
197 }//difference 197 }//difference
198 // bridging patch 198 // bridging patch
199 if(bridges) place_idler() 199 if(bridges) place_idler()
200 translate([0,0,lever_thickness/2-mount_screwhead_h]) 200 translate([0,0,lever_thickness/2-mount_screwhead_h])
201 mirror([0,0,1]) 201 mirror([0,0,1])
202 cylinder(d=mount_screwhead_d,h=layer_height); 202 cylinder(d=mount_screwhead_d,h=layer_height);
203 }//translate 203 }//translate
204 }//lever module 204 }//lever module
205 205
206 module body() { 206 module body() {
207 difference() { 207 difference() {
208 union() { 208 union() {
209 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); 209 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d);
210 // finger and spring support 210 // finger and spring support
211 fsw = gearbox_d-(gearbox_d-mount_d)/2-spring_lc; 211 fsw = gearbox_d-(gearbox_d-mount_d)/2-spring_lc;
212 translate([-gearbox_d/2,0,0]) difference() { 212 translate([-gearbox_d/2,0,0]) difference() {
213 union() { 213 union() {
214 hull() { 214 hull() {
215 translate([0,-longwing,ls_z]) 215 translate([0,-longwing,ls_z])
216 rotate([0,90,0]) 216 rotate([0,90,0])
217 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); 217 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness);
218 hh=body_h-ls_z; 218 hh=body_h-ls_z;
219 translate([0,0,ls_z-lever_thickness/2]) 219 translate([0,0,ls_z-lever_thickness/2])
220 mirror([0,1,0]) cube(size=[fsw,longwing-hh+lever_thickness/sqrt(2),hh+lever_thickness/2]); 220 mirror([0,1,0]) cube(size=[fsw,longwing-hh+lever_thickness/sqrt(2),hh+lever_thickness/2]);
221 hhh=ls_z; 221 hhh=ls_z;
222 translate([0,0,0]) 222 translate([0,0,0])
223 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); 223 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]);
224 } 224 }
225 } 225 }
226 translate([0,-longwing,ls_z]) rotate([0,-90,0]) { 226 translate([0,-longwing,ls_z]) rotate([0,-90,0]) {
227 if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { 227 if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else {
228 mirror([0,0,1]) { 228 mirror([0,0,1]) {
229 translate([0,0,st_thickshell]) 229 translate([0,0,st_thickshell])
230 hull() for(o=[0,spring_d]) translate([0,-o,0]) 230 hull() for(o=[0,spring_d]) translate([0,-o,0])
231 rotate([0,0,30]) 231 rotate([0,0,30])
232 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); 232 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6);
233 translate([0,0,-1]) cylinder(d=st_screw_d+st_screw_d_tolerance,h=fsw+2,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 233 translate([0,0,-1]) cylinder(d=st_screw_d+st_screw_d_tolerance,h=fsw+2,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
234 bigd = spring_d+spring_d_clearance; 234 bigd = spring_d+spring_d_clearance;
235 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; 235 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2;
236 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) 236 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon])
237 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, 237 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd,
238 h=hf+epsilon, $fn=fnd*bigd); 238 h=hf+epsilon, $fn=fnd*bigd);
239 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) 239 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon])
240 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); 240 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd);
241 } 241 }
242 } 242 }
243 } 243 }
244 } // translate 244 } // translate
245 245
246 // pushfit bracket 246 // pushfit bracket
247 translate([0,0,filament_elevation]) 247 translate([0,0,filament_elevation])
248 rotate([0,0,45]) translate([(pulley_d-filament_path_d)/2,0,0]) 248 rotate([0,0,45]) translate([pulley_d/2,0,0])
249 rotate([-90,0,0]) 249 rotate([-90,0,0])
250 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) { 250 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) {
251 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; 251 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2;
252 pfbd = pfb2a/cos(30); 252 pfbd = pfb2a/cos(30);
253 pfbs = pfb2a*tan(30); 253 pfbs = pfb2a*tan(30);
254 pfbl = pf_h(pf)+gearbox_d/2/*TODO:*/; 254 pfbl = pf_h(pf)+gearbox_d/2/*TODO:*/;
255 cylinder(d=pfbd,h=pfbl,$fn=6); 255 cylinder(d=pfbd,h=pfbl,$fn=6);
256 translate([-pfbs/2,0,0]) { 256 translate([-pfbs/2,0,0]) {
257 hull() { 257 hull() {
258 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); 258 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]);
259 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); 259 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]);
260 mirror([0,1,0]) 260 mirror([0,1,0])
261 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); 261 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]);
262 } 262 }
263 } 263 }
264 } 264 }
265 }//union (first child of difference) 265 }//union (first child of difference)
266 266
267 // protrusion 267 // protrusion
268 translate([0,0,-1]) 268 translate([0,0,-1])
269 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); 269 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h));
270 // mount screw holes 270 // mount screw holes
271 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { 271 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) {
272 translate([0,0,mount_screw_l-mounthole_depth/2-(bridges?layer_height:-epsilon)]) 272 translate([0,0,mount_screw_l-mounthole_depth/2-(bridges?layer_height:-epsilon)])
273 mirror([0,0,1]) 273 mirror([0,0,1])
274 cylinder(d=mount_screw_d+mount_screw_d_tolerance, 274 cylinder(d=mount_screw_d+mount_screw_d_tolerance,
275 h=mount_screw_l-mounthole_depth/2+1, 275 h=mount_screw_l-mounthole_depth/2+1,
276 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); 276 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance));
277 translate([0,0,mount_screw_l-mounthole_depth/2]) 277 translate([0,0,mount_screw_l-mounthole_depth/2])
278 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); 278 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d);
279 }//for 279 }//for
280 // pushfit 280 // pushfit
281 translate([0,0,filament_elevation]) 281 translate([0,0,filament_elevation])
282 rotate([0,0,45]) translate([(pulley_d-filament_path_d)/2,0,0]) 282 rotate([0,0,45]) translate([pulley_d/2,0,0])
283 rotate([-90,0,0]) 283 rotate([-90,0,0])
284 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d+epsilon]) 284 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d+epsilon])
285 rotate([0,0,180]) { 285 rotate([0,0,180]) {
286 pushfit(pf); 286 pushfit(pf);
287 cylinder(d=filament_guide_d,h=gearbox_d,center=true,$fn=fnd*filament_guide_d); 287 cylinder(d=filament_guide_d,h=gearbox_d,center=true,$fn=fnd*filament_guide_d);
288 translate([0,-filament_guide_d/2/sqrt(2),0]) 288 translate([0,-filament_guide_d/2/sqrt(2),0])
289 rotate([0,0,45]) 289 rotate([0,0,45])
290 cube(size=[filament_guide_d/2,filament_guide_d/2,gearbox_d],center=true); 290 cube(size=[filament_guide_d/2,filament_guide_d/2,gearbox_d],center=true);
291 }//rotate translate rotate translate rotate translate 291 }//rotate translate rotate translate rotate translate
292 // pulley 292 // pulley
293 cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); 293 cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance));
294 // leverspace 294 // leverspace
295 hull() for(x=[0,gearbox_d]) 295 hull() for(x=[0,gearbox_d])
296 rotate([0,0,45]) 296 rotate([0,0,45])
297 translate([x,0,ls_z-ls_h/2]) 297 translate([x,0,ls_z-ls_h/2])
298 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); 298 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance));
299 299
300 // idler clearance 300 // idler clearance
301 a=cos(45)*(pulley_d+idler_d)/2; 301 a=cos(45)*(pulley_d+idler_d)/2;
302 b=mount_d/2-a; 302 b=mount_d/2-a;
303 x=sqrt(pow(a,2)+pow(b,2)); 303 x=sqrt(pow(a,2)+pow(b,2));
304 translate([mount_d/2,0,ls_z]) 304 translate([mount_d/2,0,ls_z])
305 intersection() { 305 intersection() {
306 r = x+idler_d/2+idler_clearance; 306 r = x+idler_d/2+idler_clearance;
307 cylinder(r=r,h=ls_h,center=true); 307 cylinder(r=r,h=ls_h,center=true);
308 translate([-r-1,0,-ls_h/2-1]) cube(size=[2*r+2,r+1,ls_h+2]); 308 translate([-r-1,0,-ls_h/2-1]) cube(size=[2*r+2,r+1,ls_h+2]);
309 } 309 }
310 310
311 // back side cutout 311 // back side cutout
312 a0 = asin((mount_screwhead_d+2*extrusion_width)/mount_d); 312 a0 = asin((mount_screwhead_d+2*extrusion_width)/mount_d);
313 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); 313 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2));
314 translate([0,0,ls_z]) hull() { 314 translate([0,0,ls_z]) hull() {
315 rotate([0,0,-180+a0]) 315 rotate([0,0,-180+a0])
316 rotate_extrude(angle=a1-a0) 316 rotate_extrude(angle=a1-a0)
317 translate([0,-ls_h/2]) 317 translate([0,-ls_h/2])
318 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, 318 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1,
319 ls_h]); 319 ls_h]);
320 cylinder(d=bore_d/2/*TODO:recalculate angles based on this, 320 cylinder(d=bore_d/2/*TODO:recalculate angles based on this,
321 too lazy to do that now*/, 321 too lazy to do that now*/,
322 h=ls_h,center=true); 322 h=ls_h,center=true);
323 } 323 }
324 324
325 rotate([0,0,-45]) 325 rotate([0,0,-45])
326 translate([0,0,ls_z-ls_h/2]) 326 translate([0,0,ls_z-ls_h/2])
327 cube(size=[gearbox_d,gearbox_d,lever_thickness+lever_v_clearance]); 327 cube(size=[gearbox_d,gearbox_d,lever_thickness+lever_v_clearance]);
328 translate([0,0,ls_z-ls_h/2]) { 328 translate([0,0,ls_z-ls_h/2]) {
329 translate([mount_screwhead_d/2,0,0]) 329 translate([mount_screwhead_d/2,0,0])
330 mirror([0,1,0]) 330 mirror([0,1,0])
331 cube(size=[gearbox_d,gearbox_d/2+1,lever_thickness+lever_v_clearance]); 331 cube(size=[gearbox_d,gearbox_d/2+1,lever_thickness+lever_v_clearance]);
332 } 332 }
333 //translate([-mount_d/2,-longwing,filament_elevation]) 333 //translate([-mount_d/2,-longwing,filament_elevation])
334 if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ 334 if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */
335 translate([mount_d/2,-longwing,filament_elevation]) 335 translate([mount_d/2,-longwing,filament_elevation])
336 rotate([0,-90,0]) difference() { 336 rotate([0,-90,0]) difference() {
337 cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); 337 cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance));
338 translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 338 translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
339 } 339 }
340 340
341 }//difference 341 }//difference
342 342
343 if(supports) intersection() { 343 if(supports) intersection() {
344 difference() { 344 difference() {
345 translate([0,0,ls_z-ls_h/2-epsilon]) 345 translate([0,0,ls_z-ls_h/2-epsilon])
346 cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); 346 cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d);
347 cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance)); 347 cylinder(d=pulley_d+pulley_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_clearance));
348 } 348 }
349 // supports 349 // supports
350 // TODO: hardcoded stuff below… 350 // TODO: hardcoded stuff below…
351 if(false) { // parallel 351 if(false) { // parallel
352 for(y=[-gearbox_d:4:gearbox_d]) 352 for(y=[-gearbox_d:4:gearbox_d])
353 translate([0,y-extrusion_width/2,0]) 353 translate([0,y-extrusion_width/2,0])
354 cube(size=[gearbox_d,extrusion_width,body_h]); 354 cube(size=[gearbox_d,extrusion_width,body_h]);
355 }else{ // radial 355 }else{ // radial
356 for(zr=[-65:(65+50)/7:50]) 356 for(zr=[-65:(65+50)/7:50])
357 rotate([0,0,zr]) translate([0,-extrusion_width/2,0]) 357 rotate([0,0,zr]) translate([0,-extrusion_width/2,0])
358 cube(size=[gearbox_d,extrusion_width,body_h]); 358 cube(size=[gearbox_d,extrusion_width,body_h]);
359 } 359 }
360 } 360 }
361 361
362 }//body module 362 }//body module
363 363
364 module springpad() { 364 module springpad() {
365 smalld=st_screw_d+st_screw_d_tolerance+2*extrusion_width; 365 smalld=st_screw_d+st_screw_d_tolerance+2*extrusion_width;
366 bigd = spring_d+spring_d_clearance/2; 366 bigd = spring_d+spring_d_clearance/2;
367 hf = (bigd-smalld)/2; 367 hf = (bigd-smalld)/2;
368 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) 368 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation])
369 rotate([0,90,0]) difference() { 369 rotate([0,90,0]) difference() {
370 union() { 370 union() {
371 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); 371 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd);
372 translate([0,0,hf-epsilon]) 372 translate([0,0,hf-epsilon])
373 cylinder(d=bigd,h=hf*2,$fn=fnd*bigd); 373 cylinder(d=bigd,h=hf*2,$fn=fnd*bigd);
374 translate([0,0,3*hf]) 374 translate([0,0,3*hf])
375 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 375 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
376 } 376 }
377 translate([0,0,-epsilon]) 377 translate([0,0,-epsilon])
378 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 378 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance));