mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
Merge remote-tracking branch 'upstream/master'
This commit is contained in:
commit
b39fb5d588
54 changed files with 341 additions and 288 deletions
|
@ -24,6 +24,29 @@ LibFile blocks can be followed by multiple lines that can be added as markdown t
|
||||||
// The end of the block is denoted by a line without a comment.
|
// The end of the block is denoted by a line without a comment.
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Includes:
|
||||||
|
|
||||||
|
Include blocks contain code that all examples in the file should show and use. This is generally used for `include <file>` and `use <file>` commands. Indentation is important. Less than three spaces indent denotes the end of the block
|
||||||
|
|
||||||
|
```
|
||||||
|
// Includes:
|
||||||
|
// include <BOSL2/std.scad>
|
||||||
|
// use <foo.scad>
|
||||||
|
```
|
||||||
|
|
||||||
|
## CommonCode:
|
||||||
|
|
||||||
|
CommonCode blocks can be used to denote code that can be shared between all of the Figure and Example blocks in the file, without being shown itself. Indentation is important. Less than three spaces indent denotes the end of the block
|
||||||
|
|
||||||
|
```
|
||||||
|
// CommonCode:
|
||||||
|
// module text3d(text, h=0.01, size=3) {
|
||||||
|
// linear_extrude(height=h, convexity=10) {
|
||||||
|
// text(text=text, size=size, valign="center", halign="center");
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
```
|
||||||
|
|
||||||
## Section:
|
## Section:
|
||||||
|
|
||||||
Section blocks can be followed by multiple lines that can be added as markdown text after the header. Indentation is important, as it denotes the end of block.
|
Section blocks can be followed by multiple lines that can be added as markdown text after the header. Indentation is important, as it denotes the end of block.
|
||||||
|
@ -48,19 +71,6 @@ Sections can also include Figures; images generated from code that is not shown
|
||||||
// cube([100,10,30], center=true);
|
// cube([100,10,30], center=true);
|
||||||
```
|
```
|
||||||
|
|
||||||
## CommonCode:
|
|
||||||
|
|
||||||
CommonCode blocks can be used to denote code that can be shared between all of the Figure and Example blocks in the file, without being shown itself. Indentation is important. Less than three spaces indent denotes the end of the block
|
|
||||||
|
|
||||||
```
|
|
||||||
// CommonCode:
|
|
||||||
// module text3d(text, h=0.01, size=3) {
|
|
||||||
// linear_extrude(height=h, convexity=10) {
|
|
||||||
// text(text=text, size=size, valign="center", halign="center");
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
```
|
|
||||||
|
|
||||||
## Module:/Function:/Function&Module:/Constant:
|
## Module:/Function:/Function&Module:/Constant:
|
||||||
|
|
||||||
Module, Function, and Constant docs blocks all have a similar specific format. Most sub-blocks are optional, except the Module/Function/Constant line, and the Description block.
|
Module, Function, and Constant docs blocks all have a similar specific format. Most sub-blocks are optional, except the Module/Function/Constant line, and the Description block.
|
||||||
|
@ -71,9 +81,12 @@ Valid sub-blocks are:
|
||||||
- `Usage: Optional Usage Title` - Optional. Multiple allowed. Followed by an indented block of usage patterns. Optional arguments should be in braces like `[opt]`. Alternate args should be separated by a vertical bar like `r|d`.
|
- `Usage: Optional Usage Title` - Optional. Multiple allowed. Followed by an indented block of usage patterns. Optional arguments should be in braces like `[opt]`. Alternate args should be separated by a vertical bar like `r|d`.
|
||||||
- `Description:` - Can be single-line or a multi-line block of the description.
|
- `Description:` - Can be single-line or a multi-line block of the description.
|
||||||
- `Figure: Optional Figure Title` - Optional. Multiple allowed. Followed by a multi-line code block used to create a figure image. The code will not be shown. All figures will follow the Description block.
|
- `Figure: Optional Figure Title` - Optional. Multiple allowed. Followed by a multi-line code block used to create a figure image. The code will not be shown. All figures will follow the Description block.
|
||||||
- `Arguments:` - Denotes start of an indented block of argument descriptions. Each line has the argument name, a space, an equals, another space, then the description for the argument all on one line. Like `arg = The argument description`. If you really need to explain an argument in longer form, explain it in the Description.
|
- `Returns:` - Can be single-line or a multi-line block, describing the return value of this function.
|
||||||
|
- `Custom: Foo` - Creates a text block labeled `Foo:` followed by the given multi-line block of text.
|
||||||
|
- `Arguments:` - Denotes start of an indented block of argument descriptions. Each line has the argument name, a space, an equals, another space, then the description for the argument all on one line. Like `arg = The argument description`. If you really need to explain an argument in longer form, explain it in the Description. If an argument line is just `---`, then the arguments table is split into two tables, with the positional arguments before the `---` and arguments that should always be passed by name after.
|
||||||
- `Side Effects:` - Denotes the start of a block describing the side effects, such as `$special_var`s that are set.
|
- `Side Effects:` - Denotes the start of a block describing the side effects, such as `$special_var`s that are set.
|
||||||
- `Extra Anchors:` - Denotes the start of an indented block of available non-standard named anchors for a part.
|
- `Extra Anchors:` - Denotes the start of an indented block of available non-standard named anchors for a part.
|
||||||
|
- `Topics: Topic1, Topic2, Topic2, etc.` - Lets you list topics related to this fuction or module.
|
||||||
- `Example:` - Denotes the beginning of a multi-line example code block.
|
- `Example:` - Denotes the beginning of a multi-line example code block.
|
||||||
- `Examples:` - Denotes the beginning of a block of examples, where each line will be shows as a separate example with a separate image if needed.
|
- `Examples:` - Denotes the beginning of a block of examples, where each line will be shows as a separate example with a separate image if needed.
|
||||||
|
|
||||||
|
@ -83,7 +96,8 @@ The full set of optional example tags are:
|
||||||
|
|
||||||
- `2D`: Orient camera in a top-down view for showing 2D objects.
|
- `2D`: Orient camera in a top-down view for showing 2D objects.
|
||||||
- `3D`: Orient camera in an oblique view for showing 3D objects. Used to force an Example sub-block to generate an image in Function and Constant blocks.
|
- `3D`: Orient camera in an oblique view for showing 3D objects. Used to force an Example sub-block to generate an image in Function and Constant blocks.
|
||||||
- `NORENDER`: Don't generate an image for this example.
|
- `NORENDER`: Don't generate an image for this example, but show the example text.
|
||||||
|
- `Hide`: Don't show example text or image. This can be used to generate images to be manually displayed in markdown text blocks.
|
||||||
- `Small`: Make the image small sized. (The default)
|
- `Small`: Make the image small sized. (The default)
|
||||||
- `Med`: Make the image medium sized.
|
- `Med`: Make the image medium sized.
|
||||||
- `Big`: Make the image big sized.
|
- `Big`: Make the image big sized.
|
||||||
|
@ -105,11 +119,10 @@ Indentation is important, as it denotes the end of sub-block.
|
||||||
// foo(foo, flee, flie, [qux])
|
// foo(foo, flee, flie, [qux])
|
||||||
// Description: Short description.
|
// Description: Short description.
|
||||||
// Description:
|
// Description:
|
||||||
// A longer, multi-line description.
|
// A longer, multi-line description. If multiple description blocks exist,
|
||||||
// All description blocks are added together.
|
// they are all are added together. You can use most *markdown* notation
|
||||||
// You _can_ use *markdown* notation as well.
|
// as well. You can have paragraph breaks by having a line with just a
|
||||||
// You can have paragraph breaks by having a
|
// period, like this:
|
||||||
// line with just a period, like this:
|
|
||||||
// .
|
// .
|
||||||
// You can end multi-line blocks by un-indenting the next
|
// You can end multi-line blocks by un-indenting the next
|
||||||
// line, or by using a comment with no spaces like this:
|
// line, or by using a comment with no spaces like this:
|
||||||
|
@ -121,22 +134,29 @@ Indentation is important, as it denotes the end of sub-block.
|
||||||
// cube([10,100,50], center=true);
|
// cube([10,100,50], center=true);
|
||||||
// cube([100,10,30], center=true);
|
// cube([100,10,30], center=true);
|
||||||
//
|
//
|
||||||
|
// Returns: A description of the return value.
|
||||||
|
//
|
||||||
|
// Custom: Custom Block Title
|
||||||
|
// Multi-line text to be shown in the custom block.
|
||||||
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// foo = This is the description of the foo argument. All on one line.
|
// foo = This is the description of the first positional argument, foo. All on one line.
|
||||||
// bar = This is the description of the bar argument. All on one line.
|
// bar = This is the description of the second positional argument, bar. All on one line.
|
||||||
// baz = This is the description of the baz argument. All on one line.
|
// baz = This is the description of the third positional argument, baz. All on one line.
|
||||||
// qux = This is the description of the qux argument. All on one line.
|
// ---
|
||||||
// flee = This is the description of the flee argument. All on one line.
|
// qux = This is the description of the named argument qux. All on one line.
|
||||||
// flie = This is the description of the flie argument. All on one line.
|
// flee = This is the description of the named argument flee. All on one line.
|
||||||
// Side Effects:
|
// Side Effects:
|
||||||
// `$floo` gets set to the floo value.
|
// `$floo` gets set to the floo value.
|
||||||
// Extra Anchors:
|
// Extra Anchors:
|
||||||
// "blawb" = An anchor at the blawb point of the part, oriented upwards.
|
// "blawb" = An anchor at the blawb point of the part, oriented upwards.
|
||||||
// "fewble" = An anchor at the fewble connector of the part, oriented back yowards Y+.
|
// "fewble" = An anchor at the fewble connector of the part, oriented back yowards Y+.
|
||||||
|
// Topics: Fubar, Barbie, Bazil
|
||||||
// Examples: Each line below gets its own example block and image.
|
// Examples: Each line below gets its own example block and image.
|
||||||
// foo(foo="a", bar="b");
|
// foo(foo="a", bar="b");
|
||||||
// foo(foo="b", baz="c");
|
// foo(foo="b", baz="c");
|
||||||
// Example: Multi-line example.
|
// Example: Multi-line example.
|
||||||
|
// --$vpr = [55,0,120]; // Lines starting with `--` aren't shown in docs example text.
|
||||||
// lst = [
|
// lst = [
|
||||||
// "multi-line examples",
|
// "multi-line examples",
|
||||||
// "are shown in one block",
|
// "are shown in one block",
|
||||||
|
|
66
affine.scad
66
affine.scad
|
@ -1,16 +1,16 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: affine.scad
|
// LibFile: affine.scad
|
||||||
// Matrix math and affine transformation matrices.
|
// Matrix math and affine transformation matrices.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
// Section: Matrix Manipulation
|
// Section: Matrix Manipulation
|
||||||
|
|
||||||
// Function: ident()
|
// Function: ident()
|
||||||
|
// Usage:
|
||||||
|
// mat = ident(n);
|
||||||
// Description: Create an `n` by `n` identity matrix.
|
// Description: Create an `n` by `n` identity matrix.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// n = The size of the identity matrix square, `n` by `n`.
|
// n = The size of the identity matrix square, `n` by `n`.
|
||||||
|
@ -18,6 +18,8 @@ function ident(n) = [for (i = [0:1:n-1]) [for (j = [0:1:n-1]) (i==j)?1:0]];
|
||||||
|
|
||||||
|
|
||||||
// Function: affine2d_to_3d()
|
// Function: affine2d_to_3d()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine2d_to_3d(m);
|
||||||
// Description: Takes a 3x3 affine2d matrix and returns its 4x4 affine3d equivalent.
|
// Description: Takes a 3x3 affine2d matrix and returns its 4x4 affine3d equivalent.
|
||||||
function affine2d_to_3d(m) = concat(
|
function affine2d_to_3d(m) = concat(
|
||||||
[for (r = [0:2])
|
[for (r = [0:2])
|
||||||
|
@ -35,11 +37,15 @@ function affine2d_to_3d(m) = concat(
|
||||||
|
|
||||||
|
|
||||||
// Function: affine2d_identity()
|
// Function: affine2d_identity()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine2d_identify();
|
||||||
// Description: Create a 3x3 affine2d identity matrix.
|
// Description: Create a 3x3 affine2d identity matrix.
|
||||||
function affine2d_identity() = ident(3);
|
function affine2d_identity() = ident(3);
|
||||||
|
|
||||||
|
|
||||||
// Function: affine2d_translate()
|
// Function: affine2d_translate()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine2d_translate(v);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 3x3 affine2d matrix to perform a 2D translation.
|
// Returns the 3x3 affine2d matrix to perform a 2D translation.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -52,6 +58,8 @@ function affine2d_translate(v) = [
|
||||||
|
|
||||||
|
|
||||||
// Function: affine2d_scale()
|
// Function: affine2d_scale()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine2d_scale(v);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 3x3 affine2d matrix to perform a 2D scaling transformation.
|
// Returns the 3x3 affine2d matrix to perform a 2D scaling transformation.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -64,6 +72,8 @@ function affine2d_scale(v) = [
|
||||||
|
|
||||||
|
|
||||||
// Function: affine2d_zrot()
|
// Function: affine2d_zrot()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine2d_zrot(ang);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 3x3 affine2d matrix to perform a rotation of a 2D vector around the Z axis.
|
// Returns the 3x3 affine2d matrix to perform a rotation of a 2D vector around the Z axis.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -93,7 +103,7 @@ function affine2d_mirror(v) =
|
||||||
|
|
||||||
// Function: affine2d_skew()
|
// Function: affine2d_skew()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine2d_skew(xa, ya)
|
// mat = affine2d_skew(xa, ya);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 3x3 affine2d matrix to skew a 2D vector along the XY plane.
|
// Returns the 3x3 affine2d matrix to skew a 2D vector along the XY plane.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -108,7 +118,7 @@ function affine2d_skew(xa, ya) = [
|
||||||
|
|
||||||
// Function: affine2d_chain()
|
// Function: affine2d_chain()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine2d_chain(affines)
|
// mat = affine2d_chain(affines);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns a 3x3 affine2d transformation matrix which results from applying each matrix in `affines` in order.
|
// Returns a 3x3 affine2d transformation matrix which results from applying each matrix in `affines` in order.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -123,11 +133,15 @@ function affine2d_chain(affines, _m=undef, _i=0) =
|
||||||
|
|
||||||
|
|
||||||
// Function: affine3d_identity()
|
// Function: affine3d_identity()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine3d_identity();
|
||||||
// Description: Create a 4x4 affine3d identity matrix.
|
// Description: Create a 4x4 affine3d identity matrix.
|
||||||
function affine3d_identity() = ident(4);
|
function affine3d_identity() = ident(4);
|
||||||
|
|
||||||
|
|
||||||
// Function: affine3d_translate()
|
// Function: affine3d_translate()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine3d_translate(v);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a 3D translation.
|
// Returns the 4x4 affine3d matrix to perform a 3D translation.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -141,6 +155,8 @@ function affine3d_translate(v) = [
|
||||||
|
|
||||||
|
|
||||||
// Function: affine3d_scale()
|
// Function: affine3d_scale()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine3d_scale(v);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a 3D scaling transformation.
|
// Returns the 4x4 affine3d matrix to perform a 3D scaling transformation.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -154,6 +170,8 @@ function affine3d_scale(v) = [
|
||||||
|
|
||||||
|
|
||||||
// Function: affine3d_xrot()
|
// Function: affine3d_xrot()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine3d_xrot(ang);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around the X axis.
|
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around the X axis.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -167,6 +185,8 @@ function affine3d_xrot(ang) = [
|
||||||
|
|
||||||
|
|
||||||
// Function: affine3d_yrot()
|
// Function: affine3d_yrot()
|
||||||
|
// Usage:
|
||||||
|
// mat = affine3d_yrot(ang);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around the Y axis.
|
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around the Y axis.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -181,7 +201,7 @@ function affine3d_yrot(ang) = [
|
||||||
|
|
||||||
// Function: affine3d_zrot()
|
// Function: affine3d_zrot()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_zrot(ang)
|
// mat = affine3d_zrot(ang);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around the Z axis.
|
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around the Z axis.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -196,7 +216,7 @@ function affine3d_zrot(ang) = [
|
||||||
|
|
||||||
// Function: affine3d_rot_by_axis()
|
// Function: affine3d_rot_by_axis()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_rot_by_axis(u, ang);
|
// mat = affine3d_rot_by_axis(u, ang);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around an axis.
|
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector around an axis.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -219,7 +239,7 @@ function affine3d_rot_by_axis(u, ang) =
|
||||||
|
|
||||||
// Function: affine3d_rot_from_to()
|
// Function: affine3d_rot_from_to()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_rot_from_to(from, to);
|
// mat = affine3d_rot_from_to(from, to);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector from one vector direction to another.
|
// Returns the 4x4 affine3d matrix to perform a rotation of a 3D vector from one vector direction to another.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -246,16 +266,16 @@ function affine3d_rot_from_to(from, to) =
|
||||||
|
|
||||||
// Function: affine_frame_map()
|
// Function: affine_frame_map()
|
||||||
// Usage:
|
// Usage:
|
||||||
// map = affine_frame_map(x=v1,y=v2);
|
// map = affine_frame_map(v1, v2, v3);
|
||||||
// map = affine_frame_map(x=v1,z=v2);
|
// map = affine_frame_map(x=VECTOR1, y=VECTOR2, <reverse>);
|
||||||
// map = affine_frame_map(y=v1,y=v2);
|
// map = affine_frame_map(x=VECTOR1, z=VECTOR2, <reverse>);
|
||||||
// map = affine_frame_map(v1,v2,v3);
|
// map = affine_frame_map(y=VECTOR1, y=VECTOR2, <reverse>);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns a transformation that maps one coordinate frame to another. You must specify two or three of `x`, `y`, and `z`. The specified
|
// Returns a transformation that maps one coordinate frame to another. You must specify two or three of `x`, `y`, and `z`. The specified
|
||||||
// axes are mapped to the vectors you supplied. If you give two inputs, the third vector is mapped to the appropriate normal to maintain a right hand coordinate system.
|
// axes are mapped to the vectors you supplied. If you give two inputs, the third vector is mapped to the appropriate normal to maintain a right hand coordinate system.
|
||||||
// If the vectors you give are orthogonal the result will be a rotation and the `reverse` parameter will supply the inverse map, which enables you
|
// If the vectors you give are orthogonal the result will be a rotation and the `reverse` parameter will supply the inverse map, which enables you
|
||||||
// to map two arbitrary coordinate systems to each other by using the canonical coordinate system as an intermediary. You cannot use the `reverse` option
|
// to map two arbitrary coordinate systems to each other by using the canonical coordinate system as an intermediary. You cannot use the `reverse` option
|
||||||
// with non-orthogonal inputs.
|
// with non-orthogonal inputs.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// x = Destination vector for x axis
|
// x = Destination vector for x axis
|
||||||
// y = Destination vector for y axis
|
// y = Destination vector for y axis
|
||||||
|
@ -320,7 +340,7 @@ function affine3d_mirror(v) =
|
||||||
|
|
||||||
// Function: affine3d_skew()
|
// Function: affine3d_skew()
|
||||||
// Usage:
|
// Usage:
|
||||||
// mat = affine3d_skew([sxy], [sxz], [syx], [syz], [szx], [szy]);
|
// mat = affine3d_skew(<sxy>, <sxz>, <syx>, <syz>, <szx>, <szy>);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a skew transformation.
|
// Returns the 4x4 affine3d matrix to perform a skew transformation.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -340,7 +360,7 @@ function affine3d_skew(sxy=0, sxz=0, syx=0, syz=0, szx=0, szy=0) = [
|
||||||
|
|
||||||
// Function: affine3d_skew_xy()
|
// Function: affine3d_skew_xy()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_skew_xy(xa, ya)
|
// mat = affine3d_skew_xy(xa, ya);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a skew transformation along the XY plane.
|
// Returns the 4x4 affine3d matrix to perform a skew transformation along the XY plane.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -356,7 +376,7 @@ function affine3d_skew_xy(xa, ya) = [
|
||||||
|
|
||||||
// Function: affine3d_skew_xz()
|
// Function: affine3d_skew_xz()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_skew_xz(xa, za)
|
// mat = affine3d_skew_xz(xa, za);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a skew transformation along the XZ plane.
|
// Returns the 4x4 affine3d matrix to perform a skew transformation along the XZ plane.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -372,7 +392,7 @@ function affine3d_skew_xz(xa, za) = [
|
||||||
|
|
||||||
// Function: affine3d_skew_yz()
|
// Function: affine3d_skew_yz()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_skew_yz(ya, za)
|
// mat = affine3d_skew_yz(ya, za);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the 4x4 affine3d matrix to perform a skew transformation along the YZ plane.
|
// Returns the 4x4 affine3d matrix to perform a skew transformation along the YZ plane.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -388,7 +408,7 @@ function affine3d_skew_yz(ya, za) = [
|
||||||
|
|
||||||
// Function: affine3d_chain()
|
// Function: affine3d_chain()
|
||||||
// Usage:
|
// Usage:
|
||||||
// affine3d_chain(affines)
|
// mat = affine3d_chain(affines);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns a 4x4 affine3d transformation matrix which results from applying each matrix in `affines` in order.
|
// Returns a 4x4 affine3d transformation matrix which results from applying each matrix in `affines` in order.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -400,7 +420,7 @@ function affine3d_chain(affines, _m=undef, _i=0) =
|
||||||
|
|
||||||
// Function: apply()
|
// Function: apply()
|
||||||
// Usage:
|
// Usage:
|
||||||
// pts = apply(transform, points)
|
// pts = apply(transform, points);
|
||||||
// Description:
|
// Description:
|
||||||
// Applies the specified transformation matrix to a point list (or single point). Both inputs can be 2d or 3d, and it is also allowed
|
// Applies the specified transformation matrix to a point list (or single point). Both inputs can be 2d or 3d, and it is also allowed
|
||||||
// to supply 3d transformations with 2d data as long as the the only action on the z coordinate is a simple scaling.
|
// to supply 3d transformations with 2d data as long as the the only action on the z coordinate is a simple scaling.
|
||||||
|
@ -425,7 +445,7 @@ function apply(transform,points) =
|
||||||
|
|
||||||
// Function: apply_list()
|
// Function: apply_list()
|
||||||
// Usage:
|
// Usage:
|
||||||
// pts = apply_list(points, transform_list)
|
// pts = apply_list(points, transform_list);
|
||||||
// Description:
|
// Description:
|
||||||
// Transforms the specified point list (or single point) using a list of transformation matrices. Transformations on
|
// Transforms the specified point list (or single point) using a list of transformation matrices. Transformations on
|
||||||
// the list are applied in the order they appear in the list (as in right multiplication of matrices). Both inputs can be
|
// the list are applied in the order they appear in the list (as in right multiplication of matrices). Both inputs can be
|
||||||
|
@ -457,7 +477,7 @@ function apply_list(points,transform_list) =
|
||||||
|
|
||||||
// Function: is_2d_transform()
|
// Function: is_2d_transform()
|
||||||
// Usage:
|
// Usage:
|
||||||
// is_2d_transform(t)
|
// x = is_2d_transform(t);
|
||||||
// Description:
|
// Description:
|
||||||
// Checks if the input is a 3d transform that does not act on the z coordinate, except
|
// Checks if the input is a 3d transform that does not act on the z coordinate, except
|
||||||
// possibly for a simple scaling of z. Note that an input which is only a zscale returns false.
|
// possibly for a simple scaling of z. Note that an input which is only a zscale returns false.
|
||||||
|
@ -469,7 +489,7 @@ function is_2d_transform(t) = // z-parameters are zero, except we allow t[2][
|
||||||
|
|
||||||
// Function: rot_decode()
|
// Function: rot_decode()
|
||||||
// Usage:
|
// Usage:
|
||||||
// [angle,axis,cp,translation] = rot_decode(rotation)
|
// info = rot_decode(rotation); // Returns: [angle,axis,cp,translation]
|
||||||
// Description:
|
// Description:
|
||||||
// Given an input 3d rigid transformation operator (one composed of just rotations and translations)
|
// Given an input 3d rigid transformation operator (one composed of just rotations and translations)
|
||||||
// represented as a 4x4 matrix, compute the rotation and translation parameters of the operator.
|
// represented as a 4x4 matrix, compute the rotation and translation parameters of the operator.
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: arrays.scad
|
// LibFile: arrays.scad
|
||||||
// List and Array manipulation functions.
|
// List and Array manipulation functions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: attachments.scad
|
// LibFile: attachments.scad
|
||||||
// This is the file that handles attachments and orientation of children.
|
// This is the file that handles attachments and orientation of children.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: beziers.scad
|
// LibFile: beziers.scad
|
||||||
// Bezier functions and modules.
|
// Bezier functions and modules.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/beziers.scad>
|
// include <BOSL2/beziers.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: bottlecaps.scad
|
// LibFile: bottlecaps.scad
|
||||||
// Bottle caps and necks for PCO18XX standard plastic beverage bottles.
|
// Bottle caps and necks for PCO18XX standard plastic beverage bottles.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/bottlecaps.scad>
|
// include <BOSL2/bottlecaps.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: common.scad
|
// LibFile: common.scad
|
||||||
// Common functions used in argument processing.
|
// Common functions used in argument processing.
|
||||||
// To use, include this line at the top of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: constants.scad
|
// LibFile: constants.scad
|
||||||
// Useful Constants.
|
// Useful Constants.
|
||||||
// To use this, add the following line to the top of your file.
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: coords.scad
|
// LibFile: coords.scad
|
||||||
// Coordinate transformations and coordinate system conversions.
|
// Coordinate transformations and coordinate system conversions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
// Libfile: cubetruss.scad
|
// LibFile: cubetruss.scad
|
||||||
// Parts for making modular open-frame cross-braced trusses and connectors.
|
// Parts for making modular open-frame cross-braced trusses and connectors.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/cubetruss.scad>
|
// include <BOSL2/cubetruss.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
$cubetruss_size = 30;
|
$cubetruss_size = 30;
|
||||||
|
@ -16,7 +14,7 @@ $cubetruss_clip_thickness = 1.6;
|
||||||
|
|
||||||
// Function: cubetruss_dist()
|
// Function: cubetruss_dist()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_dist(cubes, gaps, [size], [strut]);
|
// cubetruss_dist(cubes, gaps, <size>, <strut>);
|
||||||
// Description:
|
// Description:
|
||||||
// Function to calculate the length of a cubetruss truss.
|
// Function to calculate the length of a cubetruss truss.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -24,7 +22,8 @@ $cubetruss_clip_thickness = 1.6;
|
||||||
// gaps = The number of extra strut widths to add in, corresponding to each time a truss butts up against another.
|
// gaps = The number of extra strut widths to add in, corresponding to each time a truss butts up against another.
|
||||||
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
function cubetruss_dist(cubes=0, gaps=0, size=undef, strut=undef) =
|
// Topics: Trusses
|
||||||
|
function cubetruss_dist(cubes=0, gaps=0, size, strut) =
|
||||||
let(
|
let(
|
||||||
size = is_undef(size)? $cubetruss_size : size,
|
size = is_undef(size)? $cubetruss_size : size,
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut
|
strut = is_undef(strut)? $cubetruss_strut_size : strut
|
||||||
|
@ -33,22 +32,24 @@ function cubetruss_dist(cubes=0, gaps=0, size=undef, strut=undef) =
|
||||||
|
|
||||||
// Module: cubetruss_segment()
|
// Module: cubetruss_segment()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_segment([size], [strut], [bracing]);
|
// cubetruss_segment(<size>, <strut>, <bracing>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a single cubetruss cube segment.
|
// Creates a single cubetruss cube segment.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// bracing = If true, adds internal cross-braces. Default: `$cubetruss_bracing` (usually true)
|
// bracing = If true, adds internal cross-braces. Default: `$cubetruss_bracing` (usually true)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples:
|
// Examples:
|
||||||
// cubetruss_segment(bracing=false);
|
// cubetruss_segment(bracing=false);
|
||||||
// cubetruss_segment(bracing=true);
|
// cubetruss_segment(bracing=true);
|
||||||
// cubetruss_segment(strut=4);
|
// cubetruss_segment(strut=4);
|
||||||
// cubetruss_segment(size=40);
|
// cubetruss_segment(size=40);
|
||||||
module cubetruss_segment(size=undef, strut=undef, bracing=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss_segment(size, strut, bracing, anchor=CENTER, spin=0, orient=UP) {
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
bracing = is_undef(bracing)? $cubetruss_bracing : bracing;
|
bracing = is_undef(bracing)? $cubetruss_bracing : bracing;
|
||||||
|
@ -100,7 +101,7 @@ module cubetruss_segment(size=undef, strut=undef, bracing=undef, anchor=CENTER,
|
||||||
|
|
||||||
// Module: cubetruss_clip()
|
// Module: cubetruss_clip()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_clip(extents, [size], [strut], [clipthick]);
|
// cubetruss_clip(extents, <size>, <strut>, <clipthick>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a pair of clips to add onto the end of a truss.
|
// Creates a pair of clips to add onto the end of a truss.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -108,14 +109,16 @@ module cubetruss_segment(size=undef, strut=undef, bracing=undef, anchor=CENTER,
|
||||||
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// clipthick = The thickness of the clip. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
// clipthick = The thickness of the clip. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples:
|
// Examples:
|
||||||
// cubetruss_clip(extents=2);
|
// cubetruss_clip(extents=2);
|
||||||
// cubetruss_clip(extents=1);
|
// cubetruss_clip(extents=1);
|
||||||
// cubetruss_clip(clipthick=2.5);
|
// cubetruss_clip(clipthick=2.5);
|
||||||
module cubetruss_clip(extents=1, size=undef, strut=undef, clipthick=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss_clip(extents=1, size, strut, clipthick, anchor=CENTER, spin=0, orient=UP) {
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
||||||
|
@ -162,7 +165,7 @@ module cubetruss_clip(extents=1, size=undef, strut=undef, clipthick=undef, ancho
|
||||||
|
|
||||||
// Module: cubetruss_foot()
|
// Module: cubetruss_foot()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_foot(w, [size], [strut], [clipthick]);
|
// cubetruss_foot(w, <size>, <strut>, <clipthick>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a foot that can be clipped onto the bottom of a truss for support.
|
// Creates a foot that can be clipped onto the bottom of a truss for support.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -170,13 +173,15 @@ module cubetruss_clip(extents=1, size=undef, strut=undef, clipthick=undef, ancho
|
||||||
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples:
|
// Examples:
|
||||||
// cubetruss_foot(w=1);
|
// cubetruss_foot(w=1);
|
||||||
// cubetruss_foot(w=3);
|
// cubetruss_foot(w=3);
|
||||||
module cubetruss_foot(w=1, size=undef, strut=undef, clipthick=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss_foot(w=1, size, strut, clipthick, anchor=CENTER, spin=0, orient=UP) {
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
||||||
|
@ -236,7 +241,7 @@ module cubetruss_foot(w=1, size=undef, strut=undef, clipthick=undef, anchor=CENT
|
||||||
|
|
||||||
// Module: cubetruss_joiner()
|
// Module: cubetruss_joiner()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_joiner([w], [vert], [size], [strut], [clipthick]);
|
// cubetruss_joiner(<w>, <vert>, <size>, <strut>, <clipthick>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a part to join two cubetruss trusses end-to-end.
|
// Creates a part to join two cubetruss trusses end-to-end.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -245,14 +250,16 @@ module cubetruss_foot(w=1, size=undef, strut=undef, clipthick=undef, anchor=CENT
|
||||||
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples:
|
// Examples:
|
||||||
// cubetruss_joiner(w=1, vert=false);
|
// cubetruss_joiner(w=1, vert=false);
|
||||||
// cubetruss_joiner(w=1, vert=true);
|
// cubetruss_joiner(w=1, vert=true);
|
||||||
// cubetruss_joiner(w=2, vert=true, anchor=BOT);
|
// cubetruss_joiner(w=2, vert=true, anchor=BOT);
|
||||||
module cubetruss_joiner(w=1, vert=true, size=undef, strut=undef, clipthick=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss_joiner(w=1, vert=true, size, strut, clipthick, anchor=CENTER, spin=0, orient=UP) {
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
||||||
|
@ -301,19 +308,23 @@ module cubetruss_joiner(w=1, vert=true, size=undef, strut=undef, clipthick=undef
|
||||||
|
|
||||||
// Module: cubetruss_uclip()
|
// Module: cubetruss_uclip()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_uclip(dual, [size], [strut], [clipthick]);
|
// cubetruss_uclip(dual, <size>, <strut>, <clipthick>);
|
||||||
// Description:
|
// Description:
|
||||||
|
// Creates a small clip that can snap around one or two adjacent struts.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
// dual = If true, create a clip to clip around two adjacent struts. If false, just fit around one strut. Default: true
|
||||||
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
// size = The length of each side of the cubetruss cubes. Default: `$cubetruss_size` (usually 30)
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples:
|
// Examples:
|
||||||
// cubetruss_uclip(dual=false);
|
// cubetruss_uclip(dual=false);
|
||||||
// cubetruss_uclip(dual=true);
|
// cubetruss_uclip(dual=true);
|
||||||
module cubetruss_uclip(dual=true, size=undef, strut=undef, clipthick=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss_uclip(dual=true, size, strut, clipthick, anchor=CENTER, spin=0, orient=UP) {
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
clipthick = is_undef(clipthick)? $cubetruss_clip_thickness : clipthick;
|
||||||
|
@ -342,7 +353,7 @@ module cubetruss_uclip(dual=true, size=undef, strut=undef, clipthick=undef, anch
|
||||||
|
|
||||||
// Module: cubetruss()
|
// Module: cubetruss()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss(extents, clips, bracing, size, strut, clipthick);
|
// cubetruss(extents, <clips>, <bracing>, <size>, <strut>, <clipthick>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a cubetruss truss, assembled out of one or more cubical segments.
|
// Creates a cubetruss truss, assembled out of one or more cubical segments.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -352,9 +363,11 @@ module cubetruss_uclip(dual=true, size=undef, strut=undef, clipthick=undef, anch
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// bracing = If true, adds internal cross-braces. Default: `$cubetruss_bracing` (usually true)
|
// bracing = If true, adds internal cross-braces. Default: `$cubetruss_bracing` (usually true)
|
||||||
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples(FlatSpin):
|
// Examples(FlatSpin):
|
||||||
// cubetruss(extents=3);
|
// cubetruss(extents=3);
|
||||||
// cubetruss(extents=3, clips=FRONT);
|
// cubetruss(extents=3, clips=FRONT);
|
||||||
|
@ -362,7 +375,7 @@ module cubetruss_uclip(dual=true, size=undef, strut=undef, clipthick=undef, anch
|
||||||
// cubetruss(extents=[2,3]);
|
// cubetruss(extents=[2,3]);
|
||||||
// cubetruss(extents=[1,4,2]);
|
// cubetruss(extents=[1,4,2]);
|
||||||
// cubetruss(extents=[1,4,2], bracing=false);
|
// cubetruss(extents=[1,4,2], bracing=false);
|
||||||
module cubetruss(extents=6, clips=[], bracing=undef, size=undef, strut=undef, clipthick=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss(extents=6, clips=[], bracing, size, strut, clipthick, anchor=CENTER, spin=0, orient=UP) {
|
||||||
clips = is_vector(clips)? [clips] : clips;
|
clips = is_vector(clips)? [clips] : clips;
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
|
@ -410,7 +423,7 @@ module cubetruss(extents=6, clips=[], bracing=undef, size=undef, strut=undef, cl
|
||||||
|
|
||||||
// Module: cubetruss_corner()
|
// Module: cubetruss_corner()
|
||||||
// Usage:
|
// Usage:
|
||||||
// cubetruss_corner(h, extents, [bracing], [size], [strut], [clipthick);
|
// cubetruss_corner(h, extents, <bracing>, <size>, <strut>, <clipthick>);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a corner cubetruss with extents jutting out in one or more directions.
|
// Creates a corner cubetruss with extents jutting out in one or more directions.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -420,16 +433,18 @@ module cubetruss(extents=6, clips=[], bracing=undef, size=undef, strut=undef, cl
|
||||||
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
// strut = The width of the struts on the cubetruss cubes. Default: `$cubetruss_strut_size` (usually 3)
|
||||||
// bracing = If true, adds internal cross-braces. Default: `$cubetruss_bracing` (usually true)
|
// bracing = If true, adds internal cross-braces. Default: `$cubetruss_bracing` (usually true)
|
||||||
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
// clipthick = The thickness of the clips. Default: `$cubetruss_clip_thickness` (usually 1.6)
|
||||||
|
// ---
|
||||||
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
// anchor = Translate so anchor point is at origin (0,0,0). See [anchor](attachments.scad#anchor). Default: `CENTER`
|
||||||
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
// spin = Rotate this many degrees around the Z axis. See [spin](attachments.scad#spin). Default: `0`
|
||||||
// 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`
|
||||||
|
// Topics: Attachable, Trusses
|
||||||
// Examples(FlatSpin):
|
// Examples(FlatSpin):
|
||||||
// cubetruss_corner(extents=2);
|
// cubetruss_corner(extents=2);
|
||||||
// cubetruss_corner(extents=2, h=2);
|
// cubetruss_corner(extents=2, h=2);
|
||||||
// cubetruss_corner(extents=[3,3,0,0,2]);
|
// cubetruss_corner(extents=[3,3,0,0,2]);
|
||||||
// cubetruss_corner(extents=[3,0,3,0,2]);
|
// cubetruss_corner(extents=[3,0,3,0,2]);
|
||||||
// cubetruss_corner(extents=[3,3,3,3,2]);
|
// cubetruss_corner(extents=[3,3,3,3,2]);
|
||||||
module cubetruss_corner(h=1, extents=[1,1,0,0,1], bracing=undef, size=undef, strut=undef, clipthick=undef, anchor=CENTER, spin=0, orient=UP) {
|
module cubetruss_corner(h=1, extents=[1,1,0,0,1], bracing, size, strut, clipthick, anchor=CENTER, spin=0, orient=UP) {
|
||||||
size = is_undef(size)? $cubetruss_size : size;
|
size = is_undef(size)? $cubetruss_size : size;
|
||||||
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
strut = is_undef(strut)? $cubetruss_strut_size : strut;
|
||||||
bracing = is_undef(bracing)? $cubetruss_bracing : bracing;
|
bracing = is_undef(bracing)? $cubetruss_bracing : bracing;
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: debug.scad
|
// LibFile: debug.scad
|
||||||
// Helpers to make debugging OpenScad code easier.
|
// Helpers to make debugging OpenScad code easier.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/debug.scad>
|
// include <BOSL2/debug.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: distributors.scad
|
// LibFile: distributors.scad
|
||||||
// Functions and modules to distribute children or copies of children.
|
// Functions and modules to distribute children or copies of children.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: edges.scad
|
// LibFile: edges.scad
|
||||||
// Routines to work with edge sets and edge set descriptors.
|
// Routines to work with edge sets and edge set descriptors.
|
||||||
// To use this, add the following line to the top of your file.
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: geometry.scad
|
// LibFile: geometry.scad
|
||||||
// Geometry helpers.
|
// Geometry helpers.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: hingesnaps.scad
|
// LibFile: hingesnaps.scad
|
||||||
// Useful hinge mask and snaps shapes.
|
// Useful hinge mask and snaps shapes.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/hingesnaps.scad>
|
// include <BOSL2/hingesnaps.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,11 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: hull.scad
|
// LibFile: hull.scad
|
||||||
// Functions to create 2D and 3D convex hulls.
|
// Functions to create 2D and 3D convex hulls.
|
||||||
// To use, add the following line to the beginning of your file:
|
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
|
||||||
// include <BOSL2/hull.scad>
|
|
||||||
// ```
|
|
||||||
// Derived from Oskar Linde's Hull:
|
// Derived from Oskar Linde's Hull:
|
||||||
// - https://github.com/openscad/scad-utils
|
// - https://github.com/openscad/scad-utils
|
||||||
|
// Includes:
|
||||||
|
// include <BOSL2/std.scad>
|
||||||
|
// include <BOSL2/hull.scad>
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -16,12 +16,9 @@
|
||||||
// implemented it from scratch from the descriptions and equations on Wikipedia
|
// implemented it from scratch from the descriptions and equations on Wikipedia
|
||||||
// and the web, using Mathematica for calculations and testing, and I now
|
// and the web, using Mathematica for calculations and testing, and I now
|
||||||
// release it into the public domain.
|
// release it into the public domain.
|
||||||
// .
|
// Includes:
|
||||||
// To use, add the following line to the beginning of your file:
|
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/involute_gears.scad>
|
// include <BOSL2/involute_gears.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: joiners.scad
|
// LibFile: joiners.scad
|
||||||
// Snap-together joiners.
|
// Snap-together joiners.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/joiners.scad>
|
// include <BOSL2/joiners.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: knurling.scad
|
// LibFile: knurling.scad
|
||||||
// Shapes and masks for knurling cylinders.
|
// Shapes and masks for knurling cylinders.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
// include <BOSL2/knurling.scad>
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: linear_bearings.scad
|
// LibFile: linear_bearings.scad
|
||||||
// Linear Bearing clips/holders.
|
// Linear Bearing clips/holders.
|
||||||
// To use, add these lines to the top of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/linear_bearings.scad>
|
// include <BOSL2/linear_bearings.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: masks.scad
|
// LibFile: masks.scad
|
||||||
// Masking shapes.
|
// Masking shapes.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: math.scad
|
// LibFile: math.scad
|
||||||
// Math helper functions.
|
// Math helper functions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: metric_screws.scad
|
// LibFile: metric_screws.scad
|
||||||
// Screws, Bolts, and Nuts.
|
// Screws, Bolts, and Nuts.
|
||||||
// To use, include the following lines at the top of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/metric_screws.scad>
|
// include <BOSL2/metric_screws.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: transforms.scad
|
// LibFile: mutators.scad
|
||||||
// Functions and modules to mutate children in various ways.
|
// Functions and modules to mutate children in various ways.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,7 +25,7 @@
|
||||||
// }
|
// }
|
||||||
// translate([10,8,4]) cube(5);
|
// translate([10,8,4]) cube(5);
|
||||||
// translate([3,0,12]) cube(2);
|
// translate([3,0,12]) cube(2);
|
||||||
module bounding_box(excess=0, planar=true) {
|
module bounding_box(excess=0, planar=false) {
|
||||||
xs = excess>.1? excess : 1;
|
xs = excess>.1? excess : 1;
|
||||||
// a 3D approx. of the children projection on X axis
|
// a 3D approx. of the children projection on X axis
|
||||||
module _xProjection()
|
module _xProjection()
|
||||||
|
@ -607,9 +605,11 @@ module round2d(r, or, ir)
|
||||||
// shell2d([-10,10]) {square([40,100], center=true); square([100,40], center=true);}
|
// shell2d([-10,10]) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
// shell2d(10,or=10) {square([40,100], center=true); square([100,40], center=true);}
|
// shell2d(10,or=10) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
// shell2d(10,ir=10) {square([40,100], center=true); square([100,40], center=true);}
|
// shell2d(10,ir=10) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
// shell2d(10,round=10) {square([40,100], center=true); square([100,40], center=true);}
|
// shell2d(10,or=[10,0]) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
// shell2d(10,fill=10) {square([40,100], center=true); square([100,40], center=true);}
|
// shell2d(10,or=[0,10]) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
// shell2d(8,or=16,ir=8,round=16,fill=8) {square([40,100], center=true); square([100,40], center=true);}
|
// shell2d(10,ir=[10,0]) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
|
// shell2d(10,ir=[0,10]) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
|
// shell2d(8,or=[16,8],ir=[16,8]) {square([40,100], center=true); square([100,40], center=true);}
|
||||||
module shell2d(thickness, or=0, ir=0)
|
module shell2d(thickness, or=0, ir=0)
|
||||||
{
|
{
|
||||||
thickness = is_num(thickness)? (
|
thickness = is_num(thickness)? (
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: nema_steppers.scad
|
// LibFile: nema_steppers.scad
|
||||||
// Masks and models for NEMA stepper motors.
|
// Masks and models for NEMA stepper motors.
|
||||||
// To use, add these lines to the top of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/nema_steppers.scad>
|
// include <BOSL2/nema_steppers.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: partitions.scad
|
// LibFile: partitions.scad
|
||||||
// Modules to help partition large objects into smaller parts that can be reassembled.
|
// Modules to help partition large objects into smaller parts that can be reassembled.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/partitions.scad>
|
// include <BOSL2/partitions.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: paths.scad
|
// LibFile: paths.scad
|
||||||
// Support for polygons and paths.
|
// Support for polygons and paths.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: phillips_drive.scad
|
// LibFile: phillips_drive.scad
|
||||||
// Phillips driver bits
|
// Phillips driver bits
|
||||||
// To use, add these lines to the top of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/phillips_drive.scad>
|
// include <BOSL2/phillips_drive.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: polyhedra.scad
|
// LibFile: polyhedra.scad
|
||||||
// Useful platonic, archimedian, and catalan polyhedra.
|
// Useful platonic, archimedian, and catalan polyhedra.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/polyhedra.scad>
|
// include <BOSL2/polyhedra.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,10 +2,8 @@
|
||||||
// LibFile: primitives.scad
|
// LibFile: primitives.scad
|
||||||
// The basic built-in shapes, reworked to integrate better with
|
// The basic built-in shapes, reworked to integrate better with
|
||||||
// other BOSL2 library shapes and utilities.
|
// other BOSL2 library shapes and utilities.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
///////////////////////////////////////////
|
///////////////////////////////////////////
|
||||||
// LibFile: quaternions.scad
|
// LibFile: quaternions.scad
|
||||||
// Support for Quaternions.
|
// Support for Quaternions.
|
||||||
// To use, add the following line to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
///////////////////////////////////////////
|
///////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: queues.scad
|
// LibFile: queues.scad
|
||||||
// Queue data structure implementation.
|
// Queue data structure implementation.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
// include <BOSL2/queues.scad>
|
||||||
// use <BOSL2/queues.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: regions.scad
|
// LibFile: regions.scad
|
||||||
// Regions and 2D boolean geometry
|
// Regions and 2D boolean geometry
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,11 +2,9 @@
|
||||||
// LibFile: rounding.scad
|
// LibFile: rounding.scad
|
||||||
// Routines to create rounded corners, with either circular rounding,
|
// Routines to create rounded corners, with either circular rounding,
|
||||||
// or continuous curvature rounding with no sudden curvature transitions.
|
// or continuous curvature rounding with no sudden curvature transitions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/rounding.scad>
|
// include <BOSL2/rounding.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
include <beziers.scad>
|
include <beziers.scad>
|
||||||
include <structs.scad>
|
include <structs.scad>
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: screws.scad
|
// LibFile: screws.scad
|
||||||
// Functions and modules for creating metric and UTS standard screws and nuts.
|
// Functions and modules for creating metric and UTS standard screws and nuts.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/screws.scad>
|
// include <BOSL2/screws.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
include <structs.scad>
|
include <structs.scad>
|
||||||
|
|
|
@ -120,7 +120,6 @@ def run_openscad_script(libfile, infile, imgfile, imgsize=(320,240), eye=None, s
|
||||||
class ImageProcessing(object):
|
class ImageProcessing(object):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.examples = []
|
self.examples = []
|
||||||
self.commoncode = []
|
|
||||||
self.imgroot = ""
|
self.imgroot = ""
|
||||||
self.keep_scripts = False
|
self.keep_scripts = False
|
||||||
self.force = False
|
self.force = False
|
||||||
|
@ -132,9 +131,6 @@ class ImageProcessing(object):
|
||||||
def add_image(self, libfile, imgfile, code, extype):
|
def add_image(self, libfile, imgfile, code, extype):
|
||||||
self.examples.append((libfile, imgfile, code, extype))
|
self.examples.append((libfile, imgfile, code, extype))
|
||||||
|
|
||||||
def set_commoncode(self, code):
|
|
||||||
self.commoncode = code
|
|
||||||
|
|
||||||
def process_examples(self, imgroot, force=False, test_only=False):
|
def process_examples(self, imgroot, force=False, test_only=False):
|
||||||
self.imgroot = imgroot
|
self.imgroot = imgroot
|
||||||
self.force = force
|
self.force = force
|
||||||
|
@ -171,14 +167,7 @@ class ImageProcessing(object):
|
||||||
print("")
|
print("")
|
||||||
return
|
return
|
||||||
|
|
||||||
stdlibs = ["std.scad", "debug.scad"]
|
|
||||||
script = ""
|
script = ""
|
||||||
for lib in stdlibs:
|
|
||||||
script += "include <BOSL2/%s>\n" % lib
|
|
||||||
if libfile not in stdlibs:
|
|
||||||
script += "include <BOSL2/%s>\n" % libfile
|
|
||||||
for line in self.commoncode:
|
|
||||||
script += line+"\n"
|
|
||||||
for line in code:
|
for line in code:
|
||||||
script += line+"\n"
|
script += line+"\n"
|
||||||
|
|
||||||
|
@ -334,12 +323,16 @@ class LeafNode(object):
|
||||||
self.name = ""
|
self.name = ""
|
||||||
self.leaftype = ""
|
self.leaftype = ""
|
||||||
self.status = ""
|
self.status = ""
|
||||||
self.description = []
|
self.topics = []
|
||||||
self.usages = []
|
self.usages = []
|
||||||
|
self.description = []
|
||||||
|
self.figures = []
|
||||||
|
self.returns = []
|
||||||
|
self.customs = []
|
||||||
self.arguments = []
|
self.arguments = []
|
||||||
|
self.named_arguments = []
|
||||||
self.anchors = []
|
self.anchors = []
|
||||||
self.side_effects = []
|
self.side_effects = []
|
||||||
self.figures = []
|
|
||||||
self.examples = []
|
self.examples = []
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
@ -401,6 +394,12 @@ class LeafNode(object):
|
||||||
dummy, status = line.split(":", 1)
|
dummy, status = line.split(":", 1)
|
||||||
self.status = status.strip()
|
self.status = status.strip()
|
||||||
continue
|
continue
|
||||||
|
if line.startswith("Topics:"):
|
||||||
|
dummy, topic_line = line.split(":", 1)
|
||||||
|
topics = []
|
||||||
|
for topic in topic_line.split(","):
|
||||||
|
self.topics.append(topic.strip())
|
||||||
|
continue
|
||||||
if line.startswith("Usage:"):
|
if line.startswith("Usage:"):
|
||||||
dummy, title = line.split(":", 1)
|
dummy, title = line.split(":", 1)
|
||||||
title = title.strip()
|
title = title.strip()
|
||||||
|
@ -419,6 +418,20 @@ class LeafNode(object):
|
||||||
lines, block = get_comment_block(lines, prefix)
|
lines, block = get_comment_block(lines, prefix)
|
||||||
self.description.extend(block)
|
self.description.extend(block)
|
||||||
continue
|
continue
|
||||||
|
if line.startswith("Returns:"):
|
||||||
|
dummy, desc = line.split(":", 1)
|
||||||
|
desc = desc.strip()
|
||||||
|
if desc:
|
||||||
|
self.returns.append(desc)
|
||||||
|
lines, block = get_comment_block(lines, prefix)
|
||||||
|
self.returns.extend(block)
|
||||||
|
continue
|
||||||
|
if line.startswith("Custom:"):
|
||||||
|
dummy, title = line.split(":", 1)
|
||||||
|
title = title.strip()
|
||||||
|
lines, block = get_comment_block(lines, prefix)
|
||||||
|
self.customs.append( (title, block) )
|
||||||
|
continue
|
||||||
m = figpat.match(line)
|
m = figpat.match(line)
|
||||||
if m: # Figure(TYPE):
|
if m: # Figure(TYPE):
|
||||||
plural = m.group(1) == "Figures"
|
plural = m.group(1) == "Figures"
|
||||||
|
@ -435,7 +448,11 @@ class LeafNode(object):
|
||||||
continue
|
continue
|
||||||
if line.startswith("Arguments:"):
|
if line.startswith("Arguments:"):
|
||||||
lines, block = get_comment_block(lines, prefix)
|
lines, block = get_comment_block(lines, prefix)
|
||||||
|
named = False
|
||||||
for line in block:
|
for line in block:
|
||||||
|
if line.strip() == "---":
|
||||||
|
named = True
|
||||||
|
continue
|
||||||
if "=" not in line:
|
if "=" not in line:
|
||||||
print("Error in {}: Could not parse line in Argument block. Missing '='.".format(self.name))
|
print("Error in {}: Could not parse line in Argument block. Missing '='.".format(self.name))
|
||||||
print("Line read was:")
|
print("Line read was:")
|
||||||
|
@ -444,7 +461,10 @@ class LeafNode(object):
|
||||||
argname, argdesc = line.split("=", 1)
|
argname, argdesc = line.split("=", 1)
|
||||||
argname = argname.strip()
|
argname = argname.strip()
|
||||||
argdesc = argdesc.strip()
|
argdesc = argdesc.strip()
|
||||||
self.arguments.append([argname, argdesc])
|
if named:
|
||||||
|
self.named_arguments.append([argname, argdesc])
|
||||||
|
else:
|
||||||
|
self.arguments.append([argname, argdesc])
|
||||||
continue
|
continue
|
||||||
if line.startswith("Extra Anchors:") or line.startswith("Anchors:"):
|
if line.startswith("Extra Anchors:") or line.startswith("Anchors:"):
|
||||||
lines, block = get_comment_block(lines, prefix)
|
lines, block = get_comment_block(lines, prefix)
|
||||||
|
@ -488,7 +508,7 @@ class LeafNode(object):
|
||||||
|
|
||||||
return lines
|
return lines
|
||||||
|
|
||||||
def gen_md(self, fileroot, imgroot):
|
def gen_md(self, fileroot, imgroot, libnode, sectnode):
|
||||||
out = []
|
out = []
|
||||||
if self.name:
|
if self.name:
|
||||||
out.append("### " + mkdn_esc(self.name))
|
out.append("### " + mkdn_esc(self.name))
|
||||||
|
@ -505,14 +525,14 @@ class LeafNode(object):
|
||||||
out.append("- {0}".format(mkdn_esc(usage)))
|
out.append("- {0}".format(mkdn_esc(usage)))
|
||||||
out.append("")
|
out.append("")
|
||||||
if self.description:
|
if self.description:
|
||||||
out.append("**Description**:")
|
out.append("**Description:**")
|
||||||
for line in self.description:
|
for line in self.description:
|
||||||
out.append(mkdn_esc(line))
|
out.append(mkdn_esc(line))
|
||||||
out.append("")
|
out.append("")
|
||||||
fignum = 0
|
fignum = 0
|
||||||
for title, excode, extype in self.figures:
|
for title, excode, extype in self.figures:
|
||||||
fignum += 1
|
fignum += 1
|
||||||
extitle = "**Figure {0}**:".format(fignum)
|
extitle = "**Figure {0}:**".format(fignum)
|
||||||
if title:
|
if title:
|
||||||
extitle += " " + mkdn_esc(title)
|
extitle += " " + mkdn_esc(title)
|
||||||
san_name = re.sub(r"[^A-Za-z0-9_]", "", self.name)
|
san_name = re.sub(r"[^A-Za-z0-9_]", "", self.name)
|
||||||
|
@ -521,7 +541,17 @@ class LeafNode(object):
|
||||||
("fig%d" % fignum),
|
("fig%d" % fignum),
|
||||||
"gif" if "Spin" in extype else "png"
|
"gif" if "Spin" in extype else "png"
|
||||||
)
|
)
|
||||||
imgprc.add_image(fileroot+".scad", imgfile, excode, extype)
|
icode = []
|
||||||
|
for line in libnode.includes:
|
||||||
|
icode.append(line)
|
||||||
|
for line in libnode.commoncode:
|
||||||
|
icode.append(line)
|
||||||
|
for line in excode:
|
||||||
|
if line.strip().startswith("--"):
|
||||||
|
icode.append(line.strip()[2:])
|
||||||
|
else:
|
||||||
|
icode.append(line)
|
||||||
|
imgprc.add_image(fileroot+".scad", imgfile, icode, extype)
|
||||||
out.append(extitle)
|
out.append(extitle)
|
||||||
out.append("")
|
out.append("")
|
||||||
out.append(
|
out.append(
|
||||||
|
@ -533,9 +563,21 @@ class LeafNode(object):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
out.append("")
|
out.append("")
|
||||||
|
if self.returns:
|
||||||
|
out.append("**Returns:**")
|
||||||
|
for line in self.returns:
|
||||||
|
out.append(mkdn_esc(line))
|
||||||
|
out.append("")
|
||||||
|
if self.customs:
|
||||||
|
for title, block in self.customs:
|
||||||
|
out.append("**{}:**".format(title))
|
||||||
|
for line in block:
|
||||||
|
out.append(mkdn_esc(line))
|
||||||
|
out.append("")
|
||||||
if self.arguments:
|
if self.arguments:
|
||||||
out.append("Argument | What it does")
|
out.append("**Arguments:**")
|
||||||
out.append("--------------- | ------------------------------")
|
out.append("By Position | What it does")
|
||||||
|
out.append("---------------- | ------------------------------")
|
||||||
for argname, argdesc in self.arguments:
|
for argname, argdesc in self.arguments:
|
||||||
argname = argname.replace(" / ", "` / `")
|
argname = argname.replace(" / ", "` / `")
|
||||||
out.append(
|
out.append(
|
||||||
|
@ -545,8 +587,20 @@ class LeafNode(object):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
out.append("")
|
out.append("")
|
||||||
|
if self.named_arguments:
|
||||||
|
out.append("By Name | What it does")
|
||||||
|
out.append("-------------- | ------------------------------")
|
||||||
|
for argname, argdesc in self.named_arguments:
|
||||||
|
argname = argname.replace(" / ", "` / `")
|
||||||
|
out.append(
|
||||||
|
"{0:15s} | {1}".format(
|
||||||
|
"`{0}`".format(argname),
|
||||||
|
mkdn_esc(argdesc)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
out.append("")
|
||||||
if self.side_effects:
|
if self.side_effects:
|
||||||
out.append("**Side Effects**:")
|
out.append("**Side Effects:**")
|
||||||
for sfx in self.side_effects:
|
for sfx in self.side_effects:
|
||||||
out.append("- " + mkdn_esc(sfx))
|
out.append("- " + mkdn_esc(sfx))
|
||||||
out.append("")
|
out.append("")
|
||||||
|
@ -562,13 +616,19 @@ class LeafNode(object):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
out.append("")
|
out.append("")
|
||||||
|
if self.topics:
|
||||||
|
topics = []
|
||||||
|
for topic in self.topics:
|
||||||
|
topics.append("[{0}](Topics#{0})".format(mkdn_esc(topic)))
|
||||||
|
out.append("**Related Topics:** {}".format(", ".join(topics)))
|
||||||
|
out.append("")
|
||||||
exnum = 0
|
exnum = 0
|
||||||
for title, excode, extype in self.examples:
|
for title, excode, extype in self.examples:
|
||||||
exnum += 1
|
exnum += 1
|
||||||
if len(self.examples) < 2:
|
if len(self.examples) < 2:
|
||||||
extitle = "**Example**:"
|
extitle = "**Example:**"
|
||||||
else:
|
else:
|
||||||
extitle = "**Example {0}**:".format(exnum)
|
extitle = "**Example {0}:**".format(exnum)
|
||||||
if title:
|
if title:
|
||||||
extitle += " " + mkdn_esc(title)
|
extitle += " " + mkdn_esc(title)
|
||||||
san_name = re.sub(r"[^A-Za-z0-9_]", "", self.name)
|
san_name = re.sub(r"[^A-Za-z0-9_]", "", self.name)
|
||||||
|
@ -578,12 +638,25 @@ class LeafNode(object):
|
||||||
"gif" if "Spin" in extype else "png"
|
"gif" if "Spin" in extype else "png"
|
||||||
)
|
)
|
||||||
if "NORENDER" not in extype:
|
if "NORENDER" not in extype:
|
||||||
imgprc.add_image(fileroot+".scad", imgfile, excode, extype)
|
icode = []
|
||||||
|
for line in libnode.includes:
|
||||||
|
icode.append(line)
|
||||||
|
for line in libnode.commoncode:
|
||||||
|
icode.append(line)
|
||||||
|
for line in excode:
|
||||||
|
if line.strip().startswith("--"):
|
||||||
|
icode.append(line.strip()[2:])
|
||||||
|
else:
|
||||||
|
icode.append(line)
|
||||||
|
imgprc.add_image(fileroot+".scad", imgfile, icode, extype)
|
||||||
if "Hide" not in extype:
|
if "Hide" not in extype:
|
||||||
out.append(extitle)
|
out.append(extitle)
|
||||||
out.append("")
|
out.append("")
|
||||||
for line in excode:
|
for line in libnode.includes:
|
||||||
out.append(" " + line)
|
out.append(" " + line)
|
||||||
|
for line in excode:
|
||||||
|
if not line.strip().startswith("--"):
|
||||||
|
out.append(" " + line)
|
||||||
out.append("")
|
out.append("")
|
||||||
if "NORENDER" not in extype:
|
if "NORENDER" not in extype:
|
||||||
out.append(
|
out.append(
|
||||||
|
@ -662,7 +735,7 @@ class Section(object):
|
||||||
out.append("")
|
out.append("")
|
||||||
return out
|
return out
|
||||||
|
|
||||||
def gen_md(self, count, fileroot, imgroot):
|
def gen_md(self, count, fileroot, imgroot, libnode):
|
||||||
out = []
|
out = []
|
||||||
if self.name:
|
if self.name:
|
||||||
out.append("# %d. %s" % (count, mkdn_esc(self.name)))
|
out.append("# %d. %s" % (count, mkdn_esc(self.name)))
|
||||||
|
@ -679,7 +752,7 @@ class Section(object):
|
||||||
out.append("")
|
out.append("")
|
||||||
for title, figcode, figtype in self.figures:
|
for title, figcode, figtype in self.figures:
|
||||||
Section.fignum += 1
|
Section.fignum += 1
|
||||||
figtitle = "**Figure {0}**:".format(Section.fignum)
|
figtitle = "**Figure {0}:**".format(Section.fignum)
|
||||||
if title:
|
if title:
|
||||||
figtitle += " " + mkdn_esc(title)
|
figtitle += " " + mkdn_esc(title)
|
||||||
out.append(figtitle)
|
out.append(figtitle)
|
||||||
|
@ -699,10 +772,20 @@ class Section(object):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
out.append("")
|
out.append("")
|
||||||
imgprc.add_image(fileroot+".scad", imgfile, figcode, figtype)
|
icode = []
|
||||||
|
for line in libnode.includes:
|
||||||
|
icode.append(line)
|
||||||
|
for line in libnode.commoncode:
|
||||||
|
icode.append(line)
|
||||||
|
for line in figcode:
|
||||||
|
if line.strip().startswith("--"):
|
||||||
|
icode.append(line.strip()[2:])
|
||||||
|
else:
|
||||||
|
icode.append(line)
|
||||||
|
imgprc.add_image(fileroot+".scad", imgfile, icode, figtype)
|
||||||
in_block = False
|
in_block = False
|
||||||
for node in self.leaf_nodes:
|
for node in self.leaf_nodes:
|
||||||
out += node.gen_md(fileroot, imgroot)
|
out += node.gen_md(fileroot, imgroot, libnode, self)
|
||||||
return out
|
return out
|
||||||
|
|
||||||
|
|
||||||
|
@ -710,9 +793,10 @@ class LibFile(object):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.name = ""
|
self.name = ""
|
||||||
self.description = []
|
self.description = []
|
||||||
|
self.includes = []
|
||||||
self.commoncode = []
|
self.commoncode = []
|
||||||
self.sections = []
|
self.sections = []
|
||||||
self.dep_sect = None
|
self.deprecated_section = None
|
||||||
|
|
||||||
def parse_lines(self, lines, prefix):
|
def parse_lines(self, lines, prefix):
|
||||||
currsect = None
|
currsect = None
|
||||||
|
@ -739,6 +823,12 @@ class LibFile(object):
|
||||||
lines, block = get_comment_block(lines, prefix, blanks=2)
|
lines, block = get_comment_block(lines, prefix, blanks=2)
|
||||||
self.description.extend(block)
|
self.description.extend(block)
|
||||||
|
|
||||||
|
# Check for Includes header.
|
||||||
|
if lines and lines[0].startswith(prefix + "Includes:"):
|
||||||
|
lines.pop(0)
|
||||||
|
lines, block = get_comment_block(lines, prefix)
|
||||||
|
self.includes.extend(block)
|
||||||
|
|
||||||
# Check for CommonCode header.
|
# Check for CommonCode header.
|
||||||
if lines and lines[0].startswith(prefix + "CommonCode:"):
|
if lines and lines[0].startswith(prefix + "CommonCode:"):
|
||||||
lines.pop(0)
|
lines.pop(0)
|
||||||
|
@ -758,10 +848,10 @@ class LibFile(object):
|
||||||
lines = node.parse_lines(lines, prefix)
|
lines = node.parse_lines(lines, prefix)
|
||||||
deprecated = node.status.startswith("DEPRECATED")
|
deprecated = node.status.startswith("DEPRECATED")
|
||||||
if deprecated:
|
if deprecated:
|
||||||
if self.dep_sect == None:
|
if self.deprecated_section == None:
|
||||||
self.dep_sect = Section()
|
self.deprecated_section = Section()
|
||||||
self.dep_sect.name = "Deprecations"
|
self.deprecated_section.name = "Deprecations"
|
||||||
sect = self.dep_sect
|
sect = self.deprecated_section
|
||||||
else:
|
else:
|
||||||
if currsect == None:
|
if currsect == None:
|
||||||
currsect = Section()
|
currsect = Section()
|
||||||
|
@ -773,7 +863,6 @@ class LibFile(object):
|
||||||
return lines
|
return lines
|
||||||
|
|
||||||
def gen_md(self, fileroot, imgroot):
|
def gen_md(self, fileroot, imgroot):
|
||||||
imgprc.set_commoncode(self.commoncode)
|
|
||||||
out = []
|
out = []
|
||||||
if self.name:
|
if self.name:
|
||||||
out.append("# Library File " + mkdn_esc(self.name))
|
out.append("# Library File " + mkdn_esc(self.name))
|
||||||
|
@ -789,30 +878,37 @@ class LibFile(object):
|
||||||
out.append(mkdn_esc(line))
|
out.append(mkdn_esc(line))
|
||||||
out.append("")
|
out.append("")
|
||||||
in_block = False
|
in_block = False
|
||||||
|
if self.includes:
|
||||||
|
out.append("To use, add the following lines to the beginning of your file:")
|
||||||
|
out.append("```openscad")
|
||||||
|
for line in self.includes:
|
||||||
|
out.append(" " + line)
|
||||||
|
out.append("```")
|
||||||
|
out.append("")
|
||||||
if self.name or self.description:
|
if self.name or self.description:
|
||||||
out.append("---")
|
out.append("---")
|
||||||
out.append("")
|
out.append("")
|
||||||
|
|
||||||
if self.sections or self.dep_sect:
|
if self.sections or self.deprecated_section:
|
||||||
out.append("# Table of Contents")
|
out.append("# Table of Contents")
|
||||||
out.append("")
|
out.append("")
|
||||||
cnt = 0
|
cnt = 0
|
||||||
for sect in self.sections:
|
for sect in self.sections:
|
||||||
cnt += 1
|
cnt += 1
|
||||||
out += sect.gen_md_toc(cnt)
|
out += sect.gen_md_toc(cnt)
|
||||||
if self.dep_sect:
|
if self.deprecated_section:
|
||||||
cnt += 1
|
cnt += 1
|
||||||
out += self.dep_sect.gen_md_toc(cnt)
|
out += self.deprecated_section.gen_md_toc(cnt)
|
||||||
out.append("---")
|
out.append("---")
|
||||||
out.append("")
|
out.append("")
|
||||||
|
|
||||||
cnt = 0
|
cnt = 0
|
||||||
for sect in self.sections:
|
for sect in self.sections:
|
||||||
cnt += 1
|
cnt += 1
|
||||||
out += sect.gen_md(cnt, fileroot, imgroot)
|
out += sect.gen_md(cnt, fileroot, imgroot, self)
|
||||||
if self.dep_sect:
|
if self.deprecated_section:
|
||||||
cnt += 1
|
cnt += 1
|
||||||
out += self.dep_sect.gen_md(cnt, fileroot, imgroot)
|
out += self.deprecated_section.gen_md(cnt, fileroot, imgroot, self)
|
||||||
return out
|
return out
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: shapes.scad
|
// LibFile: shapes.scad
|
||||||
// Common useful shapes and structured objects.
|
// Common useful shapes and structured objects.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: shapes2d.scad
|
// LibFile: shapes2d.scad
|
||||||
// Common useful 2D shapes.
|
// Common useful 2D shapes.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,13 +1,11 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: skin.scad
|
// LibFile: skin.scad
|
||||||
// Functions to skin arbitrary 2D profiles/paths in 3-space.
|
// Functions to skin arbitrary 2D profiles/paths in 3-space.
|
||||||
// To use, add the following line to the beginning of your file:
|
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
|
||||||
// include <BOSL2/skin.scad>
|
|
||||||
// ```
|
|
||||||
// Inspired by list-comprehension-demos skin():
|
// Inspired by list-comprehension-demos skin():
|
||||||
// - https://github.com/openscad/list-comprehension-demos/blob/master/skin.scad
|
// - https://github.com/openscad/list-comprehension-demos/blob/master/skin.scad
|
||||||
|
// Includes:
|
||||||
|
// include <BOSL2/std.scad>
|
||||||
|
// include <BOSL2/skin.scad>
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: sliders.scad
|
// LibFile: sliders.scad
|
||||||
// Simple V-groove based sliders and rails.
|
// Simple V-groove based sliders and rails.
|
||||||
// To use, add these lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/sliders.scad>
|
// include <BOSL2/sliders.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: stacks.scad
|
// LibFile: stacks.scad
|
||||||
// Stack data structure implementation.
|
// Stack data structure implementation.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
// include <BOSL2/stacks.scad>
|
||||||
// use <BOSL2/stacks.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
6
std.scad
6
std.scad
|
@ -1,13 +1,11 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: std.scad
|
// LibFile: std.scad
|
||||||
// File that includes the standard BOSL include files.
|
// File that includes the standard BOSL include files.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
assert(version_num()>=20190301, "BOSL2 requires OpenSCAD version 2019.03.01 or later.");
|
assert(version_num()>=20190500, "BOSL2 requires OpenSCAD version 2019.05 or later.");
|
||||||
|
|
||||||
include <version.scad>
|
include <version.scad>
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: strings.scad
|
// LibFile: strings.scad
|
||||||
// String manipulation and formatting functions.
|
// String manipulation and formatting functions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: structs.scad
|
// LibFile: structs.scad
|
||||||
// Struct/Dictionary manipulation functions.
|
// Struct/Dictionary manipulation functions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
// include <BOSL2/structs.scad>
|
||||||
// use <BOSL2/structs.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: threading.scad
|
// LibFile: threading.scad
|
||||||
// Triangular and Trapezoidal-Threaded Screw Rods and Nuts.
|
// Triangular and Trapezoidal-Threaded Screw Rods and Nuts.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/threading.scad>
|
// include <BOSL2/threading.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: torx_drive.scad
|
// LibFile: torx_drive.scad
|
||||||
// Torx driver bits
|
// Torx driver bits
|
||||||
// To use, add these lines to the top of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/torx_drive.scad>
|
// include <BOSL2/torx_drive.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: transforms.scad
|
// LibFile: transforms.scad
|
||||||
// Functions and modules for translation, rotation, reflection and skewing.
|
// Functions and modules for translation, rotation, reflection and skewing.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: triangulation.scad
|
// LibFile: triangulation.scad
|
||||||
// Functions to triangulate polyhedron faces.
|
// Functions to triangulate polyhedron faces.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/triangulation.scad>
|
// include <BOSL2/triangulation.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,11 +2,9 @@
|
||||||
// LibFile: turtle3d.scad
|
// LibFile: turtle3d.scad
|
||||||
// Three dimensional turtle graphics to generate 3d paths or sequences
|
// Three dimensional turtle graphics to generate 3d paths or sequences
|
||||||
// of 3d transformations.
|
// of 3d transformations.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/turtle3d.scad>
|
// include <BOSL2/turtle3d.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
include<structs.scad>
|
include<structs.scad>
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: vectors.scad
|
// LibFile: vectors.scad
|
||||||
// Vector math functions.
|
// Vector math functions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,14 +1,12 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: version.scad
|
// LibFile: version.scad
|
||||||
// File that provides functions to manage versioning.
|
// File that provides functions to manage versioning.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
BOSL_VERSION = [2,0,505];
|
BOSL_VERSION = [2,0,511];
|
||||||
|
|
||||||
|
|
||||||
// Section: BOSL Library Version Functions
|
// Section: BOSL Library Version Functions
|
||||||
|
|
8
vnf.scad
8
vnf.scad
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: vnf.scad
|
// LibFile: vnf.scad
|
||||||
// VNF structures, holding Vertices 'N' Faces for use with `polyhedron().`
|
// VNF structures, holding Vertices 'N' Faces for use with `polyhedron().`
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
// include <BOSL2/std.scad>
|
||||||
// use <BOSL2/std.scad>
|
// include <BOSL2/vnf.scad>
|
||||||
// use <BOSL2/vnf.scad>
|
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: walls.scad
|
// LibFile: walls.scad
|
||||||
// Various wall constructions.
|
// Various wall constructions.
|
||||||
// To use, add the following lines to the beginning of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/walls.scad>
|
// include <BOSL2/walls.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,9 @@
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// LibFile: wiring.scad
|
// LibFile: wiring.scad
|
||||||
// Rendering for wiring bundles
|
// Rendering for wiring bundles
|
||||||
// To use, include the following line at the top of your file:
|
// Includes:
|
||||||
// ```
|
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// include <BOSL2/wiring.scad>
|
// include <BOSL2/wiring.scad>
|
||||||
// ```
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue