Merge branch 'master' into master

This commit is contained in:
Revar Desmera 2021-05-22 15:42:50 -07:00 committed by GitHub
commit b0236958e2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 90 additions and 23 deletions

View file

@ -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

View file

@ -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);

View file

@ -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