Add secondary strap. Add preview model simplification.
This commit is contained in:
parent
6a6c5c57d2
commit
383bcd084e
46
main.scad
46
main.scad
@ -23,16 +23,24 @@ function is_model(m) = is_not_export() || export == m;
|
||||
|
||||
function get_phone_size() = [160, 76.7, 10];
|
||||
|
||||
module cubi(s, fillet=0, edges=EDGES_ALL) {
|
||||
if ($preview) {
|
||||
cube(s, center=true);
|
||||
} else {
|
||||
cuboid(s, fillet=fillet, edges=edges);
|
||||
}
|
||||
}
|
||||
|
||||
module phone() {
|
||||
s=get_phone_size();
|
||||
color("gray")
|
||||
cuboid(s, fillet=5);
|
||||
cubi(s, fillet=5);
|
||||
}
|
||||
module arm() {
|
||||
$fn=6;
|
||||
s=[210, 55, 50];
|
||||
color("SaddleBrown")
|
||||
down(s.z/2 + get_phone_size().z/2) cuboid(s, fillet=20);
|
||||
down(s.z/2 + get_phone_size().z/2) cubi(s, fillet=20);
|
||||
}
|
||||
|
||||
module phone_harness() {
|
||||
@ -59,8 +67,8 @@ module phone_harness() {
|
||||
module shell() {
|
||||
$fn = $preview ? 6 : 30;
|
||||
difference() {
|
||||
cuboid(hs, fillet=f);
|
||||
cuboid(ps, fillet=f);
|
||||
cubi(hs, fillet=f);
|
||||
cubi(ps, fillet=f);
|
||||
}
|
||||
shell_rim();
|
||||
shell_screwmounts();
|
||||
@ -71,10 +79,10 @@ module phone_harness() {
|
||||
s=rim_size;
|
||||
intersection() {
|
||||
difference() {
|
||||
cuboid(s, fillet=rf, edges=EDGES_Z_ALL);
|
||||
cuboid(ps, fillet=f, edges=EDGES_Z_ALL);
|
||||
cubi(s, fillet=rf, edges=EDGES_Z_ALL);
|
||||
cubi(ps, fillet=f, edges=EDGES_Z_ALL);
|
||||
}
|
||||
cuboid(s, fillet=1);
|
||||
cubi(s, fillet=1);
|
||||
}
|
||||
rail_extension=10;
|
||||
fwd(hs.y/2) xrot(90) harness_rail(slider_len_front+rail_extension);
|
||||
@ -88,10 +96,10 @@ module phone_harness() {
|
||||
resi=[hs.x+2*offset, hs.y+2*offset, res.z+1];
|
||||
up(0.0) difference() {
|
||||
intersection() {
|
||||
cuboid(res, fillet=rf, edges=EDGES_Z_ALL);
|
||||
cuboid(res, fillet=(groove?1:1.5), edges=EDGES_BOTTOM);
|
||||
cubi(res, fillet=rf, edges=EDGES_Z_ALL);
|
||||
cubi(res, fillet=(groove?1:1.5), edges=EDGES_BOTTOM);
|
||||
}
|
||||
cuboid(resi, fillet=rf, edges=EDGES_Z_ALL);
|
||||
cubi(resi, fillet=rf, edges=EDGES_Z_ALL);
|
||||
}
|
||||
}
|
||||
module foreach_screwmount() {
|
||||
@ -115,7 +123,7 @@ module phone_harness() {
|
||||
}
|
||||
}
|
||||
module shell_backplane(groove) {
|
||||
down(hs.z/2 - shell_wall/6) up(backplane_rim_size.z/2) right(harness_divider.x) scale(groove ? 1.01 : 1) cuboid(backplane_rim_size, fillet=5, edges=EDGES_Z_LF);
|
||||
down(hs.z/2 - shell_wall/6) up(backplane_rim_size.z/2) right(harness_divider.x) scale(groove ? 1.01 : 1) cubi(backplane_rim_size, fillet=5, edges=EDGES_Z_LF);
|
||||
}
|
||||
|
||||
// ==== SHELL SLIDER AND RAIL ====
|
||||
@ -148,22 +156,22 @@ module phone_harness() {
|
||||
// -- TOP --
|
||||
module screen_cutout() {
|
||||
s=[138, 69, 100];
|
||||
up(s.z/2) cuboid(s, fillet=3, edges=EDGES_Z_ALL);
|
||||
up(s.z/2) cubi(s, fillet=3, edges=EDGES_Z_ALL);
|
||||
}
|
||||
top_offset=6.5;
|
||||
module top_speaker_cutout() {
|
||||
s=[3, 12, 100];
|
||||
right(ps.x/2 - top_offset) up(s.z/2 - ps.z/3) cuboid(s, fillet=1);
|
||||
right(ps.x/2 - top_offset) up(s.z/2 - ps.z/3) cubi(s, fillet=1);
|
||||
}
|
||||
module front_camera_cutout() {
|
||||
$fn = $preview ? 6 : 30;
|
||||
d=5;
|
||||
s=[d, d, 100];
|
||||
right(ps.x/2 - top_offset) fwd(11) cylinder(d=s.x, h=s.z);
|
||||
right(ps.x/2 - top_offset) fwd(11.5) cylinder(d=s.x, h=s.z);
|
||||
}
|
||||
module leds_cutout() {
|
||||
s=[4, 14, 100];
|
||||
right(ps.x/2 - top_offset) up(s.z/2 - ps.z/3) back(23) cuboid(s, fillet=1);
|
||||
right(ps.x/2 - top_offset) up(s.z/2 - ps.z/3) back(23) cubi(s, fillet=1);
|
||||
}
|
||||
module top_cutout() {
|
||||
screen_cutout();
|
||||
@ -175,13 +183,13 @@ module phone_harness() {
|
||||
// -- BOTTOM --
|
||||
module back_camera_cutout() {
|
||||
s=[13, 25, expose_back_camera ? 100 : 11];
|
||||
right(ps.x/2 - 7.5) fwd(ps.y/2 - 23) down(s.z/2 - ps.z/3) cuboid(s, fillet=6, edges=EDGES_Z_ALL);
|
||||
right(ps.x/2 - 7.5) fwd(ps.y/2 - 23) down(s.z/2 - ps.z/3) cubi(s, fillet=6, edges=EDGES_Z_ALL);
|
||||
}
|
||||
module bottom_speaker_cutout() {
|
||||
s=[8, 49, 100];
|
||||
left(ps.x/2 - 13)
|
||||
difference() {
|
||||
down(s.z/2 - ps.z/3) cuboid(s, fillet=1);
|
||||
down(s.z/2 - ps.z/3) cubi(s, fillet=1);
|
||||
bars=8;
|
||||
down(ps.z/2)
|
||||
for (i = [0:bars-1]) {
|
||||
@ -211,7 +219,7 @@ module phone_harness() {
|
||||
// -- LEFT --
|
||||
module usbc_cutout() {
|
||||
s=[100, 20, 6];
|
||||
left(ps.x/2) down(2) cuboid(s, fillet=1);
|
||||
left(ps.x/2) down(2) cubi(s, fillet=1);
|
||||
}
|
||||
module left_cutout() {
|
||||
usbc_cutout();
|
||||
@ -220,7 +228,7 @@ module phone_harness() {
|
||||
// -- FRONT --
|
||||
module buttons_cutout() {
|
||||
s=[42, 100, 5];
|
||||
fwd(ps.y/2) right(ps.x/2 - 44.5) cuboid(s, fillet=1);
|
||||
fwd(ps.y/2) right(ps.x/2 - 44.5) cubi(s, fillet=1);
|
||||
}
|
||||
module front_cutout() {
|
||||
buttons_cutout();
|
||||
|
38
strap.scad
38
strap.scad
@ -13,6 +13,7 @@ use <BOSL/sliders.scad>
|
||||
MODEL_STRAP_PLATFORM_BASE=10;
|
||||
MODEL_STRAP_PLATFORM_RIB=11;
|
||||
MODEL_STRAP_PLATFORM_RIB_BRACE=12;
|
||||
MODEL_STRAP_SECONDARY=13;
|
||||
export=0; // [0:20]
|
||||
function is_not_export() = is_undef(export) || export == 0;
|
||||
function is_export() = !is_not_export();
|
||||
@ -25,20 +26,24 @@ module arm() {
|
||||
$fn=$preview ? 10 : 30;
|
||||
arm_size=[200, 55, 40];
|
||||
color("gray")
|
||||
down(arm_size.z/2) cuboid(arm_size, fillet=16, edges=EDGES_X_ALL);
|
||||
down(arm_size.z/2) {
|
||||
cuboid(arm_size, fillet=16, edges=EDGES_X_ALL);
|
||||
left(arm_size.x*0.6) scale([1, 1, 0.8]) yrot(90) cylinder(d1=arm_size.y*1.4, d2=arm_size.y*0.95, h=arm_size.x/2);
|
||||
}
|
||||
}
|
||||
|
||||
module strap_platform() {
|
||||
base_size=[40, 70, 2];
|
||||
rib_thickness=2;
|
||||
rib_thickness=5;
|
||||
rib_height=20;
|
||||
rib_pos=[base_size.x/2 - rib_thickness, 0, -1.3];
|
||||
brace_size=[base_size.x, 3.6, 4.8];
|
||||
brace_pos=[0, base_size.y/2 - 4, -1.3];
|
||||
module platform_base() {
|
||||
cutout_size=[(base_size.x-rib_thickness*2 - 2*(base_size.x/2-rib_pos.x)), (base_size.y - 5), 2*base_size.z];
|
||||
difference() {
|
||||
down(base_size.z/2) cuboid(base_size, fillet=2, edges=EDGES_Z_ALL);
|
||||
down(base_size.z/2) scale([0.75, 0.85, 2]) cuboid(base_size, fillet=2, edges=EDGES_Z_ALL);
|
||||
down(base_size.z/2) cuboid(cutout_size, fillet=2, edges=EDGES_Z_ALL);
|
||||
model_rib_left(socket=true);
|
||||
model_rib_right(socket=true);
|
||||
}
|
||||
@ -91,12 +96,39 @@ module strap_platform() {
|
||||
}
|
||||
}
|
||||
|
||||
module strap_secondary() {
|
||||
size=[40, 15, 10];
|
||||
size_base=[size.x, size.y];
|
||||
size_top=[size.x * 0.9, size.y * 0.4];
|
||||
cutout_size=[size.x - 10, size.y*10, size.z - 4];
|
||||
module anchor() {
|
||||
difference() {
|
||||
xrot(180) rounded_prismoid(size1=size_base, size2=size_top, h=size.z, r=5);
|
||||
down(size.z/2) cube(cutout_size, center=true);
|
||||
}
|
||||
}
|
||||
anchor_pos=[60, 30, 0];
|
||||
module anchor_front() {
|
||||
left(anchor_pos.x) fwd(anchor_pos.y) anchor();
|
||||
}
|
||||
module anchor_back() {
|
||||
left(anchor_pos.x) back(anchor_pos.y) anchor();
|
||||
}
|
||||
|
||||
if (is_model(MODEL_STRAP_SECONDARY)) anchor_front();
|
||||
if (is_not_export()) anchor_back();
|
||||
}
|
||||
|
||||
module model_strap_platform() {
|
||||
strap_platform();
|
||||
}
|
||||
module model_strap_secondary() {
|
||||
strap_secondary();
|
||||
}
|
||||
module model_arm() {
|
||||
if (is_not_export()) down(3) arm();
|
||||
}
|
||||
|
||||
model_strap_platform();
|
||||
model_strap_secondary();
|
||||
model_arm();
|
Loading…
Reference in New Issue
Block a user