update koffer model
This commit is contained in:
parent
9581784c06
commit
89abede4fe
231
koffer.scad
231
koffer.scad
@ -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]);
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user