//////////////////////////////////////////////////////////////////////
// LibFile: phillips_drive.scad
//   Phillips driver bits
//   To use, add these lines to the top of your file:
//   ```
//   include <BOSL2/std.scad>
//   include <BOSL2/phillips_drive.scad>
//   ```
//////////////////////////////////////////////////////////////////////


// Section: Modules


// Module: phillips_drive()
// Description: Creates a model of a phillips driver bit of a given named size.
// Arguments:
//   size = The size of the bit as a string.  "#0", "#1", "#2", "#3", or "#4"
//   shaft = The diameter of the drive bit's shaft.
//   l = The length of the drive bit.
//   anchor = Translate so anchor point is at origin (0,0,0).  See [anchor](attachments.scad#anchor).  Default: `CENTER`
//   spin = Rotate this many degrees around the Z axis after anchor.  See [spin](attachments.scad#spin).  Default: `0`
//   orient = Vector to rotate top towards, after spin.  See [orient](attachments.scad#orient).  Default: `UP`
// Example:
//   xdistribute(10) {
//      phillips_drive(size="#1", shaft=4, l=20);
//      phillips_drive(size="#2", shaft=6, l=20);
//      phillips_drive(size="#3", shaft=6, l=20);
//   }
module phillips_drive(size="#2", shaft=6, l=20, $fn=36, anchor=BOTTOM, spin=0, orient=UP) {
    assert(is_string(size));
    assert(in_list(size,["#0","#1","#2","#3","#4"]));

    num = ord(size[1]) - ord("0");
    b =     [0.61, 0.97, 1.47, 2.41, 3.48][num];
    e =     [0.31, 0.43, 0.81, 2.00, 2.41][num];
    g =     [0.81, 1.27, 2.29, 3.81, 5.08][num];
    //f =     [0.33, 0.53, 0.70, 0.82, 1.23][num];
    //r =     [0.30, 0.50, 0.60, 0.80, 1.00][num];
    alpha = [ 136,  138,  140,  146,  153][num];
    beta  = [7.00, 7.00, 5.75, 5.75, 7.00][num];
    gamma = 92.0;
    ang1 = 28.0;
    ang2 = 26.5;
    h1 = adj_ang_to_opp(g/2, ang1);
    h2 = adj_ang_to_opp((shaft-g)/2, 90-ang2);
    h3 = adj_ang_to_opp(b/2, ang1);
    p0 = [0,0];
    p1 = [e/2, adj_ang_to_opp(e/2, 90-alpha/2)];
    p2 = p1 + [(shaft-e)/2, adj_ang_to_hyp((shaft-e)/2, 90-gamma/2)];
    attachable(anchor,spin,orient, d=shaft, l=l) {
        down(l/2) {
            difference() {
                union() {
                    cyl(d1=0, d2=g, h=h1, anchor=BOT);
                    up(h1) {
                        cyl(d1=g, d2=shaft, h=h2, anchor=BOT);
                        up(h2) cyl(d=shaft, h=l-h1-h2, anchor=BOT);
                    }
                }
                zrot(45)
                zrot_copies(n=4, r=b/2/cos(90-alpha/2), sa=90) {
                    up(h3) {
                        xrot(-beta) {
                            linear_extrude(height=(h1+h2)*20, convexity=4, center=true) {
                                path = [p0, p1, p2, [-p2.x,p2.y], [-p1.x,p1.y]];
                                polygon(path);
                            }
                        }
                    }
                }
            }
        }
        children();
    }
}


// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap