X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=reprap-play.git;a=blobdiff_plain;f=pawn.scad;h=7277dcda5218dc7026ee7ece0bfc2f3a682804e6;hp=a1d97c4a1dac24716a213b8e3e2b3d27d834d70d;hb=032c9fe163865fd509a7e374f5f0857f65e3dc2d;hpb=8b9fcebfff81a71f04867cb3c68c6b0ef2e87d4d diff --git a/pawn.scad b/pawn.scad index a1d97c4..7277dcd 100644 --- a/pawn.scad +++ b/pawn.scad @@ -2,34 +2,44 @@ // shape parameters -r1 = 3; -r2 = 6; a2 = 30; +r1 = 2.85; +r2 = 4; a2 = 27; r3 = r2; -r4 = 8; a4 = 30; -r5 = 12; -h6 = 5; a6 = 5; +r4 = 4; a4 = 18; +r5 = 30; +h6 = 7; a6 = 4; // coordinates - z1 = 0; -h2 = r2 * sin(a2); z2 = z1 - h2; -h3 = r3 * sin(a2); z3 = z2 - h3; -h4 = r4 * sin(a4); z4 = z3 - h4; -h5 = r5 * sin(a4-a6); z5 = z4 - h5; - z6 = z5 - h6; + z1 = 0; +h2 = r2 * sin(a2); z2 = z1 - h2; +h3 = r3 * sin(a2); z3 = z2 - h3; +h4 = r4 * sin(a4); z4 = z3 - h4; + +zc5 = z4 - r5 * sin(a4); +z5 = zc5 + r5 * sin(a6); z6 = z5 - h6; x1 = 0 - r1; x2 = x1 + r2 * (1-cos(a2)); x3 = x2 + r3 * (1-cos(a2)); x4 = x3 - r4 * (1-cos(a4)); -x5 = x4 - r5 * (1-cos(a4-a6)); + +xc5 = x4 + r5 * cos(a4); +x5 = xc5 - r5 * cos(a6); + x6 = x5 - h6 * tan(a6); -$fa=1; -$fs=0.1; +htotal = r1 - z6; +echo("height", htotal); + +d = 0.01; +dx = 0.00; + +$fa=2; +$fs=0.2; module SegmentBasisSquare(zmin, zmax, xmin){ - translate([xmin, zmin-0.01]) square([-xmin+0.01, zmax-zmin+0.02]); + translate([xmin, zmin-d]) square([-xmin+dx, zmax-zmin+d*2]); } module ConvexSegment(xc, zc, r, zmin, zmax){ intersection(){ @@ -45,28 +55,26 @@ module ConcaveSegment(xc, zc, r, zmin, zmax){ } module PawnTemplate(){ - ConvexSegment( x1 + r1, z1, r1, z1, 50); - ConvexSegment( x1 + r2, z1, r2, z2, z1); - ConcaveSegment( x3 - r3, z3, r3, z3, z2); - ConcaveSegment( x3 - r4, z3, r4, z4, z3); - ConvexSegment( x5 + r5*cos(a6), z5 - r5*sin(a6), r5, z5, z4); + ConvexSegment( x1 + r1, z1, r1, z1, 50); + ConvexSegment( x1 + r2, z1, r2, z2, z1); + ConcaveSegment( x3 - r3, z3, r3, z3, z2); + ConcaveSegment( x3 - r4, z3, r4, z4, z3); + ConvexSegment( xc5, zc5, r5, z5, z4); polygon([[x6, z6], - [x5, z5+0.01], - [0.01, z5], - [0.01, z6]]); - + [x5, z5+d], + [dx, z5+d], + [dx, z6]]); +} -if(0) - intersection(){ - union(){ - translate([x5 + r5 * cos(a6), z5]) circle(r=r5); - difference(){ - translate([-50,z4]) square([52,z2-z4]); -// circle( +module Pawn(h=htotal){ + scale(h/htotal) { + rotate_extrude(convexity=10, $fn=50){ + assign($fn=undef){ + PawnTemplate(); } } - translate([-100,z6]) square([100.1, 200]); } } -PawnTemplate(); +Pawn(h=30); +//PawnTemplate();