-rw-r--r-- | another.scad | 28 |
1 files changed, 2 insertions, 26 deletions
diff --git a/another.scad b/another.scad index 2331003..9ff7f6a 100644 --- a/another.scad +++ b/another.scad | |||
@@ -1,510 +1,486 @@ | |||
1 | draft=true; | 1 | draft=true; |
2 | layer_height=0.2; extrusion_width=0.4; | 2 | layer_height=0.2; extrusion_width=0.4; |
3 | epsilon=0.01; | 3 | epsilon=0.01; |
4 | $fs=0.0125; | 4 | $fs=0.0125; |
5 | 5 | ||
6 | use <pushfittery.scad>; | 6 | use <pushfittery.scad>; |
7 | include <pushfit_data.scad>; | 7 | include <pushfit_data.scad>; |
8 | 8 | ||
9 | module the_extruder( | 9 | module the_extruder( |
10 | // motor properties | 10 | // motor properties |
11 | gearbox_d = 36, | 11 | gearbox_d = 36, |
12 | mount_d = 28, // the distance between opposite mounting holes | 12 | mount_d = 28, // the distance between opposite mounting holes |
13 | mounthole_depth = 5, | 13 | mounthole_depth = 5, |
14 | mounthole_min_depth = 3, mounthole_max_depth = 4, | 14 | mounthole_min_depth = 3, mounthole_max_depth = 4, |
15 | protrusion_d = 22, protrusion_h = 2.2, // the dimensions of the protrusion on top of gearbox | 15 | protrusion_d = 22, protrusion_h = 2.2, // the dimensions of the protrusion on top of gearbox |
16 | bore_d = 8, bore_l = 17.6, | 16 | bore_d = 8, bore_l = 17.6, |
17 | bore_dd = 7, | 17 | bore_dd = 7, |
18 | // pulley properties | 18 | // pulley properties |
19 | pulley_d = 11.5, pulley_h=10, | 19 | pulley_d = 11.5, pulley_h=10, |
20 | pulley_elevation = 1, // pulley elevation above the protrusion | 20 | pulley_elevation = 1, // pulley elevation above the protrusion |
21 | teeth_elevation = 7.5, // distance from the bottom of the pulley to its teeth | 21 | teeth_elevation = 7.5, // distance from the bottom of the pulley to its teeth |
22 | filament_offset = (8.25-(3.0+3.5)/2) - 11.5/2 + 1.75/2, | 22 | filament_offset = (8.25-(3.0+3.5)/2) - 11.5/2 + 1.75/2, |
23 | // idler properties | 23 | // idler properties |
24 | idler_d = 9.5, idler_h = 4, idler_id = 3,// idler dimensions: outer and inner diameters and height | 24 | idler_d = 9.5, idler_h = 4, idler_id = 3,// idler dimensions: outer and inner diameters and height |
25 | // spring properties | 25 | // spring properties |
26 | spring_d = 10, spring_lc = 9.6, // spring diameter and compressed length | 26 | spring_d = 10, spring_lc = 9.6, // spring diameter and compressed length |
27 | // filament path properties | 27 | // filament path properties |
28 | filament_d = 1.75, | 28 | filament_d = 1.75, |
29 | filament_path_d = 2, | 29 | filament_path_d = 2, |
30 | filament_guide_d = 4, // PTFE filament guide diameter | 30 | filament_guide_d = 4, // PTFE filament guide diameter |
31 | // knob properties | 31 | // knob properties |
32 | knob_h = 10, | 32 | knob_h = 10, |
33 | knob_bore_l = 4, | 33 | knob_bore_l = 4, |
34 | knob_indent_d = 4, | 34 | knob_indent_d = 4, |
35 | knob_indents = 12, | 35 | knob_indents = 12, |
36 | // spring tensioner | 36 | // spring tensioner |
37 | st_nut_d = 9, st_nut_h = 4, | 37 | st_nut_d = 9, st_nut_h = 4, |
38 | st_screw_d = 5, | 38 | st_screw_d = 5, |
39 | st_thickshell = 8*extrusion_width, st_thinshell = 4*extrusion_width, | 39 | st_thickshell = 8*extrusion_width, st_thinshell = 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_embeddest, | 47 | pf = pushfit_embeddest, |
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=1, | 53 | idler_clearance=1, |
54 | pulley_d_clearance=2, | 54 | pulley_d_clearance=2, |
55 | pulley_small_d_clearance=0.5, | 55 | pulley_small_d_clearance=0.5, |
56 | lever_v_clearance=.7, // vertical clearance for the lever | 56 | lever_v_clearance=.7, // vertical clearance for the lever |
57 | spring_d_clearance=1, | 57 | spring_d_clearance=1, |
58 | protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion | 58 | protrusion_tolerance_h=.5, // horizontal tolerance for the motor protrusion |
59 | protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion | 59 | protrusion_tolerance_v=.5, // vertical tolerance for the motor protrusion |
60 | mount_screw_d_tolerance=.4, | 60 | mount_screw_d_tolerance=.4, |
61 | idler_v_tolerance=.5, | 61 | idler_v_tolerance=.5, |
62 | knob_bore_d_tolerance=.6, | 62 | knob_bore_d_tolerance=.6, |
63 | st_nut_h_tolerance=.2, | 63 | st_nut_h_tolerance=.2, |
64 | st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */ | 64 | st_nut_d_tolerance=.2,/* TODO: make it st_nut_w_tolerance */ |
65 | st_screw_d_tolerance=.5, | 65 | st_screw_d_tolerance=.5, |
66 | st_split_w_tolerance = .3, | 66 | st_split_w_tolerance = .3, |
67 | 67 | ||
68 | min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis. | 68 | min_z_shell = 4*layer_height, // the very minimal shell thickness along z-axis. |
69 | min_xy_shell = 2*extrusion_width, | 69 | min_xy_shell = 2*extrusion_width, |
70 | 70 | ||
71 | what="lever", // lever|body|knob|springpad|* | 71 | what="lever", // lever|body|knob|springpad|* |
72 | left=false, | 72 | left=false, |
73 | vitamins = true, | 73 | vitamins = true, |
74 | supports = false, bridges = true, | 74 | bridges = true, |
75 | tensioner = true, | 75 | tensioner = true, |
76 | debug = false | 76 | debug = false |
77 | ) { | 77 | ) { |
78 | fnd = 2*PI; fnr = 2*fnd; | 78 | fnd = 2*PI; fnr = 2*fnd; |
79 | 79 | ||
80 | idler_filament_offset = filament_path_d/2; // -filament_offset; | 80 | idler_filament_offset = filament_path_d/2; // -filament_offset; |
81 | lever_shell = mount_screwhead_h+0.5; | 81 | lever_shell = mount_screwhead_h+0.5; |
82 | lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell); | 82 | lever_thickness=max(spring_d+spring_d_clearance+layer_height*8,idler_h+idler_v_tolerance+2*lever_shell); |
83 | lsd = idler_d-idler_clearance*2; // the diameter of lever thingie | 83 | lsd = idler_d-idler_clearance*2; // the diameter of lever thingie |
84 | longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell; | 84 | longwing=(mount_d+mount_screw_d+mount_screw_d_tolerance+spring_d+spring_d_clearance)/2+min_xy_shell; |
85 | shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2)) | 85 | shortwing = let(a=mount_d/2,c=(pulley_d+idler_d)/2/sqrt(2)) |
86 | sqrt(c*c+pow(a-c,2)); | 86 | sqrt(c*c+pow(a-c,2)); |
87 | longwing_travel = idler_travel*longwing/shortwing; | 87 | longwing_travel = idler_travel*longwing/shortwing; |
88 | h_ = (pulley_d+idler_d)/(2*sqrt(2)); | 88 | h_ = (pulley_d+idler_d)/(2*sqrt(2)); |
89 | ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) ); | 89 | ri = sqrt( pow(h_,2) + pow(mount_d/2-h_,2) ); |
90 | spring_dl = idler_travel*longwing/ri; | 90 | spring_dl = idler_travel*longwing/ri; |
91 | // finger and spring support | 91 | // finger and spring support |
92 | fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2); | 92 | fsw = gearbox_d-(gearbox_d-mount_d)/2-max(spring_lc,longwing_travel+(gearbox_d-mount_d)/2); |
93 | 93 | ||
94 | mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1; | 94 | mount_min_depth = mounthole_min_depth ? mounthole_min_depth : mounthole_depth-1; |
95 | mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1; | 95 | mount_max_depth = mounthole_max_depth ? mounthole_max_depth : mounthole_depth+1; |
96 | filament_elevation=protrusion_h+pulley_elevation+teeth_elevation; | 96 | filament_elevation=protrusion_h+pulley_elevation+teeth_elevation; |
97 | ls_z = filament_elevation; // leverspace mid-z | 97 | ls_z = filament_elevation; // leverspace mid-z |
98 | ls_h = lever_thickness+lever_v_clearance; // leverspace height | 98 | ls_h = lever_thickness+lever_v_clearance; // leverspace height |
99 | mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell); | 99 | mount_depth = mount_screw_l - (ls_z+ls_h/2+min_z_shell); |
100 | body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2); | 100 | body_h = max(protrusion_h+bore_l,mount_screw_l-mount_depth+mount_screwhead_h+min_z_shell,ls_z*2); |
101 | echo("mount depth",mount_depth); | 101 | echo("mount depth",mount_depth); |
102 | 102 | ||
103 | module teardrop(r,d,h,center=false,angle=45) { | 103 | module teardrop(r,d,h,center=false,angle=45) { |
104 | dd = d ? d : (2*r); | 104 | dd = d ? d : (2*r); |
105 | $fn = dd*fnd; | 105 | $fn = dd*fnd; |
106 | cylinder(d=dd,h=h,center=center); | 106 | cylinder(d=dd,h=h,center=center); |
107 | if(angle>0) translate([0,0,center?-h/2:0]) | 107 | if(angle>0) translate([0,0,center?-h/2:0]) |
108 | rotate([0,0,angle]) | 108 | rotate([0,0,angle]) |
109 | cube(size=[d/2,d/2,h]); | 109 | cube(size=[d/2,d/2,h]); |
110 | } | 110 | } |
111 | 111 | ||
112 | module mirrorleft() { | 112 | module mirrorleft() { |
113 | mirror([left?0:1,0,0]) children(); | 113 | mirror([left?0:1,0,0]) children(); |
114 | } | 114 | } |
115 | module place_idler() { | 115 | module place_idler() { |
116 | rotate([0,0,45]) | 116 | rotate([0,0,45]) |
117 | translate([(pulley_d+idler_d)/2,0,0]) | 117 | translate([(pulley_d+idler_d)/2,0,0]) |
118 | children(); | 118 | children(); |
119 | } | 119 | } |
120 | module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) { | 120 | module finger_indent(d=lever_thickness,depth/*=1*/,r/*=15*/) { |
121 | if(depth) { | 121 | if(depth) { |
122 | hh = (-4*pow(depth,2)+pow(d,2))/(8*depth); | 122 | hh = (-4*pow(depth,2)+pow(d,2))/(8*depth); |
123 | rr = depth+hh; | 123 | rr = depth+hh; |
124 | translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr); | 124 | translate([0,0,hh]) sphere(r=rr,$fn=fnr*rr); |
125 | }else if(r) { | 125 | }else if(r) { |
126 | hh=sqrt(pow(r,2)-pow(d,2)/4); | 126 | hh=sqrt(pow(r,2)-pow(d,2)/4); |
127 | translate([0,0,hh]) sphere(r=r,$fn=fnr*r); | 127 | translate([0,0,hh]) sphere(r=r,$fn=fnr*r); |
128 | } | 128 | } |
129 | } | 129 | } |
130 | 130 | ||
131 | % if(vitamins) mirrorleft() { | 131 | % if(vitamins) mirrorleft() { |
132 | translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60); | 132 | translate([0,0,-epsilon]) mirror([0,0,1]) cylinder(d=gearbox_d,h=1,$fn=60); |
133 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) | 133 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) |
134 | cylinder(d=mount_screw_d,h=20,$fn=30); | 134 | cylinder(d=mount_screw_d,h=20,$fn=30); |
135 | translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30); | 135 | translate([0,0,-epsilon]) cylinder(d=protrusion_d,h=protrusion_h,$fn=30); |
136 | translate([0,0,protrusion_h]) { | 136 | translate([0,0,protrusion_h]) { |
137 | difference() { | 137 | difference() { |
138 | cylinder(d=bore_d,h=bore_l,$fn=30); | 138 | cylinder(d=bore_d,h=bore_l,$fn=30); |
139 | translate([-bore_d/2-1,bore_dd-bore_d/2,-1]) | 139 | translate([-bore_d/2-1,bore_dd-bore_d/2,-1]) |
140 | cube([bore_d+2,bore_d/2,bore_l+2]); | 140 | cube([bore_d+2,bore_d/2,bore_l+2]); |
141 | } | 141 | } |
142 | translate([0,0,pulley_elevation]) { | 142 | translate([0,0,pulley_elevation]) { |
143 | cylinder(d=pulley_d,h=pulley_h,$fn=30); | 143 | cylinder(d=pulley_d,h=pulley_h,$fn=30); |
144 | translate([0,0,teeth_elevation]) { | 144 | translate([0,0,teeth_elevation]) { |
145 | place_idler() { | 145 | place_idler() { |
146 | cylinder(d=idler_d,h=idler_h,center=true,$fn=30); | 146 | cylinder(d=idler_d,h=idler_h,center=true,$fn=30); |
147 | cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); | 147 | cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); |
148 | }//place idler | 148 | }//place idler |
149 | // filament path | 149 | // filament path |
150 | rotate([0,0,45]) { | 150 | rotate([0,0,45]) { |
151 | translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) { | 151 | translate([pulley_d/2-idler_filament_offset,0,0]) rotate([90,0,0]) { |
152 | cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); | 152 | cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); |
153 | }//rotate translate | 153 | }//rotate translate |
154 | translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) { | 154 | translate([pulley_d/2+filament_offset,0,0]) rotate([-90,0,0]) { |
155 | cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); | 155 | cylinder(d=filament_d,h=gearbox_d,center=false,$fn=15); |
156 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d]) | 156 | translate([0,0,mount_d/sqrt(2)/2+mount_screw_d]) |
157 | pushfit(pf); | 157 | pushfit(pf); |
158 | }//rotate translate | 158 | }//rotate translate |
159 | }//rotate | 159 | }//rotate |
160 | }//translate teeth | 160 | }//translate teeth |
161 | }//translate pulley | 161 | }//translate pulley |
162 | }//translate protrusion | 162 | }//translate protrusion |
163 | }//vitamins | 163 | }//vitamins |
164 | 164 | ||
165 | module lever() { | 165 | module lever() { |
166 | translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) { | 166 | translate([0,0,protrusion_h+pulley_elevation+teeth_elevation]) { |
167 | difference() { | 167 | difference() { |
168 | union() { | 168 | union() { |
169 | hull() { | 169 | hull() { |
170 | place_idler() | 170 | place_idler() |
171 | cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); | 171 | cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); |
172 | translate([mount_d/2,0,0]) | 172 | translate([mount_d/2,0,0]) |
173 | cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); | 173 | cylinder(d=lsd,h=lever_thickness,center=true,$fn=60); |
174 | }//hull | 174 | }//hull |
175 | hull() { | 175 | hull() { |
176 | translate([mount_d/2,0,0]) | 176 | translate([mount_d/2,0,0]) |
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,-longwing,0]) rotate([0,90,0]) | 178 | translate([mount_d/2,-longwing,0]) rotate([0,90,0]) |
179 | cylinder(d=lever_thickness,h=lsd,center=true,$fn=60); | 179 | cylinder(d=lever_thickness,h=lsd,center=true,$fn=60); |
180 | }//hull | 180 | }//hull |
181 | }//union | 181 | }//union |
182 | 182 | ||
183 | // filament path | 183 | // filament path |
184 | place_idler() | 184 | place_idler() |
185 | translate([-idler_d/2-idler_filament_offset,0,0]) | 185 | translate([-idler_d/2-idler_filament_offset,0,0]) |
186 | rotate([90,0,0]) { | 186 | rotate([90,0,0]) { |
187 | mirror([0,1,0]) | 187 | mirror([0,1,0]) |
188 | teardrop(d=filament_path_d,h=3*gearbox_d,center=true); | 188 | teardrop(d=filament_path_d,h=3*gearbox_d,center=true); |
189 | translate([0,0, | 189 | translate([0,0, |
190 | sqrt(2)*(mount_d-pulley_d+lsd)/2 | 190 | sqrt(2)*(mount_d-pulley_d+lsd)/2 |
191 | ]) { | 191 | ]) { |
192 | cylinder(d1=filament_path_d,d2=2*filament_path_d, | 192 | cylinder(d1=filament_path_d,d2=2*filament_path_d, |
193 | h=filament_path_d,$fn=2*filament_path_d*fnd); | 193 | h=filament_path_d,$fn=2*filament_path_d*fnd); |
194 | translate([0,0,filament_path_d-epsilon]) | 194 | translate([0,0,filament_path_d-epsilon]) |
195 | cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd); | 195 | cylinder(d=2*filament_path_d,h=lsd*sqrt(2),$fn=2*filament_path_d*fnd); |
196 | }//translate | 196 | }//translate |
197 | }//rotate translate place_idler | 197 | }//rotate translate place_idler |
198 | 198 | ||
199 | // idler space and mounting hole | 199 | // idler space and mounting hole |
200 | place_idler() { | 200 | place_idler() { |
201 | difference() { | 201 | cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); |
202 | cylinder(d=idler_d+idler_clearance*2,h=idler_h+idler_v_tolerance,center=true,$fn=60); | ||
203 | if(supports) for(y=[-lsd/2+extrusion_width:(lsd-2*extrusion_width)/3:lsd/2-extrusion_width]) | ||
204 | translate([-lsd/2-1,y-extrusion_width/2,-idler_h/2-idler_v_tolerance/2-1]) | ||
205 | cube(size=[lsd+2,extrusion_width,idler_h+idler_v_tolerance+2]); | ||
206 | } | ||
207 | cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); | 202 | cylinder(d=idler_screw_d,h=lever_thickness+2,center=true,$fn=30); |
208 | translate([0,0,lever_thickness/2-idler_screwhead_h]) | 203 | translate([0,0,lever_thickness/2-idler_screwhead_h]) |
209 | cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d); | 204 | cylinder(d=idler_screwhead_d,h=idler_screwhead_h+1,$fn=fnd*idler_screwhead_d); |
210 | } | 205 | } |
211 | // mounting screw hole | 206 | // mounting screw hole |
212 | translate([mount_d/2,0,0]) | 207 | translate([mount_d/2,0,0]) |
213 | cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); | 208 | cylinder(d=mount_screw_d+mount_screw_d_tolerance,h=lever_thickness+2,center=true,$fn=fnd*mount_screw_d); |
214 | 209 | ||
215 | // lever end | 210 | // lever end |
216 | translate([mount_d/2,0,0]) rotate([0,90,0]) { | 211 | translate([mount_d/2,0,0]) rotate([0,90,0]) { |
217 | translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); | 212 | translate([0,-longwing,lsd/2]) finger_indent(d=lever_thickness-1,r=15); |
218 | translate([0,-longwing,0]) | 213 | translate([0,-longwing,0]) |
219 | mirror([0,0,1]) | 214 | mirror([0,0,1]) |
220 | difference() { | 215 | difference() { |
221 | cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); | 216 | cylinder(d=spring_d+spring_d_clearance,h=lsd,$fn=fnd*(spring_d+spring_d_clearance)); |
222 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 217 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
223 | } | 218 | } |
224 | }//rotate-translate | 219 | }//rotate-translate |
225 | }//difference | 220 | }//difference |
226 | // bridging patch | 221 | // bridging patch |
227 | if(bridges) place_idler() | 222 | if(bridges) place_idler() |
228 | translate([0,0,lever_thickness/2-mount_screwhead_h]) | 223 | translate([0,0,lever_thickness/2-mount_screwhead_h]) |
229 | mirror([0,0,1]) | 224 | mirror([0,0,1]) |
230 | cylinder(d=mount_screwhead_d,h=layer_height); | 225 | cylinder(d=mount_screwhead_d,h=layer_height); |
231 | }//translate | 226 | }//translate |
232 | }//lever module | 227 | }//lever module |
233 | 228 | ||
234 | module body() { | 229 | module body() { |
235 | difference() { | 230 | difference() { |
236 | union() { | 231 | union() { |
237 | cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); | 232 | cylinder(d=gearbox_d,h=body_h,$fn=fnd*gearbox_d); |
238 | // spring tensioner part | 233 | // spring tensioner part |
239 | translate([-gearbox_d/2,0,0]) hull() { | 234 | translate([-gearbox_d/2,0,0]) hull() { |
240 | translate([0,-longwing,ls_z]) | 235 | translate([0,-longwing,ls_z]) |
241 | rotate([0,90,0]) | 236 | rotate([0,90,0]) |
242 | cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); | 237 | cylinder(d=lever_thickness,h=fsw,$fn=fnd*lever_thickness); |
243 | hh=body_h-ls_z; | 238 | hh=body_h-ls_z; |
244 | translate([0,0,ls_z]) | 239 | translate([0,0,ls_z]) |
245 | mirror([0,1,0]) cube(size=[fsw,longwing+(st_thinshell+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]); | 240 | mirror([0,1,0]) cube(size=[fsw,longwing+(st_thinshell+st_split_w_tolerance)/2+st_thickshell,body_h-ls_z]); |
246 | hhh=ls_z; | 241 | hhh=ls_z; |
247 | translate([0,0,0]) | 242 | translate([0,0,0]) |
248 | mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); | 243 | mirror([0,1,0]) cube(size=[fsw,longwing-hhh+lever_thickness/sqrt(2),hhh+lever_thickness/2]); |
249 | }//hull translate | 244 | }//hull translate |
250 | 245 | ||
251 | // pushfit bracket | 246 | // pushfit bracket |
252 | translate([0,0,filament_elevation]) | 247 | translate([0,0,filament_elevation]) |
253 | rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) | 248 | rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) |
254 | rotate([-90,0,0]) | 249 | rotate([-90,0,0]) |
255 | 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:*/]) { |
256 | pfbl = pf_h(pf)+gearbox_d/2; //TODO: | 251 | pfbl = pf_h(pf)+gearbox_d/2; //TODO: |
257 | if(pf_smooth) { | 252 | if(pf_smooth) { |
258 | pfbd = pf_d(pf)+2*pf_shell; | 253 | pfbd = pf_d(pf)+2*pf_shell; |
259 | hull() { | 254 | hull() { |
260 | cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd); | 255 | cylinder(d=pfbd,h=pfbl,$fn=pfbd*fnd); |
261 | translate([-epsilon/2,0,0]) { | 256 | translate([-epsilon/2,0,0]) { |
262 | cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]); | 257 | cube(size=[epsilon,filament_elevation,pfbl-filament_elevation+pfbd/2]); |
263 | mirror([0,1,0]) | 258 | mirror([0,1,0]) |
264 | cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]); | 259 | cube(size=[epsilon,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfbd/2]); |
265 | }//translate | 260 | }//translate |
266 | }//hull | 261 | }//hull |
267 | }else{ | 262 | }else{ |
268 | pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; | 263 | pfb2a = pf_d(pf)+2*pf_shell; pfba = pfb2a/2; |
269 | pfbd = pfb2a/cos(30); | 264 | pfbd = pfb2a/cos(30); |
270 | pfbs = pfb2a*tan(30); | 265 | pfbs = pfb2a*tan(30); |
271 | cylinder(d=pfbd,h=pfbl,$fn=6); | 266 | cylinder(d=pfbd,h=pfbl,$fn=6); |
272 | translate([-pfbs/2,0,0]) { | 267 | translate([-pfbs/2,0,0]) { |
273 | hull() { | 268 | hull() { |
274 | translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); | 269 | translate([0,-pfba,0]) cube(size=[pfbs,pfb2a,pfbl]); |
275 | cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); | 270 | cube(size=[pfbs,filament_elevation,pfbl-filament_elevation+pfba]); |
276 | mirror([0,1,0]) | 271 | mirror([0,1,0]) |
277 | cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); | 272 | cube(size=[pfbs,body_h-filament_elevation,pfbl-body_h+filament_elevation+pfba]); |
278 | }//hull | 273 | }//hull |
279 | }//translate*/ | 274 | }//translate*/ |
280 | }//if(pf_smooth) | 275 | }//if(pf_smooth) |
281 | }//translate rotate translate rotate translate | 276 | }//translate rotate translate rotate translate |
282 | }//union (first child of difference) | 277 | }//union (first child of difference) |
283 | 278 | ||
284 | // protrusion | 279 | // protrusion |
285 | translate([0,0,-1]) | 280 | translate([0,0,-1]) |
286 | cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); | 281 | cylinder(d=protrusion_d+protrusion_tolerance_h,h=protrusion_h+protrusion_tolerance_v+1,$fn=fnd*(protrusion_d+protrusion_tolerance_h)); |
287 | // mount screw holes | 282 | // mount screw holes |
288 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { | 283 | for(zr=[0:90:359]) rotate([0,0,zr]) translate([mount_d/2,0,0]) { |
289 | translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)]) | 284 | translate([0,0,mount_screw_l-mount_depth-(bridges?layer_height:-epsilon)]) |
290 | mirror([0,0,1]) | 285 | mirror([0,0,1]) |
291 | cylinder(d=mount_screw_d+mount_screw_d_tolerance, | 286 | cylinder(d=mount_screw_d+mount_screw_d_tolerance, |
292 | h=mount_screw_l-mount_depth+1, | 287 | h=mount_screw_l-mount_depth+1, |
293 | $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); | 288 | $fn=fnd*(mount_screw_d+mount_screw_d_tolerance)); |
294 | translate([0,0,mount_screw_l-mount_depth]) | 289 | translate([0,0,mount_screw_l-mount_depth]) |
295 | cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); | 290 | cylinder(d=mount_screwhead_d,h=body_h+1,$fn=fnd*mount_screwhead_d); |
296 | }//for | 291 | }//for |
297 | // pushfit | 292 | // pushfit |
298 | pf_offset = mount_d/sqrt(2)/2+mount_screw_d; | 293 | pf_offset = mount_d/sqrt(2)/2+mount_screw_d; |
299 | translate([0,0,filament_elevation]) | 294 | translate([0,0,filament_elevation]) |
300 | rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) | 295 | rotate([0,0,45]) translate([pulley_d/2+filament_offset,0,0]) |
301 | rotate([-90,0,0]) | 296 | rotate([-90,0,0]) |
302 | translate([0,0,pf_offset]) | 297 | translate([0,0,pf_offset]) |
303 | rotate([0,0,180]) { | 298 | rotate([0,0,180]) { |
304 | pushfit(pf); | 299 | pushfit(pf); |
305 | mirror([0,0,1]) { | 300 | mirror([0,0,1]) { |
306 | fh = 1.5* (filament_guide_d-filament_path_d)/2; | 301 | fh = 1.5* (filament_guide_d-filament_path_d)/2; |
307 | fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh; | 302 | fo = pf_offset -filament_path_d /*(idler_d+idler_clearance)/2*/-fh; |
308 | translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225); | 303 | translate([0,0,-1]) teardrop(d=filament_guide_d,h=fo/2,angle=225); |
309 | translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225); | 304 | translate([0,0,-1]) teardrop(d=filament_path_d,h=gearbox_d/2+1,angle=-225); |
310 | translate([0,0,fo+epsilon]) | 305 | translate([0,0,fo+epsilon]) |
311 | cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d); | 306 | cylinder(d1=filament_path_d,d2=filament_guide_d,h=fh,$fn=fnd*filament_guide_d); |
312 | }//mirror | 307 | }//mirror |
313 | }//rotate translate rotate translate rotate translate | 308 | }//rotate translate rotate translate rotate translate |
314 | // pulley | 309 | // pulley |
315 | cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); | 310 | cylinder(d=pulley_d+pulley_small_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); |
316 | cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance)); | 311 | cylinder(d=pulley_d+pulley_d_clearance,ls_z-max(idler_h,filament_guide_d)/2,$fn=fnd*(pulley_d+pulley_d_clearance)); |
317 | 312 | ||
318 | translate([0,0,ls_z-ls_h/2]) { | 313 | translate([0,0,ls_z-ls_h/2]) { |
319 | // idler travel | 314 | // idler travel |
320 | translate([mount_d/2,0,0]) | 315 | translate([mount_d/2,0,0]) |
321 | rotate([0,0,45]) | 316 | rotate([0,0,45]) |
322 | rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2)) | 317 | rotate_extrude(angle=90,$fn=fnr*(shortwing+(idler_d+idler_clearance)/2)) |
323 | square([shortwing+(idler_d+idler_clearance)/2,ls_h]); | 318 | square([shortwing+(idler_d+idler_clearance)/2,ls_h]); |
324 | // idler itself | 319 | // idler itself |
325 | place_idler() | 320 | place_idler() |
326 | cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); | 321 | cylinder(d=idler_d+idler_clearance,h=ls_h,$fn=fnd*(idler_d+idler_clearance)); |
327 | // lever space | 322 | // lever space |
328 | rotate([0,0,45]) | 323 | rotate([0,0,45]) |
329 | rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1))) | 324 | rotate_extrude(angle=-135+max(atan(2*fsw/gearbox_d-1),atan(gearbox_d/mount_d-1))) |
330 | square([gearbox_d/2+1,ls_h]); | 325 | square([gearbox_d/2+1,ls_h]); |
331 | } | 326 | } |
332 | 327 | ||
333 | // back side cutout | 328 | // back side cutout |
334 | // XXX: this is somewhat ugly and potentially bugged, | 329 | // XXX: this is somewhat ugly and potentially bugged, |
335 | // but I want to sleep. | 330 | // but I want to sleep. |
336 | a0_ = atan( | 331 | a0_ = atan( |
337 | (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2) | 332 | (mount_d/sqrt(2)/2+mount_screw_d+pf_h(pf)+gearbox_d/2) |
338 | / | 333 | / |
339 | ( | 334 | ( |
340 | pulley_d/2+filament_offset- | 335 | pulley_d/2+filament_offset- |
341 | (pf_d(pf)+2*pf_shell)/2/cos(30) | 336 | (pf_d(pf)+2*pf_shell)/2/cos(30) |
342 | ) | 337 | ) |
343 | ); | 338 | ); |
344 | a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ ); | 339 | a0 = -135 + ( (a0_>0) ? a0_ : 180+a0_ ); |
345 | a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); | 340 | a1 = atan((longwing-lever_thickness/2)/(gearbox_d/2)); |
346 | translate([0,0,ls_z]) difference() { | 341 | translate([0,0,ls_z]) difference() { |
347 | rotate([0,0,-180+a0]) | 342 | rotate([0,0,-180+a0]) |
348 | rotate_extrude(angle=a1-a0) | 343 | rotate_extrude(angle=a1-a0) |
349 | translate([0,-ls_h/2]) | 344 | translate([0,-ls_h/2]) |
350 | square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, | 345 | square([sqrt(pow(gearbox_d/2,2)+pow(longwing-lever_thickness/2,2))+1, |
351 | ls_h]); | 346 | ls_h]); |
352 | translate([-mount_d/2,0,0]) | 347 | translate([-mount_d/2,0,0]) |
353 | cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d)); | 348 | cylinder(d=gearbox_d-mount_d,h=ls_h+2,center=true,$fn=fnd*(gearbox_d-mount_d)); |
354 | }//difference translate | 349 | }//difference translate |
355 | 350 | ||
356 | //translate([-mount_d/2,-longwing,filament_elevation]) | 351 | //translate([-mount_d/2,-longwing,filament_elevation]) |
357 | if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ | 352 | if(!tensioner) /* XXX: this seems to be bullshit, but it's so old, that it's historical bullshit */ |
358 | translate([mount_d/2,-longwing,filament_elevation]) | 353 | translate([mount_d/2,-longwing,filament_elevation]) |
359 | rotate([0,-90,0]) difference() { | 354 | rotate([0,-90,0]) difference() { |
360 | cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); | 355 | cylinder(d=spring_d+spring_d_clearance,h=spring_lc+spring_dl,$fn=fnd*(spring_d+spring_d_clearance)); |
361 | translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 356 | translate([0,0,spring_lc+spring_dl]) sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
362 | } | 357 | } |
363 | 358 | ||
364 | // spring tensioner | 359 | // spring tensioner |
365 | translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) { | 360 | translate([-gearbox_d/2,-longwing,ls_z]) rotate([0,-90,0]) { |
366 | if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { | 361 | if(!tensioner) finger_indent(d=lever_thickness-1,r=15); else { |
367 | mirror([0,0,1]) { | 362 | mirror([0,0,1]) { |
368 | translate([0,0,st_thickshell]) | 363 | translate([0,0,st_thickshell]) |
369 | hull() for(o=[0,spring_d]) translate([0,-o,0]) | 364 | hull() for(o=[0,spring_d]) translate([0,-o,0]) |
370 | rotate([0,0,30]) | 365 | rotate([0,0,30]) |
371 | cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); | 366 | cylinder(d=st_nut_d+st_nut_d_tolerance,h=st_nut_h+st_nut_h_tolerance,$fn=6); |
372 | 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)); | 367 | 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)); |
373 | bigd = spring_d+spring_d_clearance; | 368 | bigd = spring_d+spring_d_clearance; |
374 | hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; | 369 | hf = (bigd-st_screw_d-st_screw_d_tolerance)/2; |
375 | translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) { | 370 | translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell-epsilon]) { |
376 | cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, | 371 | cylinder(d1=st_screw_d+st_screw_d_tolerance,d2=bigd, |
377 | h=hf+epsilon, $fn=fnd*bigd); | 372 | h=hf+epsilon, $fn=fnd*bigd); |
378 | translate([0,-(st_thinshell+st_split_w_tolerance)/2,0]) | 373 | translate([0,-(st_thinshell+st_split_w_tolerance)/2,0]) |
379 | cube(size=[body_h-ls_z+1,st_thinshell+st_split_w_tolerance,fsw+1]); | 374 | cube(size=[body_h-ls_z+1,st_thinshell+st_split_w_tolerance,fsw+1]); |
380 | } | 375 | } |
381 | translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) | 376 | translate([0,0,st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+hf-epsilon]) |
382 | cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); | 377 | cylinder(d=bigd,h=fsw+1,$fn=fnd*bigd); |
383 | } | 378 | } |
384 | } | 379 | } |
385 | } | 380 | } |
386 | 381 | ||
387 | }//difference | 382 | }//difference |
388 | 383 | ||
389 | if(supports) intersection() { | ||
390 | difference() { | ||
391 | translate([0,0,ls_z-ls_h/2-epsilon]) | ||
392 | cylinder(d=gearbox_d,h=ls_h+2*epsilon,$fn=fnd*gearbox_d); | ||
393 | cylinder(d=pulley_d+pulley_d_clearance,h=body_h+1,$fn=fnd*(pulley_d+pulley_d_clearance)); | ||
394 | } | ||
395 | // supports | ||
396 | // TODO: hardcoded stuff below… | ||
397 | if(false) { // parallel | ||
398 | for(y=[-gearbox_d:4:gearbox_d]) | ||
399 | translate([0,y-extrusion_width/2,0]) | ||
400 | cube(size=[gearbox_d,extrusion_width,body_h]); | ||
401 | }else{ // radial | ||
402 | for(zr=[-65:(65+50)/7:50]) | ||
403 | rotate([0,0,zr]) translate([0,-extrusion_width/2,0]) | ||
404 | cube(size=[gearbox_d,extrusion_width,body_h]); | ||
405 | } | ||
406 | } | ||
407 | |||
408 | }//body module | 384 | }//body module |
409 | 385 | ||
410 | module springpad() { | 386 | module springpad() { |
411 | smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; | 387 | smalld=st_screw_d+st_screw_d_tolerance+min_xy_shell; |
412 | bigd = spring_d+spring_d_clearance/2; | 388 | bigd = spring_d+spring_d_clearance/2; |
413 | hf = (bigd-smalld)/2; | 389 | hf = (bigd-smalld)/2; |
414 | h = hf*3.5; | 390 | h = hf*3.5; |
415 | translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) | 391 | translate([-gearbox_d/2+st_thickshell+st_nut_h+st_nut_h_tolerance+st_thinshell+1,-longwing,filament_elevation]) |
416 | rotate([0,90,0]) difference() { | 392 | rotate([0,90,0]) difference() { |
417 | union() { | 393 | union() { |
418 | cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); | 394 | cylinder(d1=smalld,d2=bigd,h=hf,$fn=fnd*bigd); |
419 | translate([0,0,hf-epsilon]) | 395 | translate([0,0,hf-epsilon]) |
420 | cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); | 396 | cylinder(d=bigd,h=h-hf,$fn=fnd*bigd); |
421 | translate([0,0,h]) | 397 | translate([0,0,h]) |
422 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); | 398 | sphere(d=spring_d*3/4,$fn=fnd*spring_d*3/4); |
423 | l = body_h-ls_z; | 399 | l = body_h-ls_z; |
424 | w = st_thinshell; | 400 | w = st_thinshell; |
425 | hull() translate([0,-st_thinshell/2,0]) mirror([1,0,0]) { | 401 | hull() translate([0,-st_thinshell/2,0]) mirror([1,0,0]) { |
426 | translate([0,0,w]) | 402 | translate([0,0,w]) |
427 | cube(size=[l,st_thinshell,w]); | 403 | cube(size=[l,st_thinshell,w]); |
428 | cube(size=[l-w,st_thinshell,2*w]); | 404 | cube(size=[l-w,st_thinshell,2*w]); |
429 | } | 405 | } |
430 | } | 406 | } |
431 | translate([0,0,-epsilon]) | 407 | translate([0,0,-epsilon]) |
432 | cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); | 408 | cylinder(d=st_screw_d+st_screw_d_tolerance,h=2*hf+epsilon,$fn=fnd*(st_screw_d+st_screw_d_tolerance)); |
433 | } | 409 | } |
434 | } | 410 | } |
435 | 411 | ||
436 | module knob() { | 412 | module knob() { |
437 | ch = knob_indent_d/2; | 413 | ch = knob_indent_d/2; |
438 | translate([0,0,body_h+epsilon]) { | 414 | translate([0,0,body_h+epsilon]) { |
439 | mirror([0,0,1]) translate([0,0,-epsilon]) { | 415 | mirror([0,0,1]) translate([0,0,-epsilon]) { |
440 | difference() { | 416 | difference() { |
441 | cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); | 417 | cylinder(d=pulley_d,h=knob_bore_l,$fn=fnd*pulley_d); |
442 | translate([0,0,-1]) difference() { | 418 | translate([0,0,-1]) difference() { |
443 | cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); | 419 | cylinder(d=bore_d+knob_bore_d_tolerance,h=knob_bore_l+2); |
444 | translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) | 420 | translate([-bore_d/2-1,bore_dd-bore_d/2+knob_bore_d_tolerance/2,-1]) |
445 | cube([bore_d+2,bore_d/2,knob_bore_l+4]); | 421 | cube([bore_d+2,bore_d/2,knob_bore_l+4]); |
446 | } | 422 | } |
447 | } | 423 | } |
448 | } | 424 | } |
449 | difference() { | 425 | difference() { |
450 | union() { | 426 | union() { |
451 | cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); | 427 | cylinder(d1=gearbox_d-2*ch,d2=gearbox_d,h=ch+epsilon,$fn=fnd*gearbox_d); |
452 | translate([0,0,ch]) | 428 | translate([0,0,ch]) |
453 | cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); | 429 | cylinder(d=gearbox_d,h=knob_h-2*ch+epsilon,$fn=fnd*gearbox_d); |
454 | translate([0,0,knob_h-ch]) | 430 | translate([0,0,knob_h-ch]) |
455 | cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d); | 431 | cylinder(d1=gearbox_d,d2=gearbox_d-2*ch,h=ch,$fn=fnd*gearbox_d); |
456 | } | 432 | } |
457 | for(a=[0:360/knob_indents:359]) rotate([0,0,a]) | 433 | for(a=[0:360/knob_indents:359]) rotate([0,0,a]) |
458 | translate([0,gearbox_d/2,-1]) | 434 | translate([0,gearbox_d/2,-1]) |
459 | cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); | 435 | cylinder(d=knob_indent_d,h=knob_h+2,$fn=fnd*knob_indent_d); |
460 | } | 436 | } |
461 | } | 437 | } |
462 | }//knob module | 438 | }//knob module |
463 | 439 | ||
464 | module debug() { | 440 | module debug() { |
465 | difference() { | 441 | difference() { |
466 | children(); | 442 | children(); |
467 | if(debug) { | 443 | if(debug) { |
468 | // spring tensioner debug cutout | 444 | // spring tensioner debug cutout |
469 | if(tensioner) // TODO: collapse copypasted transformations | 445 | if(tensioner) // TODO: collapse copypasted transformations |
470 | translate([-gearbox_d/2,0,0]) | 446 | translate([-gearbox_d/2,0,0]) |
471 | translate([0,-longwing,ls_z]) rotate([0,-90,0]) | 447 | translate([0,-longwing,ls_z]) rotate([0,-90,0]) |
472 | translate([0,-lever_thickness/2-1,-gearbox_d]) | 448 | translate([0,-lever_thickness/2-1,-gearbox_d]) |
473 | cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); | 449 | cube(size=[body_h/2+1,lever_thickness/2+1,gearbox_d+2]); |
474 | // lever axis debug cutout | 450 | // lever axis debug cutout |
475 | translate([mount_d/2,0,-1]) | 451 | translate([mount_d/2,0,-1]) |
476 | rotate([0,0,-45]) | 452 | rotate([0,0,-45]) |
477 | cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]); | 453 | cube(size=[gearbox_d-mount_d,gearbox_d-mount_d,body_h+knob_h+2]); |
478 | // idler debug cutout | 454 | // idler debug cutout |
479 | translate([0,0,ls_z]) | 455 | translate([0,0,ls_z]) |
480 | place_idler() | 456 | place_idler() |
481 | rotate([0,0,-45]) | 457 | rotate([0,0,-45]) |
482 | translate([0,0,-lever_thickness/2-epsilon]) | 458 | translate([0,0,-lever_thickness/2-epsilon]) |
483 | cube(size=[(idler_d+idler_clearance)/2,(idler_d+idler_clearance)/2, | 459 | cube(size=[(idler_d+idler_clearance)/2,(idler_d+idler_clearance)/2, |
484 | lever_thickness+2*epsilon]); | 460 | lever_thickness+2*epsilon]); |
485 | // pushfit debug cutout | 461 | // pushfit debug cutout |
486 | place_idler() | 462 | place_idler() |
487 | translate([-idler_d/2+filament_offset,0,ls_z]) | 463 | translate([-idler_d/2+filament_offset,0,ls_z]) |
488 | cube(size=[gearbox_d/2,gearbox_d/2+pf_h(pf),body_h-ls_z+1]); | 464 | cube(size=[gearbox_d/2,gearbox_d/2+pf_h(pf),body_h-ls_z+1]); |
489 | }//if debug | 465 | }//if debug |
490 | }//difference | 466 | }//difference |
491 | } | 467 | } |
492 | 468 | ||
493 | mirrorleft() | 469 | mirrorleft() |
494 | debug() | 470 | debug() |
495 | if(what=="lever") color("green",0.7) lever(); | 471 | if(what=="lever") color("green",0.7) lever(); |
496 | else if(what=="body") color("yellow",0.7) body(); | 472 | else if(what=="body") color("yellow",0.7) body(); |
497 | else if(what=="knob") color("red",0.7) knob(); | 473 | else if(what=="knob") color("red",0.7) knob(); |
498 | else if(what=="springpad") color("blue",0.7) springpad(); | 474 | else if(what=="springpad") color("blue",0.7) springpad(); |
499 | else if(what=="both") { | 475 | else if(what=="both") { |
500 | color("green",0.7) lever(); | 476 | color("green",0.7) lever(); |
501 | color("yellow",0.7) body(); | 477 | color("yellow",0.7) body(); |
502 | }else{ | 478 | }else{ |
503 | color("green",0.7) lever(); | 479 | color("green",0.7) lever(); |
504 | color("yellow",0.7) body(); | 480 | color("yellow",0.7) body(); |
505 | color("red",0.7) knob(); | 481 | color("red",0.7) knob(); |
506 | color("blue",0.7) springpad(); | 482 | color("blue",0.7) springpad(); |
507 | } | 483 | } |
508 | } | 484 | } |
509 | 485 | ||
510 | the_extruder(what="*",left=false,debug=true); | 486 | the_extruder(what="*",left=false,debug=true); |