mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
fix doc typo in skin, fix first section docs in distributors
This commit is contained in:
parent
b81c3638d5
commit
711050e605
2 changed files with 35 additions and 7 deletions
|
@ -28,20 +28,38 @@
|
||||||
// parent. This means that `$` variables like `$idx` are not available in assignments, so if you use them you will get a warning about an unknown variable.
|
// parent. This means that `$` variables like `$idx` are not available in assignments, so if you use them you will get a warning about an unknown variable.
|
||||||
// Two workarounds exist, neither of which are needed in newer versions of OpenSCAD. The workarounds solve the problem because
|
// Two workarounds exist, neither of which are needed in newer versions of OpenSCAD. The workarounds solve the problem because
|
||||||
// **modules** execute after their parent, so the `$` variables **are** available in modules. You can put your assignments
|
// **modules** execute after their parent, so the `$` variables **are** available in modules. You can put your assignments
|
||||||
// in a `let()` module, or you can wrap your child in a `union()`. Both methods appear below in the examples.
|
// in a `let()` module, or you can wrap your child in a `union()`. Both methods appear below.
|
||||||
// Example(2D): This example shows how we can use `$idx` to produce **different** geometry at each index.
|
// ```
|
||||||
// xcopies(n=10, spacing=10)
|
// xcopies(n=10, spacing=10)
|
||||||
// text(str($idx));
|
// text(str($idx));
|
||||||
// Example(2D): Here the children are sometimes squares and sometimes circles as determined by the conditional `if` module. This use of `if` is OK because no variables are assigned.
|
// ```
|
||||||
|
// Figure(2D): This example shows how we can use `$idx` to produce **different** geometry at each index.
|
||||||
|
// xcopies(n=10, spacing=10)
|
||||||
|
// text(str($idx));
|
||||||
|
// Continues:
|
||||||
|
// Figure(2D): Here the children are sometimes squares and sometimes circles as determined by the conditional `if` module. This use of `if` is OK because no variables are assigned.
|
||||||
// xcopies(n=4, spacing=10)
|
// xcopies(n=4, spacing=10)
|
||||||
// if($idx%2==0) circle(r=3,$fn=16);
|
// if($idx%2==0) circle(r=3,$fn=16);
|
||||||
// else rect(6);
|
// else rect(6);
|
||||||
// Example(2D): Suppose we would like to color odd and even index copies differently. In this example we compute the color for a given child from `$idx` using the ternary operator. The `let()` module is a module that sets variables and makes them available to its children. Note that multiple assignments in `let()` are separated by commas, not semicolons.
|
// Continues:
|
||||||
|
// ```
|
||||||
|
// xcopies(n=4, spacing=10)
|
||||||
|
// if($idx%2==0) circle(r=3,$fn=16);
|
||||||
|
// else rect(6);
|
||||||
|
// ```
|
||||||
|
// Figure(2D): Suppose we would like to color odd and even index copies differently. In this example we compute the color for a given child from `$idx` using the ternary operator. The `let()` module is a module that sets variables and makes them available to its children. Note that multiple assignments in `let()` are separated by commas, not semicolons.
|
||||||
// xcopies(n=6, spacing=10){
|
// xcopies(n=6, spacing=10){
|
||||||
// let(c = $idx % 2 == 0 ? "red" : "green")
|
// let(c = $idx % 2 == 0 ? "red" : "green")
|
||||||
// color(c) rect(6);
|
// color(c) rect(6);
|
||||||
// }
|
// }
|
||||||
// Example(2D): This example shows how you can change the position of children adaptively. If you want to avoid repeating your code for each case, this requires storing a transformation matrix in a variable and then applying it using `multmatrix()`. We wrap our code in `union()` to ensure that it works in OpenSCAD 2021.01.
|
// Continues:
|
||||||
|
// ```
|
||||||
|
// xcopies(n=6, spacing=10){
|
||||||
|
// let(c = $idx % 2 == 0 ? "red" : "green")
|
||||||
|
// color(c) rect(6);
|
||||||
|
// }
|
||||||
|
// ```
|
||||||
|
// Figure(2D): This example shows how you can change the position of children adaptively. If you want to avoid repeating your code for each case, this requires storing a transformation matrix in a variable and then applying it using `multmatrix()`. We wrap our code in `union()` to ensure that it works in OpenSCAD 2021.01.
|
||||||
// xcopies(n=5,spacing=10)
|
// xcopies(n=5,spacing=10)
|
||||||
// union()
|
// union()
|
||||||
// {
|
// {
|
||||||
|
@ -49,6 +67,16 @@
|
||||||
// spin = zrot(180*$idx/4);
|
// spin = zrot(180*$idx/4);
|
||||||
// multmatrix(shiftback*spin) stroke([[-4,0],[4,0]],endcap2="arrow2",width=1/2);
|
// multmatrix(shiftback*spin) stroke([[-4,0],[4,0]],endcap2="arrow2",width=1/2);
|
||||||
// }
|
// }
|
||||||
|
// Continues:
|
||||||
|
// ```
|
||||||
|
// xcopies(n=5,spacing=10)
|
||||||
|
// union()
|
||||||
|
// {
|
||||||
|
// shiftback = $idx%2==0 ? back(5) : IDENT;
|
||||||
|
// spin = zrot(180*$idx/4);
|
||||||
|
// multmatrix(shiftback*spin) stroke([[-4,0],[4,0]],endcap2="arrow2",width=1/2);
|
||||||
|
// }
|
||||||
|
// ```
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -1064,8 +1064,8 @@ module rotate_sweep(
|
||||||
// turns = number of revolutions to spiral up along the height.
|
// turns = number of revolutions to spiral up along the height.
|
||||||
// ---
|
// ---
|
||||||
// d = Diameter of the spiral to extrude along.
|
// d = Diameter of the spiral to extrude along.
|
||||||
// d1|r1 = Bottom inside diameter or radius of spiral to extrude along.
|
// d1/r1 = Bottom inside diameter or radius of spiral to extrude along.
|
||||||
// d2|r2 = Top inside diameter or radius of spiral to extrude along.
|
// d2/r2 = Top inside diameter or radius of spiral to extrude along.
|
||||||
// taper = Length of tapers for thread ends. Positive to add taper to threads, negative to taper within specified length. Default: 0
|
// taper = Length of tapers for thread ends. Positive to add taper to threads, negative to taper within specified length. Default: 0
|
||||||
// taper1 = Length of taper for bottom thread end
|
// taper1 = Length of taper for bottom thread end
|
||||||
// taper2 = Length of taper for top thread end
|
// taper2 = Length of taper for top thread end
|
||||||
|
|
Loading…
Reference in a new issue