From: Ian Jackson Date: Sun, 16 Sep 2012 15:58:23 +0000 (+0100) Subject: splitpin wip, pin seems good X-Git-Tag: filamentspool-v2-release~810 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=commitdiff_plain;h=50ae9afd185f8d16b49702f981ff406cc9e03e5a splitpin wip, pin seems good --- diff --git a/splitpin.scad b/splitpin.scad index 7120037..6ef5bb3 100644 --- a/splitpin.scad +++ b/splitpin.scad @@ -6,45 +6,54 @@ tau = 6.28318530718; function deg2rad(deg) = deg/360 * tau; function rad2deg(rad) = rad/tau * 360; -module SplitPin(w=1.5, holeminrad=4, thick=3, deviationrad=1.5, - mainlen=20, handlerad=10, handlelen=7){ +module SplitPin(w=1.5, holeminrad=3.5, thick=3, deviationrad=1.0, + mainlen=20, handlerad=10, handlelen=7) { spare = holeminrad - deviationrad - w; echo("splitpin spare",spare); %translate([0,mainlen+handlelen,0]) cylinder(r=spare, h=thick); %translate([0,mainlen,thick/2]) rotate([90,0,0]) cylinder(r=holeminrad, h=thick); - bent_x0 = w*1.5; - bent_x1 = holeminrad; - bent_dx = bent_x1 - bent_x0; - bent_y1 = mainlen; - bent_dy = bent_y1; - bent_rad = (bent_dy / bent_dx) * bent_dy; - bent_subang = atan(bent_dx / bent_dy); - actual_mainlen = bent_rad * deg2rad(bent_subang); - + bent_dx = holeminrad; unbent_dx = bent_dx + deviationrad; - unbent_subang = atan(unbent_dx / actual_mainlen); - unbent_rad = actual_mainlen / deg2rad(unbent_subang); - main_cx = w*1.5 + unbent_rad; + unbent_subang = atan(unbent_dx / mainlen); + unbent_rad = mainlen / deg2rad(unbent_subang); + + corner_x = unbent_rad * (1 - cos(unbent_subang)); + corner_y = unbent_rad * sin(unbent_subang); + + main_cx = unbent_rad; + +// translate([w*1.5, 0, 0]) { +// translate([corner_x, corner_y, 10]) %cube([10,10,10]); +// translate([bent_dx, 0, 10]) %cube([10,10,10]); +// translate([unbent_dx, 5, 10]) %cube([10,10,10]); +// } for (xmir=[0,1]) mirror([xmir,0,0]) { linear_extrude(height=thick) { FlatArc(0,0, w*0.5, w*1.5, 270-1,360); - FlatArc($fa=1, main_cx,0, unbent_rad, unbent_rad+w, - 180-unbent_subang, 180); - translate([unbent_rad * (1 - cos(unbent_subang)) + w*1.5, - unbent_rad * sin(unbent_subang)]) - rotate([0,0,-unbent_subang]) { - translate([-(w + deviationrad), -0.1]) - square(size=[w + deviationrad, w+0.1]); - FlatArc(-deviationrad + handlerad, w, - handlerad, handlerad+w, - 180-rad2deg(handlelen/handlerad), 180); + translate([w*1.5, 0, 0]) { + FlatArc($fa=1, main_cx,0, unbent_rad, unbent_rad+w, + 180-unbent_subang, 180); + translate([corner_x, corner_y]) + rotate([0,0,-unbent_subang]) { + translate([-(w + deviationrad), -0.1]) + square(size=[w + deviationrad, w+0.1]); + FlatArc(-deviationrad + handlerad, w, + handlerad, handlerad+w, + 180-rad2deg(handlelen/handlerad), 180, + $fa=0.25, $fn=60); + } } } } } +module SplitPinCavity(w=1.5, holeminrad=3.5, thick=3, deviationrad=1.0, + mainlen=20) { + +} + SplitPin();