summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--another.scad10
1 files changed, 6 insertions, 4 deletions
diff --git a/another.scad b/another.scad
index 461dc26..74a2d5f 100644
--- a/another.scad
+++ b/another.scad
@@ -36,388 +36,390 @@ module the_extruder(
36 st_nut_d = 9, st_nut_h = 4, 36 st_nut_d = 9, st_nut_h = 4,
37 st_screw_d = 5, 37 st_screw_d = 5,
38 st_thickshell = 8*extrusion_width, st_thinshell = 2*extrusion_width, 38 st_thickshell = 8*extrusion_width, st_thinshell = 2*extrusion_width,
39 st_split_w = 4*extrusion_width, 39 st_split_w = 4*extrusion_width,
40 40
41 // screw it 41 // screw it
42 mount_screw_d = 3.1, mount_screw_l = 20, 42 mount_screw_d = 3.1, mount_screw_l = 20,
43 mount_screwhead_d=6, mount_screwhead_h=3, 43 mount_screwhead_d=6, mount_screwhead_h=3,
44 idler_screw_d = 3, 44 idler_screw_d = 3,
45 idler_screwhead_d=6, idler_screwhead_h=3, 45 idler_screwhead_d=6, idler_screwhead_h=3,
46 46
47 pf = pushfit_metal, 47 pf = pushfit_metal,
48 pf_shell = max(3*layer_height,3*extrusion_width), 48 pf_shell = max(3*layer_height,3*extrusion_width),
49 pf_smooth = true, 49 pf_smooth = true,
50 50
51 // empty spaces 51 // empty spaces
52 idler_travel = 3, // how far should idler travel when pressed 52 idler_travel = 3, // how far should idler travel when pressed
53 idler_clearance=.5, 53 idler_clearance=.5,
54 pulley_small_d_clearance=.5, 54 pulley_small_d_clearance=.5,
55 lever_v_clearance=.7, // vertical clearance for the lever 55 lever_v_clearance=.7, // vertical clearance for the lever
56 spring_d_clearance=1, 56 spring_d_clearance=1,
57 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion 57 protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion
58 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion 58 protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion
59 mount_screw_d_tolerance=.4, 59 mount_screw_d_tolerance=.4,
60 idler_v_tolerance=.5, 60 idler_v_tolerance=.5,
61 knob_bore_d_tolerance=.6, 61 knob_bore_d_tolerance=.6,
62 st_nut_h_tolerance=.2, 62 st_nut_h_tolerance=.2,
63 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */ 63 st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */
64 st_screw_d_tolerance=.5, 64 st_screw_d_tolerance=.5,
65 st_split_w_tolerance = .3, 65 st_split_w_tolerance = .3,
66 66
67 min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis. 67 min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis.
68 min_xy_shell = 2*extrusion_width, 68 min_xy_shell = 2*extrusion_width,
69 69
70 what="lever", // lever|body|knob|springpad|* 70 what="lever", // lever|body|knob|springpad|*
71 left=false, 71 left=false,
72 vitamins = true, 72 vitamins = true,
73 bridges = true, 73 bridges = true,
74 debug = false, 74 debug = false,
75 label = "another" 75 label = "another"
76) { 76) {
77 fnd = 2*PI; fnr = 2*fnd; 77 fnd = 2*PI; fnr = 2*fnd;
78 function lu(m,k) = m[search([k],m)[0]][1]; 78 function lu(m,k) = m[search([k],m)[0]][1];
79 79
80 pulley_d = lu(pulley,"d"); 80 pulley_d = lu(pulley,"d");
81 pulley_h = lu(pulley,"h"); 81 pulley_h = lu(pulley,"h");
82 teeth_elevation = lu(pulley,"fe"); 82 teeth_elevation = lu(pulley,"fe");
83 filament_offset = lu(pulley,"g")+filament_d/2; 83 filament_offset = lu(pulley,"g")+filament_d/2;
84 pulley_d_clearance = lu(pulley,"ssrc")*2; 84 pulley_d_clearance = lu(pulley,"ssrc")*2;
85 85
86 idler_filament_offset = filament_path_d/2; 86 idler_filament_offset = filament_path_d/2;
87 lever_shell = mount_screwhead_h+0.5; 87 lever_shell = mount_screwhead_h+0.5;
88 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell); 88 lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell);
89 lsd = idler_d-idler_clearance*2; // the diameter of lever thingie 89 lsd = idler_d-idler_clearance*2; // the diameter of lever thingie
90 longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell; 90 longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell;
91 shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2)) 91 shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2))
92 sqrt(c*c+pow(a-c,2)); 92 sqrt(c*c+pow(a-c,2));
93 longwing_travel = idler_travel*longwing/shortwing; 93 longwing_travel = idler_travel*longwing/shortwing;
94 h_ = (pulley_d+idler_d)/(2*sqrt(2)); 94 h_ = (pulley_d+idler_d)/(2*sqrt(2));
95 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) ); 95 ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) );
96 spring_dl = idler_travel*longwing/ri; 96 spring_dl = idler_travel*longwing/ri;
97 // finger and spring support 97 // finger and spring support
98 fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2); 98 fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2);
99 99
100 mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1; 100 mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1;
101 mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1; 101 mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1;
102 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation; 102 filament_elevation=protrusion_h+pulley_elevation+teeth_elevation;
103 ls_z = filament_elevation; // leverspace mid-z 103 ls_z = filament_elevation; // leverspace mid-z
104 ls_h = lever_thickness+lever_v_clearance; // leverspace height 104 ls_h = lever_thickness+lever_v_clearance; // leverspace height
105 mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell); 105 mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell);
106 body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2); 106 body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2);
107 echo("mount depth",mount_depth); 107 echo("mount depth",mount_depth);
108 108
109 module teardrop(r,d,h,center=false,angle=45) { 109 module teardrop(r,d,h,center=false,angle=45) {
110 dd = d ? d : (2*r); 110 dd = d ? d : (2*r);
111 $fn = dd*fnd; 111 $fn = dd*fnd;
112 cylinder(d=dd,h=h,center=center); 112 cylinder(d=dd,h=h,center=center);
113 if(angle>0) translate([0,0,center?-h/2:0]) 113 if(angle>0) translate([0,0,center?-h/2:0])
114 rotate([0,0,angle]) 114 rotate([0,0,angle])
115 cube(size=[d/2,d/2,h]); 115 cube(size=[d/2,d/2,h]);
116 } 116 }
117 117
118 module mirrorleft() { 118 module mirrorleft() {
119 mirror([left?0:1,0,0]) children(); 119 mirror([left?0:1,0,0]) children();
120 } 120 }
121 module place_idler() { 121 module place_idler() {
122 rotate([0,0,45]) 122 rotate([0,0,45])
123 translate([(pulley_d+idler_d)/2,0,0]) 123 translate([(pulley_d+idler_d)/2,0,0])
124 children(); 124 children();
125 } 125 }
126 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) { 126 module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) {
127 if(depth) { 127 if(depth) {
128 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth); 128 hh = (-4*pow(depth,2)+pow(d,2))/(8*depth);
129 rr = depth+hh; 129 rr = depth+hh;
130 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr); 130 translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr);
131 }else if(r) { 131 }else if(r) {
132 hh=sqrt(pow(r,2)-pow(d,2)/4); 132 hh=sqrt(pow(r,2)-pow(d,2)/4);
133 translate([0,0,hh]) sphere(r=r,$fn=fnr*r); 133 translate([0,0,hh]) sphere(r=r,$fn=fnr*r);
134 } 134 }
135 } 135 }
136 136
137 % if(vitamins) mirrorleft() { 137 % if(vitamins) mirrorleft() {
138 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60); 138 translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60);
139 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) 139 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0])
140 cylinder(d=mount_screw_d,h=20,$fn=30); 140 cylinder(d=mount_screw_d,h=20,$fn=30);
141 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30); 141 translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30);
142 translate([0,0,protrusion_h]) { 142 translate([0,0,protrusion_h]) {
143 difference() { 143 difference() {
144 cylinder(d=bore_d,h=bore_l,$fn=30); 144 cylinder(d=bore_d,h=bore_l,$fn=30);
145 translate([-bore_d/2-1,bore_dd-bore_d/2,-1]) 145 translate([-bore_d/2-1,bore_dd-bore_d/2,-1])
146 cube([bore_d+2,bore_d/2,bore_l+2]); 146 cube([bore_d+2,bore_d/2,bore_l+2]);
147 } 147 }
148 translate([0,0,pulley_elevation]) { 148 translate([0,0,pulley_elevation]) {
149 cylinder(d=pulley_d,h=pulley_h,$fn=30); 149 cylinder(d=pulley_d,h=pulley_h,$fn=30);
150 translate([0,0,teeth_elevation]) { 150 translate([0,0,teeth_elevation]) {
151 place_idler() { 151 place_idler() {
152 cylinder(d=idler_d,h=idler_h,center=true,$fn=30); 152 cylinder(d=idler_d,h=idler_h,center=true,$fn=30);
153 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 153 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
154 }//place idler 154 }//place idler
155 // filament path 155 // filament path
156 rotate([0,0,45]) { 156 rotate([0,0,45]) {
157 translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) { 157 translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) {
158 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); 158 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15);
159 }//rotate translate 159 }//rotate translate
160 translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) { 160 translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) {
161 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); 161 cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15);
162 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d]) 162 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d])
163 pushfit(pf); 163 pushfit(pf);
164 }//rotate translate 164 }//rotate translate
165 }//rotate 165 }//rotate
166 }//translate teeth 166 }//translate teeth
167 }//translate pulley 167 }//translate pulley
168 }//translate protrusion 168 }//translate protrusion
169 }//vitamins 169 }//vitamins
170 170
171 module lever() { 171 module lever() {
172 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) { 172 translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) {
173 difference() { 173 difference() {
174 union() { 174 union() {
175 hull() { 175 hull() {
176 place_idler() 176 place_idler()
177 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 177 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
178 translate([mount_d/2,0,0]) 178 translate([mount_d/2,0,0])
179 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 179 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
180 }//hull 180 }//hull
181 hull() { 181 hull() {
182 translate([mount_d/2,0,0]) 182 translate([mount_d/2,0,0])
183 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); 183 cylinder(d=lsd,h=lever_thickness,center=true,$fn=60);
184 translate([mount_d/2,-longwing,0]) rotate([0,90,0]) 184 translate([mount_d/2,-longwing,0]) rotate([0,90,0])
185 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60); 185 cylinder(d=lever_thickness,h=lsd,center=true,$fn=60);
186 }//hull 186 }//hull
187 }//union 187 }//union
188 188
189 // filament path 189 // filament path
190 place_idler() 190 place_idler()
191 translate([-idler_d/2-idler_filament_offset,0,0]) 191 translate([-idler_d/2-idler_filament_offset,0,0])
192 rotate([90,0,0]) { 192 rotate([90,0,0]) {
193 mirror([0,1,0]) 193 mirror([0,1,0])
194 teardrop(d=filament_path_d,h=3*gearbox_d,center=true); 194 teardrop(d=filament_path_d,h=3*gearbox_d,center=true);
195 translate([0,0, 195 translate([0,0,
196 sqrt(2)*(mount_d-pulley_d+lsd)/2 196 sqrt(2)*(mount_d-pulley_d+lsd)/2
197 ]) { 197 ]) {
198 cylinder(d1=filament_path_d,d2=2*filament_path_d, 198 cylinder(d1=filament_path_d,d2=2*filament_path_d,
199 h=filament_path_d,$fn=2*filament_path_d*fnd); 199 h=filament_path_d,$fn=2*filament_path_d*fnd);
200 translate([0,0,filament_path_d-epsilon]) 200 translate([0,0,filament_path_d-epsilon])
201 cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd); 201 cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd);
202 }//translate 202 }//translate
203 }//rotate translate place_idler 203 }//rotate translate place_idler
204 204
205 // idler space and mounting hole 205 // idler space and mounting hole
206 place_idler() { 206 place_idler() {
207 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); 207 cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60);
208 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); 208 cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30);
209 translate([0,0,lever_thickness/2-idler_screwhead_h]) 209 translate([0,0,lever_thickness/2-idler_screwhead_h])
210 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d); 210 cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d);
211 } 211 }
212 // mounting screw hole 212 // mounting screw hole
213 translate([mount_d/2,0,0]) 213 translate([mount_d/2,0,0])
214 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); 214 cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d);
215 215
216 // lever end 216 // lever end
217 translate([mount_d/2,0,0]) rotate([0,90,0]) { 217 translate([mount_d/2,0,0]) rotate([0,90,0]) {
218 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); 218 translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15);
219 translate([0,-longwing,0]) 219 translate([0,-longwing,0])
220 mirror([0,0,1]) 220 mirror([0,0,1])
221 difference() { 221 difference() {
222 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); 222 cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance));
223 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 223 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
224 } 224 }
225 }//rotate-translate 225 }//rotate-translate
226 }//difference 226 }//difference
227 // bridging patch 227 // bridging patch
228 if(bridges) place_idler() 228 if(bridges) place_idler() {
229 translate([0,0,lever_thickness/2-mount_screwhead_h]) 229 translate([0,0,lever_thickness/2-mount_screwhead_h])
230 mirror([0,0,1]) 230 mirror([0,0,1]) cylinder(d=mount_screwhead_d,h=layer_height);
231 cylinder(d=mount_screwhead_d,h=layer_height); 231 translate([0,0,-(idler_h+idler_v_tolerance)/2])
232 mirror([0,0,1]) cylinder(d=mount_screwhead_d,h=layer_height);
233 }
232 }//translate 234 }//translate
233 }//lever module 235 }//lever module
234 236
235 module body() { 237 module body() {
236 difference() { 238 difference() {
237 union() { 239 union() {
238 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); 240 cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d);
239 // spring tensioner part 241 // spring tensioner part
240 translate([-gearbox_d/2,0,0]) hull() { 242 translate([-gearbox_d/2,0,0]) hull() {
241 translate([0,-longwing,ls_z]) 243 translate([0,-longwing,ls_z])
242 rotate([0,90,0]) 244 rotate([0,90,0])
243 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); 245 cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness);
244 hh=body_h-ls_z; 246 hh=body_h-ls_z;
245 translate([0,0,ls_z]) 247 translate([0,0,ls_z])
246 mirror([0,1,0]) cube(size=[fsw,longwing+(st_split_w+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]); 248 mirror([0,1,0]) cube(size=[fsw,longwing+(st_split_w+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]);
247 hhh=ls_z; 249 hhh=ls_z;
248 translate([0,0,0]) 250 translate([0,0,0])
249 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); 251 mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]);
250 }//hull translate 252 }//hull translate
251 253
252 // pushfit bracket 254 // pushfit bracket
253 translate([0,0,filament_elevation]) 255 translate([0,0,filament_elevation])
254 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 256 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
255 rotate([-90,0,0]) 257 rotate([-90,0,0])
256 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) { 258 translate([0,0,mount_d/sqrt(2)/2+mount_screw_d-gearbox_d/2/*TODO:*/]) {
257 pfbl = pf_h(pf)+gearbox_d/2; //TODO: 259 pfbl = pf_h(pf)+gearbox_d/2; //TODO:
258 if(pf_smooth) { 260 if(pf_smooth) {
259 pfbd = pf_d(pf)+2*pf_shell; 261 pfbd = pf_d(pf)+2*pf_shell;
260 hull() { 262 hull() {
261 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd); 263 cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd);
262 translate([-epsilon/2,0,0]) { 264 translate([-epsilon/2,0,0]) {
263 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]); 265 cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]);
264 mirror([0,1,0]) 266 mirror([0,1,0])
265 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]); 267 cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]);
266 }//translate 268 }//translate
267 }//hull 269 }//hull
268 }else{ 270 }else{
269 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; 271 pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2;
270 pfbd = pfb2a/cos(30); 272 pfbd = pfb2a/cos(30);
271 pfbs = pfb2a*tan(30); 273 pfbs = pfb2a*tan(30);
272 cylinder(d=pfbd,h=pfbl,$fn=6); 274 cylinder(d=pfbd,h=pfbl,$fn=6);
273 translate([-pfbs/2,0,0]) { 275 translate([-pfbs/2,0,0]) {
274 hull() { 276 hull() {
275 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); 277 translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]);
276 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); 278 cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]);
277 mirror([0,1,0]) 279 mirror([0,1,0])
278 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); 280 cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]);
279 }//hull 281 }//hull
280 }//translate*/ 282 }//translate*/
281 }//if(pf_smooth) 283 }//if(pf_smooth)
282 }//translate rotate translate rotate translate 284 }//translate rotate translate rotate translate
283 }//union (first child of difference) 285 }//union (first child of difference)
284 286
285 // protrusion 287 // protrusion
286 translate([0,0,-1]) 288 translate([0,0,-1])
287 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); 289 cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h));
288 // mount screw holes 290 // mount screw holes
289 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { 291 for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) {
290 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)]) 292 translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)])
291 mirror([0,0,1]) 293 mirror([0,0,1])
292 cylinder(d=mount_screw_d+mount_screw_d_tolerance, 294 cylinder(d=mount_screw_d+mount_screw_d_tolerance,
293 h=mount_screw_l-mount_depth+1, 295 h=mount_screw_l-mount_depth+1,
294 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); 296 $fn=fnd*(mount_screw_d+mount_screw_d_tolerance));
295 translate([0,0,mount_screw_l-mount_depth]) 297 translate([0,0,mount_screw_l-mount_depth])
296 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); 298 cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d);
297 }//for 299 }//for
298 // pushfit 300 // pushfit
299 pf_offset = mount_d/sqrt(2)/2+mount_screw_d; 301 pf_offset = mount_d/sqrt(2)/2+mount_screw_d;
300 translate([0,0,filament_elevation]) 302 translate([0,0,filament_elevation])
301 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) 303 rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0])
302 rotate([-90,0,0]) 304 rotate([-90,0,0])
303 translate([0,0,pf_offset]) 305 translate([0,0,pf_offset])
304 rotate([0,0,180]) { 306 rotate([0,0,180]) {
305 pushfit(pf); 307 pushfit(pf);
306 mirror([0,0,1]) { 308 mirror([0,0,1]) {
307 fh = 1.5* (filament_guide_d-filament_path_d)/2; 309 fh = 1.5* (filament_guide_d-filament_path_d)/2;
308 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh; 310 fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh;
309 translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225); 311 translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225);
310 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225); 312 translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225);
311 translate([0,0,fo+epsilon]) 313 translate([0,0,fo+epsilon])
312 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d); 314 cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d);
313 }//mirror 315 }//mirror
314 }//rotate translate rotate translate rotate translate 316 }//rotate translate rotate translate rotate translate
315 // pulley 317 // pulley
316 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); 318 cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance));
317 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance)); 319 cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance));
318 320
319 translate([0,0,ls_z-ls_h/2]) { 321 translate([0,0,ls_z-ls_h/2]) {
320 // idler travel 322 // idler travel
321 translate([mount_d/2,0,0]) 323 translate([mount_d/2,0,0])
322 rotate([0,0,45]) 324 rotate([0,0,45])
323 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2)) 325 rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2))
324 square([shortwing+(idler_d+idler_clearance)/2,ls_h]); 326 square([shortwing+(idler_d+idler_clearance)/2,ls_h]);
325 // idler itself 327 // idler itself
326 place_idler() 328 place_idler()
327 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); 329 cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance));
328 // lever space 330 // lever space
329 rotate([0,0,45]) 331 rotate([0,0,45])
330 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1))) 332 rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1)))
331 square([gearbox_d/2+1,ls_h]); 333 square([gearbox_d/2+1,ls_h]);
332 } 334 }
333 335
334 // back side cutout 336 // back side cutout
335 // XXX: this is somewhat ugly and potentially bugged, 337 // XXX: this is somewhat ugly and potentially bugged,
336 // but I want to sleep. 338 // but I want to sleep.
337 a0_ = atan( 339 a0_ = atan(
338 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2) 340 (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2)
339 / 341 /
340 ( 342 (
341 pulley_d/2+filament_offset- 343 pulley_d/2+filament_offset-
342 (pf_d(pf)+2*pf_shell)/2/cos(30) 344 (pf_d(pf)+2*pf_shell)/2/cos(30)
343 ) 345 )
344 ); 346 );
345 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ ); 347 a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ );
346 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); 348 a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2));
347 translate([0,0,ls_z]) difference() { 349 translate([0,0,ls_z]) difference() {
348 rotate([0,0,-180+a0]) 350 rotate([0,0,-180+a0])
349 rotate_extrude(angle=a1-a0) 351 rotate_extrude(angle=a1-a0)
350 translate([0,-ls_h/2]) 352 translate([0,-ls_h/2])
351 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, 353 square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1,
352 ls_h]); 354 ls_h]);
353 translate([-mount_d/2,0,0]) 355 translate([-mount_d/2,0,0])
354 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d)); 356 cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d));
355 }//difference translate 357 }//difference translate
356 358
357 // spring tensioner 359 // spring tensioner
358 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) { 360 translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) {
359 mirror([0,0,1]) { 361 mirror([0,0,1]) {
360 translate([0,0,st_thickshell]) 362 translate([0,0,st_thickshell])
361 hull() for(o=[0,spring_d]) translate([0,-o,0]) 363 hull() for(o=[0,spring_d]) translate([0,-o,0])
362 rotate([0,0,30]) 364 rotate([0,0,30])
363 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); 365 cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6);
364 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)); 366 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));
365 bigd = spring_d+spring_d_clearance; 367 bigd = spring_d+spring_d_clearance;
366 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; 368 hf = (bigd-st_screw_d-st_screw_d_tolerance)/2;
367 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) { 369 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) {
368 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, 370 cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd,
369 h=hf+epsilon, $fn=fnd*bigd); 371 h=hf+epsilon, $fn=fnd*bigd);
370 translate([0,-(st_split_w+st_split_w_tolerance)/2,0]) 372 translate([0,-(st_split_w+st_split_w_tolerance)/2,0])
371 cube(size=[body_h-ls_z+1,st_split_w+st_split_w_tolerance,fsw+1]); 373 cube(size=[body_h-ls_z+1,st_split_w+st_split_w_tolerance,fsw+1]);
372 }//translate 374 }//translate
373 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) 375 translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon])
374 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); 376 cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd);
375 }//mirror 377 }//mirror
376 }//translate 378 }//translate
377 379
378 // label 380 // label
379 label_thickness = 2*layer_height; 381 label_thickness = 2*layer_height;
380 label_len = len(label); 382 label_len = len(label);
381 if(label_len) { 383 if(label_len) {
382 labelspace = [gearbox_d/2-mount_screwhead_d/2-min_xy_shell,longwing-(mount_screwhead_d-st_split_w-st_split_w_tolerance)/2-2*min_xy_shell]; 384 labelspace = [gearbox_d/2-mount_screwhead_d/2-min_xy_shell,longwing-(mount_screwhead_d-st_split_w-st_split_w_tolerance)/2-2*min_xy_shell];
383 translate([0,0,body_h-label_thickness]) 385 translate([0,0,body_h-label_thickness])
384 linear_extrude(height=label_thickness+epsilon,convexity=64) 386 linear_extrude(height=label_thickness+epsilon,convexity=64)
385 translate([-mount_screwhead_d/2-min_xy_shell-labelspace.x/2,-longwing+(st_split_w+st_split_w_tolerance)/2+min_xy_shell+labelspace.y/2]) 387 translate([-mount_screwhead_d/2-min_xy_shell-labelspace.x/2,-longwing+(st_split_w+st_split_w_tolerance)/2+min_xy_shell+labelspace.y/2])
386 mirror([left?0:1,0]) 388 mirror([left?0:1,0])
387 text(text=label,size=labelspace.x/label_len,halign="center",valign="center",font="Arial Black"); 389 text(text=label,size=labelspace.x/label_len,halign="center",valign="center",font="Arial Black");
388 }//if(label_len) 390 }//if(label_len)
389 391
390 }//difference 392 }//difference
391 393
392 }//body module 394 }//body module
393 395
394 module springpad() { 396 module springpad() {
395 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; 397 smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell;
396 bigd = spring_d+spring_d_clearance/2; 398 bigd = spring_d+spring_d_clearance/2;
397 hf = (bigd-smalld)/2; 399 hf = (bigd-smalld)/2;
398 h = hf*3.5; 400 h = hf*3.5;
399 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) 401 translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation])
400 rotate([0,90,0]) difference() { 402 rotate([0,90,0]) difference() {
401 union() { 403 union() {
402 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); 404 cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd);
403 translate([0,0,hf-epsilon]) 405 translate([0,0,hf-epsilon])
404 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); 406 cylinder(d=bigd,h=h-hf,$fn=fnd*bigd);
405 translate([0,0,h]) 407 translate([0,0,h])
406 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); 408 sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4);
407 l = body_h-ls_z; 409 l = body_h-ls_z;
408 w = st_split_w; 410 w = st_split_w;
409 hull() translate([0,-st_split_w/2,0]) mirror([1,0,0]) { 411 hull() translate([0,-st_split_w/2,0]) mirror([1,0,0]) {
410 translate([0,0,w]) 412 translate([0,0,w])
411 cube(size=[l,st_split_w,w]); 413 cube(size=[l,st_split_w,w]);
412 cube(size=[l-w,st_split_w,2*w]); 414 cube(size=[l-w,st_split_w,2*w]);
413 } 415 }
414 } 416 }
415 translate([0,0,-epsilon]) 417 translate([0,0,-epsilon])
416 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); 418 cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance));
417 } 419 }
418 } 420 }
419 421
420 module knob() { 422 module knob() {
421 ch = knob_indent_d/2; 423 ch = knob_indent_d/2;
422 translate([0,0,body_h+epsilon]) { 424 translate([0,0,body_h+epsilon]) {
423 mirror([0,0,1]) translate([0,0,-epsilon]) { 425 mirror([0,0,1]) translate([0,0,-epsilon]) {