master
Kerem Yollu 4 years ago
commit 465ceef48e

@ -0,0 +1,154 @@
$fn = 100;
bandLenght = 110;
bandWidthSart = 21;
bandWidthEnd = 17;
bandThick = 2;
bandTipLenght = 15;
shortBandLength = 75;
shortBandWidthStop = 16;
roundingStichLenght = 10;
roundungHoleDia = 2;
stichResess = 2;
stichStep = 4;
stichHole = 2.2;
stichAngle = 38;
stichWidth = 0.5;
difference()
{
strapLong();
translate([-30,-1,0])cube([bandLenght,bandWidthSart+4,bandThick+1]);
}
//translate([0, bandWidthSart +3,0]) strapShort();
//translate([0, bandWidthSart*2 + 5,0]) strapInsret();
module roundingEnds()
{
rounded_box(roundingStichLenght + roundungHoleDia*PI,bandWidthSart,bandWidthSart,2,0.2,0,0);
}
module roundingEndBuckle()
{
rounded_box(roundingStichLenght + roundungHoleDia*PI,shortBandWidthStop,shortBandWidthStop,2,0.2,0,0);
}
module strapInsret()
{
rounded_box(40,12,7,4,2,1,1);
}
module strapLong()
{
difference()
{
union()
{
rounded_box(bandLenght-bandTipLenght, bandWidthSart,bandWidthEnd,bandThick,bandThick, 0,0);
translate([bandLenght-bandTipLenght,(bandWidthSart-bandWidthEnd)/2,0])strapEnd(15,bandWidthEnd,2);
rotate([0,0,180])translate([0,-bandWidthSart,0])roundingEnds();
}
//translate([0,stichResess,0])strapLongSticth();
translate([0,stichResess,0])stichesStrait(0,0,bandLenght-bandTipLenght,(bandWidthSart-bandWidthEnd)/2,stichStep,stichHole,stichWidth,stichAngle,bandThick);
translate([0,-stichResess,0])stichesStrait(0,bandWidthSart,bandLenght-bandTipLenght,(bandWidthSart-bandWidthEnd)/2+bandWidthEnd-stichResess/2,stichStep,stichHole,stichWidth,stichAngle,bandThick);
translate([50,bandWidthSart/2,0])tubes(7,2,7,4);
}
}
module strapShort()
{
rounded_box(shortBandLength,bandWidthSart,shortBandWidthStop,bandThick,bandThick,0,0);
rotate([0,0,180])translate([0,-bandWidthSart,0])roundingEnds();
translate([shortBandLength,(bandWidthSart-shortBandWidthStop)/2,0])roundingEndBuckle();
}
module tubes(qte,dia,space,height)
{
for( a = [0:qte])
{
translate([a*space,0,0])cylinder(d=dia, h=height);
}
}
module trinagle(l,w,t)
{
//translate([0,-w/4+1,0])
translate([0,0,0])
{
hull()
{
translate([0,0,0])cylinder(r=0.001, h=t);
translate([w,0,0])cylinder(r=0.001, h=t);
translate([w/2,l,0])cylinder(r=0.001, h=t);
}
}
}
module strapEnd(l,w,t)
{
r = sqrt(pow(l,2)+pow((w/2),2));
difference()
{
intersection()
{
translate([0,(2*r-w)+(w-r),0])cylinder(r=r, h=t);
translate([0,(w-r),0])cylinder(r=r, h=t);
}
translate([-l*1.5,0,0])cube([l*1.5,w,t]);
}
}
module rounded_box(length,widthStart,widthStop,thicknessStart,thicknessStop, rStart, rStop){
cubeSize = 0.01;
hull()
{
if(rStart)
{
translate([rStart,rStart,0])cylinder(r=rStart, h=thicknessStart);
translate([rStart,widthStart-rStart,0])cylinder(r=rStart, h=thicknessStart);
}
else
{
translate([rStart,rStart,0])cube([cubeSize,cubeSize,thicknessStart]);
translate([rStart,widthStart-rStart,0])cube([cubeSize,cubeSize,thicknessStart]);
}
if(rStop)
{
translate([length-rStop,rStop+(widthStart-widthStop)/2,0])cylinder(r=rStop, h=thicknessStop);
translate([length-rStop,(widthStop-rStop) + (widthStart-widthStop)/2 ,0])cylinder(r=rStop, h=thicknessStop);
}
else
{
translate([length-rStop,rStop+(widthStart-widthStop)/2,0])cube([cubeSize,cubeSize,thicknessStop]);
translate([length-rStop,(widthStop-rStop) + (widthStart-widthStop)/2 ,0])cube([cubeSize,cubeSize,thicknessStop]);
}
}
}
module stichesStrait(startX,startY,stopX,stopY,stichSpace,StichLenght,stichWidth,angle,height)
{
hypAngle = asin((stopY-startY)/(stopX-startX));
stichCount = floor((stopX-startX)/(stichSpace));
echo(stichCount);
for( a = [0:stichCount])
{
rotate([0,0,hypAngle])translate([startX+stichSpace*a,startY-(sin(angle)*StichLenght)/2,0])rotate([0,0,angle])cube([StichLenght,stichWidth,height]);
}
}

@ -0,0 +1,211 @@
/*
Creator : Kerem Yollu
date : 30.06.2021
Description : A simple Cube library with some of the most useful featured.
- Simple cube with or without all around roundig with the option of a flat top | keyCubeFull()
- Simple cube with or without rounded edges with flat top and bottom. | keyCubeRounded()
- Cube with opening defined by the desired wall thickness, intern and extern rounding radious and with the extra options of flat top and/or flat inside bottom | keyCubeEmpty()
- Cube wiht onpneing as described before but with an resses defined by his width heigt and rounding radious | keyCubeEmptyWithResses()
*/
$fn = 50;
cubeLenght = 20;
cubeWidht = 20;
cubeHeight = 40;
cubeRoundingRadious = 1;
cubeWallThickness = 1;
cubeInnerRoudingRadious = 2;
cubeRessesWidth = 1;
cubeRessesHeight = 2;
cubeRessesRadious = 3;
cubeCentered = false;
cubeFlatTop = true;
cubeFlatInside = true;
/*
x = Lenght | mm
y = Widht | mm
z = Height | mm
t = Wall Thickness | mm
r = extern rounding radious for minkowski if = 0 the cube exterior will not be rounded | mm
flat = Top Flat | true / flase
ce = Center or not | true / flase
*/
//keyCubeFull(cubeLenght,cubeWidht,cubeHeight,cubeRoundingRadious,cubeFlatTop,cubeCentered);
module keyCubeFull(x, y, z, r, flat = false, ce = true)
{
if(r>0)
{
if (flat)
{
difference()
{
minkowski()
{
x = x - r*2;
y = y - r*2;
if(ce)
{
translate([-x/2,-y/2,-z/2+r])cube([x, y, z+r]);
}
else
{
translate([r,r,r])cube([x, y, z]);
}
sphere(r=r);
}
if(ce)
{
translate([-x/2,-y/2,z/2])cube([x, y, 3*r]);
}
else
{
translate([0,0,z])cube([x, y, 2*r]);
}
}
}
else
{
minkowski()
{
x = x - r*2;
y = y - r*2;
z = z - r*2;
if(ce)
{
translate([-x/2,-y/2,-z/2])cube([x, y, z]);
}
else
{
translate([r,r,r])cube([x, y, z]);
}
sphere(r=r);
}
}
}
else
{
cube([x, y, z], center = ce);
}
}
/*
x = Lenght | mm
y = Widht | mm
z = Height | mm
rad = extern rounding radious | mm
ce = Center or not | true / flase
*/
//keyCubeRounded(10,10,4,3,true);
module keyCubeRounded(x,y,z,rad,ce = true)
{
if(rad > 0)
{
if(ce)
{
translate([-x/2,-y/2,-z/2])hull()
{
translate([rad,rad,0])cylinder(r=rad, h=z);
translate([x-rad,rad,0])cylinder(r=rad, h=z);
translate([rad,y-rad,0])cylinder(r=rad, h=z);
translate([x-rad,y-rad,0])cylinder(r=rad, h=z);
}
}
else
{
hull()
{
translate([rad,rad,0])cylinder(r=rad, h=z);
translate([x-rad,rad,0])cylinder(r=rad, h=z);
translate([rad,y-rad,0])cylinder(r=rad, h=z);
translate([x-rad,y-rad,0])cylinder(r=rad, h=z);
}
}
}
else
{
cube([x,y,z], center = ce);
}
}
/*
x = Lenght | mm
y = Widht | mm
z = Height | mm
t = Wall Thickness | mm
r1 = extern rounding radious for minkowski if = 0 the cube exterior will not be rounded | mm
r2 = intern rounding radious for minkowski if = 0 the cube interior will not be rounded | mm
tFlat = Top Flat | true / flase
iFlat = Inside bottom flat | true / flase
ce = Center or not | true / flase
*/
//keyCubeEmpty(cubeLenght,cubeWidht,cubeHeight,cubeWallThickness,cubeRoundingRadious,cubeInnerRoudingRadious,cubeFlatTop,cubeFlatInside,cubeCentered);
module keyCubeEmpty(x,y,z,t,r1,r2,tFlat = false, Iflat = false, ce = true)
{
if(t < r1)
{
echo("please set wall thickness at least equal to the extern rounding diameter (r1)");
}
else
{
difference()
{
keyCubeFull(x,y,z,r1,tFlat,ce);
if(ce)
{
if(Iflat){translate([0,0,t])keyCubeRounded(x-t*2,y-t*2,z,r2/2,ce);}
else{translate([0,0,t])keyCubeFull(x-t*2,y-t*2,z,r2,false,ce);}
}
else
{
if(Iflat){translate([t,t,t])keyCubeRounded(x-t*2,y-t*2,z,r2/2,ce);}
else{translate([t,t,t])keyCubeFull(x-t*2,y-t*2,z,r2,false,ce);}
}
}
}
}
/*
x = Lenght | mm
y = Widht | mm
z = Height | mm
t = Wall Thickness | mm
r1 = extern rounding radious for minkowski if = 0 the cube exterior will not be rounded | mm
r2 = intern rounding radious for minkowski if = 0 the cube interior will not be rounded | mm
rsHeigh = Resses height | mm
rsWidth = Resses Width | mm
rsRad = Resses rounding radious | mm if = 0 the cresses corners will not be rounded
tFlat = Top Flat | true / flase
iFlat = Inside bottom flat | true / flase
ce = Center or not | true / flase
*/
//keyCubeEmptyWithResses(cubeLenght,cubeWidht,cubeHeight,cubeWallThickness,cubeRoundingRadious,cubeInnerRoudingRadious,cubeRessesHeight,cubeRessesWidth,cubeRessesRadious,cubeFlatTop,cubeFlatInside,cubeCentered);
module keyCubeEmptyWithResses(x,y,z,t,r1,r2,rsHeigh,rsWidth,rsRad,tFlat = false, Iflat = false, ce = true)
{
if(ce)
{
difference()
{
keyCubeEmpty(x,y,z,t,r1,r2,tFlat,Iflat,ce);
translate([0,0,z/2-rsHeigh/2])keyCubeRounded(x-t*2+rsWidth*2,y-t*2+rsWidth*2,rsHeigh,rsRad/2,ce);
}
}
else
{
difference()
{
keyCubeEmpty(x,y,z,t,r1,r2,tFlat,Iflat,ce);
translate([t-rsWidth,t-rsWidth,z-rsHeigh])keyCubeRounded(x-t*2+rsWidth*2,y-t*2+rsWidth*2,rsHeigh,rsRad/2,ce);
}
}
}
Loading…
Cancel
Save