mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-04 03:09:45 +00:00
Merge branch 'master' into master
This commit is contained in:
commit
b0236958e2
3 changed files with 90 additions and 23 deletions
4
.github/workflows/docsgen.yml
vendored
4
.github/workflows/docsgen.yml
vendored
|
@ -1,11 +1,13 @@
|
||||||
name: CI
|
name: CI
|
||||||
on:
|
on:
|
||||||
push:
|
pull_request:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
|
types: [closed]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
GenerateDocs:
|
GenerateDocs:
|
||||||
|
if: github.event.pull_request.merged == true
|
||||||
runs-on: macos-10.15
|
runs-on: macos-10.15
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
|
|
107
shapes.scad
107
shapes.scad
|
@ -57,17 +57,41 @@
|
||||||
// Example: Rounded Edges, Untrimmed Corners
|
// Example: Rounded Edges, Untrimmed Corners
|
||||||
// cuboid([30,40,50], rounding=10, trimcorners=false);
|
// cuboid([30,40,50], rounding=10, trimcorners=false);
|
||||||
// Example: Chamferring Selected Edges
|
// Example: Chamferring Selected Edges
|
||||||
// cuboid([30,40,50], chamfer=5, edges=[TOP+FRONT,TOP+RIGHT,FRONT+RIGHT], $fn=24);
|
// cuboid(
|
||||||
|
// [30,40,50], chamfer=5,
|
||||||
|
// edges=[TOP+FRONT,TOP+RIGHT,FRONT+RIGHT],
|
||||||
|
// $fn=24
|
||||||
|
// );
|
||||||
// Example: Rounding Selected Edges
|
// Example: Rounding Selected Edges
|
||||||
// cuboid([30,40,50], rounding=5, edges=[TOP+FRONT,TOP+RIGHT,FRONT+RIGHT], $fn=24);
|
// cuboid(
|
||||||
|
// [30,40,50], rounding=5,
|
||||||
|
// edges=[TOP+FRONT,TOP+RIGHT,FRONT+RIGHT],
|
||||||
|
// $fn=24
|
||||||
|
// );
|
||||||
// Example: Negative Chamferring
|
// Example: Negative Chamferring
|
||||||
// cuboid([30,40,50], chamfer=-5, edges=[TOP,BOT], except_edges=RIGHT, $fn=24);
|
// cuboid(
|
||||||
|
// [30,40,50], chamfer=-5,
|
||||||
|
// edges=[TOP,BOT], except_edges=RIGHT,
|
||||||
|
// $fn=24
|
||||||
|
// );
|
||||||
// Example: Negative Chamferring, Untrimmed Corners
|
// Example: Negative Chamferring, Untrimmed Corners
|
||||||
// cuboid([30,40,50], chamfer=-5, edges=[TOP,BOT], except_edges=RIGHT, trimcorners=false, $fn=24);
|
// cuboid(
|
||||||
|
// [30,40,50], chamfer=-5,
|
||||||
|
// edges=[TOP,BOT], except_edges=RIGHT,
|
||||||
|
// trimcorners=false, $fn=24
|
||||||
|
// );
|
||||||
// Example: Negative Rounding
|
// Example: Negative Rounding
|
||||||
// cuboid([30,40,50], rounding=-5, edges=[TOP,BOT], except_edges=RIGHT, $fn=24);
|
// cuboid(
|
||||||
|
// [30,40,50], rounding=-5,
|
||||||
|
// edges=[TOP,BOT], except_edges=RIGHT,
|
||||||
|
// $fn=24
|
||||||
|
// );
|
||||||
// Example: Negative Rounding, Untrimmed Corners
|
// Example: Negative Rounding, Untrimmed Corners
|
||||||
// cuboid([30,40,50], rounding=-5, edges=[TOP,BOT], except_edges=RIGHT, trimcorners=false, $fn=24);
|
// cuboid(
|
||||||
|
// [30,40,50], rounding=-5,
|
||||||
|
// edges=[TOP,BOT], except_edges=RIGHT,
|
||||||
|
// trimcorners=false, $fn=24
|
||||||
|
// );
|
||||||
// Example: Standard Connectors
|
// Example: Standard Connectors
|
||||||
// cuboid(40) show_anchors();
|
// cuboid(40) show_anchors();
|
||||||
module cuboid(
|
module cuboid(
|
||||||
|
@ -417,7 +441,11 @@ function cuboid(
|
||||||
// prismoid(100, 80, chamfer=[0,5,10,15], h=30);
|
// prismoid(100, 80, chamfer=[0,5,10,15], h=30);
|
||||||
// Example: Mixing Chamfer and Rounding
|
// Example: Mixing Chamfer and Rounding
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// prismoid(100, 80, chamfer=[0,5,0,10], rounding=[5,0,10,0], h=30);
|
// prismoid(
|
||||||
|
// 100, 80, h=30,
|
||||||
|
// chamfer=[0,5,0,10],
|
||||||
|
// rounding=[5,0,10,0]
|
||||||
|
// );
|
||||||
// Example: Really Mixing It Up
|
// Example: Really Mixing It Up
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// prismoid(
|
// prismoid(
|
||||||
|
@ -588,7 +616,11 @@ function prismoid(
|
||||||
// rect_tube(isize=[60,80], wall=5, h=30);
|
// rect_tube(isize=[60,80], wall=5, h=30);
|
||||||
// rect_tube(size=[100,60], isize=[90,50], h=30);
|
// rect_tube(size=[100,60], isize=[90,50], h=30);
|
||||||
// rect_tube(size1=[100,60], size2=[70,40], wall=5, h=30);
|
// rect_tube(size1=[100,60], size2=[70,40], wall=5, h=30);
|
||||||
// rect_tube(size1=[100,60], size2=[70,40], isize1=[40,20], isize2=[65,35], h=15);
|
// Example:
|
||||||
|
// rect_tube(
|
||||||
|
// size1=[100,60], size2=[70,40],
|
||||||
|
// isize1=[40,20], isize2=[65,35], h=15
|
||||||
|
// );
|
||||||
// Example: Outer Rounding Only
|
// Example: Outer Rounding Only
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// rect_tube(size=100, wall=5, rounding=10, irounding=0, h=30);
|
// rect_tube(size=100, wall=5, rounding=10, irounding=0, h=30);
|
||||||
|
@ -603,16 +635,30 @@ function prismoid(
|
||||||
// rect_tube(size=100, wall=5, chamfer=10, irounding=8, h=30);
|
// rect_tube(size=100, wall=5, chamfer=10, irounding=8, h=30);
|
||||||
// Example: Gradiant Rounding
|
// Example: Gradiant Rounding
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// rect_tube(size1=100, size2=80, wall=5, rounding1=10, rounding2=0, irounding1=8, irounding2=0, h=30);
|
// rect_tube(
|
||||||
|
// size1=100, size2=80, wall=5, h=30,
|
||||||
|
// rounding1=10, rounding2=0,
|
||||||
|
// irounding1=8, irounding2=0
|
||||||
|
// );
|
||||||
// Example: Per Corner Rounding
|
// Example: Per Corner Rounding
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// rect_tube(size=100, wall=10, rounding=[0,5,10,15], irounding=0, h=30);
|
// rect_tube(
|
||||||
|
// size=100, wall=10, h=30,
|
||||||
|
// rounding=[0,5,10,15], irounding=0
|
||||||
|
// );
|
||||||
// Example: Per Corner Chamfer
|
// Example: Per Corner Chamfer
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// rect_tube(size=100, wall=10, chamfer=[0,5,10,15], ichamfer=0, h=30);
|
// rect_tube(
|
||||||
|
// size=100, wall=10, h=30,
|
||||||
|
// chamfer=[0,5,10,15], ichamfer=0
|
||||||
|
// );
|
||||||
// Example: Mixing Chamfer and Rounding
|
// Example: Mixing Chamfer and Rounding
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// rect_tube(size=100, wall=10, chamfer=[0,5,0,10], ichamfer=0, rounding=[5,0,10,0], irounding=0, h=30);
|
// rect_tube(
|
||||||
|
// size=100, wall=10, h=30,
|
||||||
|
// chamfer=[0,5,0,10], ichamfer=0,
|
||||||
|
// rounding=[5,0,10,0], irounding=0
|
||||||
|
// );
|
||||||
// Example: Really Mixing It Up
|
// Example: Really Mixing It Up
|
||||||
// include <BOSL2/hull.scad>
|
// include <BOSL2/hull.scad>
|
||||||
// rect_tube(
|
// rect_tube(
|
||||||
|
@ -838,7 +884,11 @@ function right_triangle(size=[1,1,1], center, anchor, spin=0, orient=UP) =
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Example: Putting it all together
|
// Example: Putting it all together
|
||||||
// cyl(l=40, d1=25, d2=15, chamfer1=10, chamfang1=30, from_end=true, rounding2=5);
|
// cyl(
|
||||||
|
// l=40, d1=25, d2=15,
|
||||||
|
// chamfer1=10, chamfang1=30,
|
||||||
|
// from_end=true, rounding2=5
|
||||||
|
// );
|
||||||
//
|
//
|
||||||
// Example: External Chamfers
|
// Example: External Chamfers
|
||||||
// cyl(l=50, r=30, chamfer=-5, chamfang=30, $fa=1, $fs=1);
|
// cyl(l=50, r=30, chamfer=-5, chamfang=30, $fa=1, $fs=1);
|
||||||
|
@ -1702,9 +1752,15 @@ module pie_slice(
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
// union() {
|
// union() {
|
||||||
// translate([0,2,-4]) cube([20, 4, 24], anchor=BOTTOM);
|
// translate([0,2,-4])
|
||||||
// translate([0,-10,-4]) cube([20, 20, 4], anchor=BOTTOM);
|
// cube([20, 4, 24], anchor=BOTTOM);
|
||||||
// color("green") interior_fillet(l=20, r=10, spin=180, orient=RIGHT);
|
// translate([0,-10,-4])
|
||||||
|
// cube([20, 20, 4], anchor=BOTTOM);
|
||||||
|
// color("green")
|
||||||
|
// interior_fillet(
|
||||||
|
// l=20, r=10,
|
||||||
|
// spin=180, orient=RIGHT
|
||||||
|
// );
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
|
@ -1762,21 +1818,30 @@ module interior_fillet(l=1.0, r, ang=90, overlap=0.01, d, anchor=FRONT+LEFT, spi
|
||||||
// orient = Vector to rotate top towards. See [orient](attachments.scad#orient). Default: `UP`
|
// orient = Vector to rotate top towards. See [orient](attachments.scad#orient). Default: `UP`
|
||||||
// Example:
|
// Example:
|
||||||
// heightfield(size=[100,100], bottom=-20, data=[
|
// heightfield(size=[100,100], bottom=-20, data=[
|
||||||
// for (y=[-180:4:180]) [for(x=[-180:4:180]) 10*cos(3*norm([x,y]))]
|
// for (y=[-180:4:180]) [
|
||||||
|
// for(x=[-180:4:180])
|
||||||
|
// 10*cos(3*norm([x,y]))
|
||||||
|
// ]
|
||||||
// ]);
|
// ]);
|
||||||
// Example:
|
// Example:
|
||||||
// intersection() {
|
// intersection() {
|
||||||
// heightfield(size=[100,100], data=[
|
// heightfield(size=[100,100], data=[
|
||||||
// for (y=[-180:5:180]) [for(x=[-180:5:180]) 10+5*cos(3*x)*sin(3*y)]
|
// for (y=[-180:5:180]) [
|
||||||
|
// for(x=[-180:5:180])
|
||||||
|
// 10+5*cos(3*x)*sin(3*y)
|
||||||
|
// ]
|
||||||
// ]);
|
// ]);
|
||||||
// cylinder(h=50,d=100);
|
// cylinder(h=50,d=100);
|
||||||
// }
|
// }
|
||||||
// Example(NORENDER): Heightfield by Function
|
// Example: Heightfield by Function
|
||||||
// fn = function (x,y) 10*sin(x*360)*cos(y*360);
|
// fn = function (x,y) 10*sin(x*360)*cos(y*360);
|
||||||
// heightfield(size=[100,100], data=fn);
|
// heightfield(size=[100,100], data=fn);
|
||||||
// Example(NORENDER): Heightfield by Function, with Specific Ranges
|
// Example: Heightfield by Function, with Specific Ranges
|
||||||
// fn = function (x,y) 2*cos(5*norm([x,y]));
|
// fn = function (x,y) 2*cos(5*norm([x,y]));
|
||||||
// heightfield(size=[100,100], bottom=-20, data=fn, xrange=[-180:2:180], yrange=[-180:2:180]);
|
// heightfield(
|
||||||
|
// size=[100,100], bottom=-20, data=fn,
|
||||||
|
// xrange=[-180:2:180], yrange=[-180:2:180]
|
||||||
|
// );
|
||||||
module heightfield(data, size=[100,100], bottom=-20, maxz=100, xrange=[-1:0.04:1], yrange=[-1:0.04:1], style="default", convexity=10, anchor=CENTER, spin=0, orient=UP)
|
module heightfield(data, size=[100,100], bottom=-20, maxz=100, xrange=[-1:0.04:1], yrange=[-1:0.04:1], style="default", convexity=10, anchor=CENTER, spin=0, orient=UP)
|
||||||
{
|
{
|
||||||
size = is_num(size)? [size,size] : point2d(size);
|
size = is_num(size)? [size,size] : point2d(size);
|
||||||
|
|
|
@ -90,7 +90,7 @@ function _rotpart(T) = [for(i=[0:3]) [for(j=[0:3]) j<3 || i==3 ? T[i][j] : 0]];
|
||||||
// "xjump" | | x | Move the turtle's x position to the specified value
|
// "xjump" | | x | Move the turtle's x position to the specified value
|
||||||
// "yjump | | y | Move the turtle's y position to the specified value
|
// "yjump | | y | Move the turtle's y position to the specified value
|
||||||
// "zjump | | y | Move the turtle's y position to the specified value
|
// "zjump | | y | Move the turtle's y position to the specified value
|
||||||
// "left" | [angle] | Turn turtle left by specified angle or default angle
|
// "left" | | [angle] | Turn turtle left by specified angle or default angle
|
||||||
// "right" | | [angle] | Turn turtle to the right by specified angle or default angle
|
// "right" | | [angle] | Turn turtle to the right by specified angle or default angle
|
||||||
// "up" | | [angle] | Turn turtle up by specified angle or default angle
|
// "up" | | [angle] | Turn turtle up by specified angle or default angle
|
||||||
// "down" | | [angle] | Turn turtle down by specified angle or default angle
|
// "down" | | [angle] | Turn turtle down by specified angle or default angle
|
||||||
|
|
Loading…
Reference in a new issue