// -*- C -*-
+// Infill density: 20%
+
+include <funcs.scad>
include <utils.scad>
-nook_th = 12.41 + 0.50;
-nook_w = 127.12 + 0.75;
-nook_h = 123.44 + 21.88 + 21.05 + 0.75;
+nook_th = 12.41 + 0.50 - 1.50 + 1.35 - .25;
+nook_w = 127.12 + 0.75 - .95 - .50;
+nook_h = 123.44 + 21.88 + 21.05 + 0.75 - 1.90 - 0.50 - 0.50;
+
+edge_ledge_w = 9.60;
+edge_ledge_h = 2.44 - .25;
+edge_ledge_inc_ang = 10; // degrees
+
+usb_w = 14.5;
+usb_below = 1.5;
+
+open_recess_w = 12.5;
+open_recess_h = 2.5;
+
+open_recess_2_len = 15;
+open_recess_2_d_tooth = 30;
nook_cnr_rad = 10;
test_pillar = 4;
-$test = false;
-
engage_l0 = 10;
engage_l1 = 10;
engage_l2 = 3;
+tooth_inward = gap[0] * 1.0 + 0.25 + 0.25;
+tooth_w = 15;
+
+diag_near_hinge_slope = 0.5;
+
+$test = false;
+
+$fa = $test ? 10 : 3;
+$fs = $test ? 0.1 : 1;
+
// calculated
+tooth_height = nook_th;
ledge_h = case_th;
lid_th = case_th;
+tooth_th = case_th;
spp0 = [0,0];
spp1 = spp0 + case_th * [-1,0];
nom_cnr = 0.5 * [nook_w, nook_h, 0] - nook_cnr_rad * [1,1,0];
+tooth_y = nom_cnr[1] - tooth_w/2;
+
etxa = nom_cnr[0] - engage_l2;
etxb = etxa - engage_l1;
etxc = -(nom_cnr[0] - engage_l2);
+tapa = nom_cnr[1] - engage_l2;
+tapb = tapa - tape_w;
+
+opra = nom_cnr[1] - engage_l2;
+oprb = opra - open_recess_w;
+
+opqa = tooth_y - open_recess_2_d_tooth + open_recess_2_len/2;
+opqb = opqa - open_recess_2_len;
+
+tppS = tppB + [-gap[0], 0];
+tppP = [ tppS[0] - tooth_th, tppC[1] ];
+tppQ = tppP + tooth_height * [0,-1] + tooth_inward * [1,0];
+tppR = [ tppS[0] + tooth_inward, tppQ[1] ];
+tppM = (tppQ + tppR) * 0.5 + tooth_th * 0.5 * [0,1];
+
+edge_ledge_rad = edge_ledge_h;
+
module RightSideMainProfile() {
rectfromto(spp7, spp0);
rectfromto(spp7, spp20);
+ EdgeLedgeProfile();
}
module LeftSideMainProfile() {
rectfromto(spp7, spp30);
rectfromto(spp7, spp20);
+ EdgeLedgeProfile();
+}
+
+module EdgeLedgeProfile() {
+ intersection(){
+ hull(){
+ for (t=[[0,0], [-20,0], [0,-10]]) {
+ translate(spp8
+ + [edge_ledge_w, edge_ledge_h]
+ + edge_ledge_rad * [ -sin(edge_ledge_inc_ang),
+ -cos(edge_ledge_inc_ang) ]
+ + t)
+ circle(edge_ledge_rad);
+ }
+ }
+ translate(spp7)
+ square(30);
+ }
}
module TopTapeCutout() {
SideTapeCutout1(spp6y, spp5y);
SideTapeCutout1(spp3y, spp2y);
SideTapeCutout1(spp3y, spp2y);
- SideTapeCutout1(spp11y, spp1[1] + 1);
+ SideTapeCutout1(spp11y, spp1[1] + 1); // obsolete I think
+}
+
+module ToothProfile(){
+ polygon([tppA,
+ tppB,
+ tppS + [-0.1,0],
+ tppP,
+ tppC]);
+ hull(){
+ polygon([tppP,
+ tppM,
+ tppS]);
+ translate(tppM)
+ circle(r= tooth_th/2);
+ }
}
module Demo(){ ////toplevel
- translate([0,0,-2]) LeftSideMainProfile();
- translate([0,0,-2]) color("yellow") LeftTopMainProfile();
- color("red") difference(){
- LeftSideMainProfile();
- SideTapeCutout();
+ translate([-1,0,0]) {
+ translate([0,0,-2]) LeftSideMainProfile();
+ translate([0,0,-2]) color("yellow") LeftTopMainProfile();
+ color("red") difference(){
+ LeftSideMainProfile();
+ SideTapeCutout();
+ }
+ translate([0,0,-4]) color("brown") EdgeLedgeProfile();
+ translate(concat(spp8 + [edge_ledge_w, edge_ledge_h], [2]))
+ rotate(-edge_ledge_inc_ang) {
+ color("blue") square(3);
+ color("lightblue") mirror([1,0]) square(3);
+ }
}
translate([0,0,0]) color("purple") difference(){
LeftTopMainProfile();
translate([nook_cnr_rad*2 + 5, 0,0]) mirror([1,0,0]) {
color("red") RightSideMainProfile();
color("purple") RightTopMainProfile();
+ color("grey") translate([0,0,-2]) ToothProfile();
}
//%SideTapeCutout();
}
module FaceCore(z0,z1, extra_left, extra_right){
- for (mx=[0,1]) mirror([mx,0,0]) {
- for (my=[0,1]) mirror([0,my,0]) {
- translate(-nom_cnr) {
- rotate_extrude(angle=90, convexity=10)
- translate(-[1,0,0] * nook_cnr_rad)
- children(mx);
+ difference(){
+ for (mx=[0,1]) mirror([mx,0,0]) {
+ for (my=[0,1]) mirror([0,my,0]) {
+ translate(-nom_cnr) {
+ rotate_extrude(angle=90, convexity=10) {
+ intersection(){
+ translate(-[1,0,0] * nook_cnr_rad)
+ children(mx);
+ rectfromto([-100,-100], [0,100]);
+ }
+ }
+ }
}
- }
- translate([nook_w/2, 0,0])
- linextr_y_xz(-nom_cnr[1]-0.1, nom_cnr[1]+0.1)
- children(1-mx);
- }
+ translate([nook_w/2, 0,0])
+ linextr_y_xz(-nom_cnr[1]-0.1, nom_cnr[1]+0.1)
+ children(1-mx);
+ }
+ for (my=[0,1]) mirror([0,my,0]) {
+ translate([-nook_w/2, 0,0])
+ mirror([1,0,0])
+ linextr_y_xz(tapb, tapa)
+ children(2);
+ }
+ }
for (my=[0,1]) mirror([0,my,0]) {
translate([0, -nook_h/2, 0]) {
linextr_x_yz(-nom_cnr[0]-0.1, etxc + extra_left) children(0);
}
}
+module DiagonaliseNearHinge(wider){
+ sz = spp0[1] - spp30[1] + gap[1];
+
+ for (my=[0,1]) mirror([0,my,0]) {
+ translate([-etxa, -nook_h/2, 0])
+ mirror([1,0,0])
+ linextr_y_xz(spp31[0] - wider, spp30[0] + gap[0] + 0.1)
+ translate([ 0, spp30[1] ])
+ polygon([[ -1, 0 ],
+ [ 0, 0 ],
+ [ sz/diag_near_hinge_slope, sz ],
+ [ sz/diag_near_hinge_slope, sz + 0.1 ],
+ [ -1, sz + 0.1 ]]);
+ }
+}
+
module Base(){ ////toplevel
- FaceCore(0,0, 0.3, 0) {
- LeftSideMainProfile();
- RightSideMainProfile();
+ difference(){
+ FaceCore(spp7[1],spp8[1], 0.3, 0) {
+ LeftSideMainProfile();
+ RightSideMainProfile();
+ SideTapeCutout();
+ }
+ translate([0, -nook_h/2, 0])
+ mirror([0,1,0])
+ linextr_x_yz(-usb_w/2, usb_w/2)
+ rectfromto(spp8 + [-40, usb_below], [40, 40]);
+ translate([ gap[0], 0,0 ])
+ DiagonaliseNearHinge(10);
+/*
+ translate([nook_w/2, 0, 0])
+ linextr_y_xz(oprb, opra)
+ translate(spp0)
+ rectfromto([-40, -open_recess_h], [40, 1]);
+*/
+ }
+ if ($test) {
+ linextr(spp7[1], spp8[1]) {
+ hull(){
+ for (r=[0,180])
+ rotate([0,0,r])
+ translate(nom_cnr + -1 * nook_cnr_rad*[1,1])
+ square(12);
+ }
+ }
}
}
module Top(){ ////toplevel
- FaceCore(0,0, -gap[0], gap[0] + 0.3) {
- LeftTopMainProfile();
- RightTopMainProfile();
+ difference(){
+ FaceCore(tppE[1],tppD[1], -gap[0], gap[0] + 0.3) {
+ LeftTopMainProfile();
+ RightTopMainProfile();
+ TopTapeCutout();
+ }
+ translate([nook_w/2, 0,0])
+ linextr_y_xz(opqb, opqa)
+ rectfromto(spp8, tppC + [-1,1]);
}
+ translate([0,0, gap[1]])
+ DiagonaliseNearHinge(0);
+ translate([nook_w/2, tooth_y, 0])
+ linextr_y_xz(-tooth_w/2, +tooth_w/2)
+ ToothProfile();
+}
+module TopPrint(){ ////toplevel
+ rotate([0,0,90]) rotate([180,0,0]) Top();
+}
+module BasePrint(){ ////toplevel
+ rotate([0,0,90]) Base();
}
module TestExtrude(){
}
}
+module BaseTestRest(){ ////toplevel
+ cube([30,15, spp8[1]-spp7[1]]);
+}
+
+module Demo3(){ ////toplevel
+ color("purple") Top();
+ color("red") Base();
+}
+
module TestSide(){ ////toplevel
TestExtrude() { LeftSideMainProfile(); SideTapeCutout(); }
}