mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-21 03:49:38 +00:00
Merge pull request #21 from ether42/master
Fix non isosceles triangle case for right_triangle with ORIENT_Z
This commit is contained in:
commit
339ef3fbd8
1 changed files with 10 additions and 16 deletions
20
shapes.scad
20
shapes.scad
|
@ -343,29 +343,23 @@ module right_triangle(size=[1, 1, 1], orient=ORIENT_Y, anchor=ALLNEG, center=und
|
|||
if (orient == ORIENT_X) {
|
||||
ang = atan2(size.y, size.z);
|
||||
masksize = [size.x, size.y, norm([size.y,size.z])] + [1,1,1];
|
||||
xrot(ang) {
|
||||
difference() {
|
||||
xrot(-ang) cube(size, center=true);
|
||||
back(masksize.y/2) cube(masksize, center=true);
|
||||
}
|
||||
cube(size, center=true);
|
||||
xrot(ang) back(masksize.y/2) cube(masksize, center=true);
|
||||
}
|
||||
} else if (orient == ORIENT_Y) {
|
||||
ang = atan2(size.x, size.z);
|
||||
masksize = [size.x, size.y, norm([size.x,size.z])] + [1,1,1];
|
||||
yrot(-ang) {
|
||||
difference() {
|
||||
yrot(ang) cube(size, center=true);
|
||||
right(masksize.x/2) cube(masksize, center=true);
|
||||
}
|
||||
cube(size, center=true);
|
||||
yrot(-ang) right(masksize.x/2) cube(masksize, center=true);
|
||||
}
|
||||
} else if (orient == ORIENT_Z) {
|
||||
ang = atan2(size.x, size.y);
|
||||
masksize = [norm([size.x,size.y]), size.y, size.z] + [1,1,1];
|
||||
zrot(-ang) {
|
||||
masksize = [size.y, norm([size.x,size.y]), size.z] + [1,1,1];
|
||||
difference() {
|
||||
zrot(ang) cube(size, center=true);
|
||||
back(masksize.y/2) cube(masksize, center=true);
|
||||
}
|
||||
cube(size, center=true);
|
||||
zrot(ang) right(masksize.x/2) cube(masksize, center=true);
|
||||
}
|
||||
}
|
||||
children();
|
||||
|
|
Loading…
Reference in a new issue