+ mirror([0,0,1]) translate([0,0,-1])
+ cylinder(r= leg_hole_dia/2,
+ h= (!TEST ? leg_height+2 : leg_height/2),
+ $fn=30);
+ mirror([0,0,1]) translate([0,0,leg_top_thick - 0.1])
+ hull(){
+ cylinder(r= (!TEST ? leg_midspc_dia/2 : 0.1),
+ h= leg_height - leg_top_thick - leg_bot_thick + 0.2,
+ $fn=30);
+ if (TEST)
+ cylinder(r= leg_midspc_dia/2,
+ h= leg_height - leg_top_thick - leg_bot_thick
+ + (!TEST ? 0.2 : -leg_midspc_dia/2),
+ $fn=30);
+ }
+ cid_shear = (leg_fin_bot_w - leg_fin_top_w)/2 /
+ (leg_height -leg_fin_bot_flat_z);
+ multmatrix([[ 1, 0, 0, leg_midspc_dia/2 ],
+ [ 0, cid_shear,
+ 1, -leg_fin_bot_w/2 ],
+ [ 0, 1, 0, -leg_height + leg_fin_bot_flat_z ],
+ [ 0, 0, 0, 1 ]])
+ Commitid_BestCount([ leg_big_dia/2 - leg_midspc_dia/2,
+ leg_height - leg_fin_bot_flat_z
+ - leg_top_thick ]);
+ if (!TEST)
+ for (rot=[45: 360/leg_n_tubules : 359]) rotate(rot) {
+ mirror([0,0,1]) translate([ leg_tubule_pos_rad, 0, -1])
+ cylinder(r= leg_tubule_dia/2, h=leg_height+2, $fn=20);
+ }