case_lip = 1.25;
+lid_gap_x = 0.25;
+lid_gap_z = 0.25;
+lid_lip = 1.75;
+
$fa = 5;
$fs = 0.1;
kppf = kppe - [0,1] * keeper_inner_height;
kppa = [ kppb[0], kppf[1] ];
+lpp10 = [ epp5[0] + lid_gap_x, kppc[1] + lid_gap_z ];
+lpp11 = [ lpp10[0], epp5[1] + lid_gap_z ];
+lpp12 = [ epp4[0] + lid_lip, lpp11[1] ];
+lpp13 = [ lpp12[0], lpp12[1] + lid_lip ];
+
module rectfromto(a,b) {
ab = b - a;
translate([min(a[0], b[0]), min(a[1], b[1])])
module EdgeProfile(){
difference(){
hull(){
- circleat(epp3, r=case_th_bottom);
+ translate(epp3) square(case_th_bottom*2, center=true);
circleat(epp2, r=case_th_bottom);
circleat(epp1, r=case_th_side);
rectfromto(epp0, epp4);
}
}
+module LidEdgeProfile(){
+ polygon([ lpp10,
+ lpp11,
+ lpp12,
+ lpp13,
+ lpp13 + [10, 0],
+ lpp10 + [10, 0]
+ ]);
+ intersection(){
+ circleat(lpp12, r=lid_lip);
+ rectfromto( lpp12 + [-10, 0],
+ lpp12 + [+10, +10] );
+ }
+}
+
module CaseBase_rhsflip(yn=[0,1]) {
for (rhs=yn) {
translate([phone_width/2, 0, 0])
}
}
+module TestCamera(){ ////toplevel
+ intersection(){
+ Case();
+ CaseBase_rhsflip(1)
+ translate([0,0,-25])
+ linear_extrude(height = 50)
+ mirror([0, 1, 0])
+ rectfromto([-20, -20],
+ camera_pos_br + [ 5, 5 ]);
+ }
+}
+
module OneKeeper(){ ////toplevel
translate([0, -phone_cnr_rad, 0])
rotate([90, 0, 0])
OneKeeper();
}
+module DemoProfiles(){ ////toplevel
+ LidEdgeProfile();
+ %EdgeProfile();
+ KeeperProfile();
+}
+
//EdgeProfile();
//KeeperProfile();
//CaseBase();
//%Case();
//Keeper();
+//LidEdgeProfile();
+//KeeperProfile();
+//DemoProfiles();