update koffer model

This commit is contained in:
MReenen 2023-03-07 12:35:07 +01:00
parent 9581784c06
commit 89abede4fe

View File

@ -14,20 +14,97 @@ DEPTH = 5; // [1:1:10]
DIMENTION = "2d"; // [2d: 2d export view, 3d: 3d render] DIMENTION = "2d"; // [2d: 2d export view, 3d: 3d render]
POSITION = "inplace"; // [inplace: in place, origin: at the origin] POSITION = "inplace"; // [inplace: in place, origin: at the origin]
//RENDER = "all"; // [bot: bottom, lid: lid, front: front, back: back, left: left, right: right, all: all]
RENDER = "all"; // comma seperated list of what to render. [all, layout, bottom, lid, front, back, left, right]
RENDER = "stadslab_plaat2";
LAYOUT_SEPERATION = 15; // [1:1:50] LAYOUT_SEPERATION = 15; // [1:1:50]
/*[lid]*/ /*[lid]*/
LID_ANGLE = 45; // [0:170] LID_ANGLE = 45; // [0:170]
/*
%square([600, 300]); %translate([0, -400, -0.15])
%square([700, 400]); cube([700, 400, 0.1]);
%square([400, 700]); // %translate([0, -850, 0])
*/ // square([700, 400]);
// %translate([0, -1300, 0])
// square([700, 400]);
Layouts = [
["stadslab_plaat1",
[ "bottom",
[ // translate
LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
],[ "lid",
[ // translate
DEPTH*UNIT + 2*MATT_THIKNESS + 2*LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
],[ "front",
[ // translate
2*DEPTH*UNIT + 4*MATT_THIKNESS + 3*LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
]
],
["stadslab_plaat2",
[ "back",
[ // translate
LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
],[ "left",
[ // translate
HIEGHT*UNIT + 1*MATT_THIKNESS + 2*LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
],[ "right",
[ // translate
2*HIEGHT*UNIT + 3*MATT_THIKNESS + 3*LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
],[ "back",
[ // translate
1*HIEGHT*UNIT + 1*MATT_THIKNESS + 2*LAYOUT_SEPERATION,
-(1*HIEGHT*UNIT + 1*DEPTH*UNIT + 3*MATT_THIKNESS + 2*LAYOUT_SEPERATION)
],
0, // rotate
0 // extrude
],[ "left",
[ // translate
3*HIEGHT*UNIT + 5*MATT_THIKNESS + 4*LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
],[ "right",
[ // translate
4*HIEGHT*UNIT + 7*MATT_THIKNESS + 5*LAYOUT_SEPERATION,
-LAYOUT_SEPERATION
],
-90, // rotate
0 // extrude
]
]
];
function finger(flip=[1,0], dir="y") = [ function finger(flip=[1,0], dir="y") = [
[ [
0, 0 0, 0
@ -75,26 +152,83 @@ module fingers(flip=[1,1], dir="y", number=2, nub=true){
); );
} }
module renderPart(3dPos, 3dRotation, 2dPos){ AllParts = ["bottom", "lid", "front", "back", "left", "right"];
if (DIMENTION == "2d"){ module GetPart(name){
if (POSITION == "inplace") echo(str("GetPart: ",name));
translate(2dPos) if (name == "bottom"){
children(); bottom();
if (POSITION == "origin") }else if (name == "lid"){
children(); lid();
} }else if (name == "front"){
if (DIMENTION == "3d"){ front();
if (POSITION == "inplace") }else if (name == "back"){
translate(3dPos) back();
rotate(3dRotation) }else if (name == "left"){
linear_extrude(MATT_THIKNESS) side();
children(); }else if (name == "right"){
if (POSITION == "origin") side();
linear_extrude(MATT_THIKNESS)
children();
} }
} }
module RenderPart(name, pos=[0,0,0], rot=[0,0,0], extrude=0){
part = (is_list(name)) ? name[0] : name;
pos = (is_list(name)) ? name[1] : pos;
rot = (is_list(name)) ? name[2] : rot;
extrude = (is_list(name)) ? name[3] : extrude;
echo(str("render part; part=",part," pos=",pos," rot=",rot," extrude=",extrude));
// translate(pos)
// rotate(rot)
if (extrude != 0){
translate(pos)
rotate(rot)
linear_extrude(extrude)
!GetPart(part);
}else{
translate(pos)
rotate(rot)
GetPart(part);
}
}
function GetLayout(name, i=0, result=[]) =
(i == len(Layouts)) ? result : GetLayout(name, i+1,
(Layouts[i][0] == name) ? Layouts[i] : result
);
module RenderLayout(name){
echo(str("search layout ", name));
layout = GetLayout(name);
echo("layout", layout);
if (len(layout) == 0){
echo("ERROR: layout not found", layout);
}else{
for (i = [1:len(layout)-1]){
RenderPart(layout[i]);
}
}
}
module Render(name){
if (len(search(",", name)) == 0){
part = false;
for (i = [0:len(AllParts)-1]){
if (name == AllParts[i]){
part = true;
}
}
if (part){
renderPart(name);
}else{
RenderLayout(name);
}
} else {
}
}
Render(RENDER);
function split(str, sep=" ", i=0, word="", v=[]) = function split(str, sep=" ", i=0, word="", v=[]) =
(i == len(str)) ? concat(v, word) : (i == len(str)) ? concat(v, word) :
(str[i] == sep) ? split(str, sep, i+1, "", concat(v, word)) : (str[i] == sep) ? split(str, sep, i+1, "", concat(v, word)) :
@ -112,6 +246,7 @@ module render(name, 3dPos, 3dRotation, 2dPos){
} }
} }
/*
render( render(
name = "bot", name = "bot",
2dPos = [0, 0], 2dPos = [0, 0],
@ -120,14 +255,14 @@ render(
) )
bottom(); bottom();
/*
render( // render(
name = "front", // name = "front",
2dPos = [-(WIDTH*UNIT + 2*MATT_THIKNESS + LAYOUT_SEPERATION), 0], // 2dPos = [-(WIDTH*UNIT + 2*MATT_THIKNESS + LAYOUT_SEPERATION), 0],
3dPos = [0, MATT_THIKNESS, 0], // 3dPos = [0, MATT_THIKNESS, 0],
3dRotation = [90, 0, 0] // 3dRotation = [90, 0, 0]
) // )
front();*/ // front();
render( render(
name = "front", name = "front",
2dPos = [ 2dPos = [
@ -174,20 +309,20 @@ render(
totalDepth = DEPTH*UNIT + MATT_THIKNESS*2; totalDepth = DEPTH*UNIT + MATT_THIKNESS*2;
/*if (RENDER == "lid" || RENDER == "all") // if (RENDER == "lid" || RENDER == "all")
render( // render(
2dPos = [ // 2dPos = [
WIDTH*UNIT + 2*MATT_THIKNESS + LAYOUT_SEPERATION, // WIDTH*UNIT + 2*MATT_THIKNESS + LAYOUT_SEPERATION,
0 // 0
], // ],
3dPos = [ // 3dPos = [
MATT_THIKNESS, // MATT_THIKNESS,
totalDepth - totalDepth*cos(LID_ANGLE), // totalDepth - totalDepth*cos(LID_ANGLE),
HIEGHT*UNIT + MATT_THIKNESS + totalDepth*sin(LID_ANGLE) // HIEGHT*UNIT + MATT_THIKNESS + totalDepth*sin(LID_ANGLE)
], // ],
3dRotation = [-LID_ANGLE, 0, 0] // 3dRotation = [-LID_ANGLE, 0, 0]
) // )
lid();*/ // lid();
render( render(
name = "lid", name = "lid",
2dPos = [ 2dPos = [
@ -202,6 +337,7 @@ render(
3dRotation = [-LID_ANGLE, 0, 0] 3dRotation = [-LID_ANGLE, 0, 0]
) )
lid(); lid();
*/
module bottom(){ module bottom(){
translate([MATT_THIKNESS, MATT_THIKNESS]) translate([MATT_THIKNESS, MATT_THIKNESS])
@ -254,6 +390,7 @@ module back(){
module side(){ module side(){
translate([MATT_THIKNESS, MATT_THIKNESS]) translate([MATT_THIKNESS, MATT_THIKNESS])
union(){ union(){
// inner square
translate([0.005, 0.005]) translate([0.005, 0.005])
square(size=[DEPTH*UNIT-0.01, HIEGHT*UNIT-0.005 + MATT_THIKNESS]); square(size=[DEPTH*UNIT-0.01, HIEGHT*UNIT-0.005 + MATT_THIKNESS]);