mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
commit
17ff8b1f0d
28 changed files with 402 additions and 238 deletions
|
@ -73,6 +73,7 @@ DefineSynTags:
|
||||||
Path = Can return a Path.
|
Path = Can return a Path.
|
||||||
PathList = Can return a list of Paths.
|
PathList = Can return a list of Paths.
|
||||||
Region = Can return a Region.
|
Region = Can return a Region.
|
||||||
|
RegList = Can return a list of Regions.
|
||||||
Trans = Can transform children.
|
Trans = Can transform children.
|
||||||
VNF = Can return a VNF.
|
VNF = Can return a VNF.
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ Requires OpenSCAD 2021.01 or later.
|
||||||
- **NOTE:** BOSL2 IS BETA CODE. THE CODE IS STILL BEING REORGANIZED.
|
- **NOTE:** BOSL2 IS BETA CODE. THE CODE IS STILL BEING REORGANIZED.
|
||||||
- **NOTE2:** CODE WRITTEN FOR BOSLv1 PROBABLY WON'T WORK WITH BOSL2!
|
- **NOTE2:** CODE WRITTEN FOR BOSLv1 PROBABLY WON'T WORK WITH BOSL2!
|
||||||
|
|
||||||
[![Join the chat at https://gitter.im/BelfrySCAD/BOSL2](https://badges.gitter.im/BelfrySCAD/BOSL2.svg)](https://gitter.im/BelfrySCAD/BOSL2?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
[![Join the chat at https://gitter.im/revarbat/BOSL2](https://badges.gitter.im/revarbat/BOSL2.svg)](https://gitter.im/revarbat/BOSL2?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
||||||
|
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
|
@ -15,6 +15,7 @@ include <screws.scad>
|
||||||
|
|
||||||
// Module: knuckle_hinge()
|
// Module: knuckle_hinge()
|
||||||
// Synopsis: Creates a knuckle-hinge shape.
|
// Synopsis: Creates a knuckle-hinge shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Hinges, Parts
|
// Topics: Hinges, Parts
|
||||||
// See Also: living_hinge_mask(), snap_lock(), snap_socket()
|
// See Also: living_hinge_mask(), snap_lock(), snap_socket()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -346,6 +347,7 @@ module _knuckle_hinge_profile(offset, arm_height, arm_angle=45, knuckle_diam=4,
|
||||||
|
|
||||||
// Module: living_hinge_mask()
|
// Module: living_hinge_mask()
|
||||||
// Synopsis: Creates a mask to make a folding "living" hinge.
|
// Synopsis: Creates a mask to make a folding "living" hinge.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Hinges, Parts
|
// Topics: Hinges, Parts
|
||||||
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket(), apply_folding_hinges_and_snaps()
|
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket(), apply_folding_hinges_and_snaps()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -391,6 +393,7 @@ module folding_hinge_mask(l, thick, layerheight=0.2, foldangle=90, hingegap=unde
|
||||||
|
|
||||||
// Module: apply_folding_hinges_and_snaps()
|
// Module: apply_folding_hinges_and_snaps()
|
||||||
// Synopsis: Adds snap shapes and removes living hinges from a child shape.
|
// Synopsis: Adds snap shapes and removes living hinges from a child shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Hinges, Parts
|
// Topics: Hinges, Parts
|
||||||
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket()
|
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -476,6 +479,7 @@ module apply_folding_hinges_and_snaps(thick, foldangle=90, hinges=[], snaps=[],
|
||||||
|
|
||||||
// Module: snap_lock()
|
// Module: snap_lock()
|
||||||
// Synopsis: Creates a snap-lock shape.
|
// Synopsis: Creates a snap-lock shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Hinges, Parts
|
// Topics: Hinges, Parts
|
||||||
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket()
|
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -515,6 +519,7 @@ module snap_lock(thick, snaplen=5, snapdiam=5, layerheight=0.2, foldangle=90, hi
|
||||||
|
|
||||||
// Module: snap_socket()
|
// Module: snap_socket()
|
||||||
// Synopsis: Creates a snap-lock socket shape.
|
// Synopsis: Creates a snap-lock socket shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Hinges, Parts
|
// Topics: Hinges, Parts
|
||||||
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket()
|
// See Also: knuckle_hinge(), living_hinge_mask(), snap_lock(), snap_socket()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -17,6 +17,7 @@ include <rounding.scad>
|
||||||
|
|
||||||
// Function&Module: half_joiner_clear()
|
// Function&Module: half_joiner_clear()
|
||||||
// Synopsis: Creates a mask to clear space for a {{half_joiner()}}.
|
// Synopsis: Creates a mask to clear space for a {{half_joiner()}}.
|
||||||
|
// SynTags: Geom, VNF
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
|
@ -62,6 +63,7 @@ module half_joiner_clear(l=20, w=10, ang=30, clearance=0, overlap=0.01, anchor=C
|
||||||
|
|
||||||
// Function&Module: half_joiner()
|
// Function&Module: half_joiner()
|
||||||
// Synopsis: Creates a half-joiner shape to mate with a {{half_joiner2()}} shape..
|
// Synopsis: Creates a half-joiner shape to mate with a {{half_joiner2()}} shape..
|
||||||
|
// SynTags: Geom, VNF
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
|
@ -244,6 +246,7 @@ module half_joiner(l=20, w=10, base=10, ang=30, screwsize, anchor=CENTER, spin=0
|
||||||
|
|
||||||
// Function&Module: half_joiner2()
|
// Function&Module: half_joiner2()
|
||||||
// Synopsis: Creates a half_joiner2 shape to mate with a {{half_joiner()}} shape..
|
// Synopsis: Creates a half_joiner2 shape to mate with a {{half_joiner()}} shape..
|
||||||
|
// SynTags: Geom, VNF
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
|
@ -459,6 +462,7 @@ module half_joiner2(l=20, w=10, base=10, ang=30, screwsize, anchor=CENTER, spin=
|
||||||
|
|
||||||
// Module: joiner_clear()
|
// Module: joiner_clear()
|
||||||
// Synopsis: Creates a mask to clear space for a {{joiner()}} shape.
|
// Synopsis: Creates a mask to clear space for a {{joiner()}} shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -498,6 +502,7 @@ module joiner_clear(l=40, w=10, ang=30, clearance=0, overlap=0.01, anchor=CENTER
|
||||||
|
|
||||||
// Module: joiner()
|
// Module: joiner()
|
||||||
// Synopsis: Creates a joiner shape that can mate with another rotated joiner shape.
|
// Synopsis: Creates a joiner shape that can mate with another rotated joiner shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
// See Also: half_joiner_clear(), half_joiner(), half_joiner2(), joiner_clear(), joiner(), snap_pin(), rabbit_clip(), dovetail()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -549,6 +554,7 @@ module joiner(l=40, w=10, base=10, ang=30, screwsize, anchor=CENTER, spin=0, ori
|
||||||
|
|
||||||
// Module: dovetail()
|
// Module: dovetail()
|
||||||
// Synopsis: Creates a possibly tapered dovetail shape.
|
// Synopsis: Creates a possibly tapered dovetail shape.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: joiner(), snap_pin(), rabbit_clip()
|
// See Also: joiner(), snap_pin(), rabbit_clip()
|
||||||
//
|
//
|
||||||
|
@ -819,6 +825,7 @@ function _pin_size(size) =
|
||||||
|
|
||||||
// Module: snap_pin()
|
// Module: snap_pin()
|
||||||
// Synopsis: Creates a snap-pin that can slot into a {{snap_pin_socket()}} to join two parts.
|
// Synopsis: Creates a snap-pin that can slot into a {{snap_pin_socket()}} to join two parts.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: snap_pin_socket(), joiner(), dovetail(), snap_pin(), rabbit_clip()
|
// See Also: snap_pin_socket(), joiner(), dovetail(), snap_pin(), rabbit_clip()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -892,6 +899,7 @@ module snap_pin(size,r,radius,d,diameter, l,length, nub_depth, snap, thickness,
|
||||||
|
|
||||||
// Module: snap_pin_socket()
|
// Module: snap_pin_socket()
|
||||||
// Synopsis: Creates a snap-pin socket for a {{snap_pin()}} to slot into.
|
// Synopsis: Creates a snap-pin socket for a {{snap_pin()}} to slot into.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: snap_pin(), joiner(), dovetail(), snap_pin(), rabbit_clip()
|
// See Also: snap_pin(), joiner(), dovetail(), snap_pin(), rabbit_clip()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -965,6 +973,7 @@ module snap_pin_socket(size, r, radius, l,length, d,diameter,nub_depth, snap, fi
|
||||||
|
|
||||||
// Module: rabbit_clip()
|
// Module: rabbit_clip()
|
||||||
// Synopsis: Creates a rabbit-eared clip that can snap into a slot.
|
// Synopsis: Creates a rabbit-eared clip that can snap into a slot.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Joiners, Parts
|
// Topics: Joiners, Parts
|
||||||
// See Also: snap_pin(), joiner(), dovetail(), snap_pin(), rabbit_clip()
|
// See Also: snap_pin(), joiner(), dovetail(), snap_pin(), rabbit_clip()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
142
linalg.scad
142
linalg.scad
|
@ -31,10 +31,11 @@
|
||||||
// Section: Matrix testing and display
|
// Section: Matrix testing and display
|
||||||
|
|
||||||
// Function: is_matrix()
|
// Function: is_matrix()
|
||||||
|
// Synopsis: Check if input is a numeric matrix, optionally of specified size
|
||||||
|
// Topics: Matrices
|
||||||
|
// See Also: is_matrix_symmetric(), is_rotation()
|
||||||
// Usage:
|
// Usage:
|
||||||
// test = is_matrix(A, [m], [n], [square])
|
// test = is_matrix(A, [m], [n], [square])
|
||||||
// Topics: Matrices
|
|
||||||
// Synopsis: Check if input is a numeric matrix, optionally of specified size
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns true if A is a numeric matrix of height m and width n with finite entries. If m or n
|
// Returns true if A is a numeric matrix of height m and width n with finite entries. If m or n
|
||||||
// are omitted or set to undef then true is returned for any positive dimension.
|
// are omitted or set to undef then true is returned for any positive dimension.
|
||||||
|
@ -52,13 +53,14 @@ function is_matrix(A,m,n,square=false) =
|
||||||
|
|
||||||
|
|
||||||
// Function: is_matrix_symmetric()
|
// Function: is_matrix_symmetric()
|
||||||
|
// Synopsis: Checks if matrix is symmetric
|
||||||
|
// Topics: Matrices
|
||||||
|
// See Also: is_matrix(), is_rotation()
|
||||||
// Usage:
|
// Usage:
|
||||||
// b = is_matrix_symmetric(A, [eps])
|
// b = is_matrix_symmetric(A, [eps])
|
||||||
// Topics: Matrices
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns true if the input matrix is symmetric, meaning it approximately equals its transpose.
|
// Returns true if the input matrix is symmetric, meaning it approximately equals its transpose.
|
||||||
// The matrix can have arbitrary entries.
|
// The matrix can have arbitrary entries.
|
||||||
// Synopsis: Checks if matrix is symmetric
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// A = matrix to test
|
// A = matrix to test
|
||||||
// eps = epsilon for comparing equality. Default: 1e-12
|
// eps = epsilon for comparing equality. Default: 1e-12
|
||||||
|
@ -67,15 +69,16 @@ function is_matrix_symmetric(A,eps=1e-12) =
|
||||||
|
|
||||||
|
|
||||||
// Function: is_rotation()
|
// Function: is_rotation()
|
||||||
|
// Synopsis: Check if a transformation matrix represents a rotation.
|
||||||
|
// Topics: Affine, Matrices, Transforms
|
||||||
|
// See Also: is_matrix(), is_matrix_symmetric(), is_rotation()
|
||||||
// Usage:
|
// Usage:
|
||||||
// b = is_rotation(A, [dim], [centered])
|
// b = is_rotation(A, [dim], [centered])
|
||||||
// Topics: Affine, Matrices, Transforms
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns true if the input matrix is a square affine matrix that is a rotation around any point,
|
// Returns true if the input matrix is a square affine matrix that is a rotation around any point,
|
||||||
// or around the origin if `centered` is true.
|
// or around the origin if `centered` is true.
|
||||||
// The matrix must be 3x3 (representing a 2d transformation) or 4x4 (representing a 3d transformation).
|
// The matrix must be 3x3 (representing a 2d transformation) or 4x4 (representing a 3d transformation).
|
||||||
// You can set `dim` to 2 to require a 2d transform (3x3 matrix) or to 3 to require a 3d transform (4x4 matrix).
|
// You can set `dim` to 2 to require a 2d transform (3x3 matrix) or to 3 to require a 3d transform (4x4 matrix).
|
||||||
// Synopsis: Check if a transformation matrix represents a rotation.
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// A = matrix to test
|
// A = matrix to test
|
||||||
// dim = if set, specify dimension in which the transform operates (2 or 3)
|
// dim = if set, specify dimension in which the transform operates (2 or 3)
|
||||||
|
@ -96,11 +99,12 @@ function is_rotation(A,dim,centered=false) =
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: echo_matrix()
|
// Function&Module: echo_matrix()
|
||||||
|
// Synopsis: Print a matrix neatly to the console.
|
||||||
|
// Topics: Matrices
|
||||||
|
// See Also: is_matrix(), is_matrix_symmetric(), is_rotation()
|
||||||
// Usage:
|
// Usage:
|
||||||
// echo_matrix(M, [description], [sig], [sep], [eps]);
|
// echo_matrix(M, [description], [sig], [sep], [eps]);
|
||||||
// dummy = echo_matrix(M, [description], [sig], [sep], [eps]),
|
// dummy = echo_matrix(M, [description], [sig], [sep], [eps]),
|
||||||
// Topics: Matrices
|
|
||||||
// Synopsis: Print a matrix neatly to the console.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Display a numerical matrix in a readable columnar format with `sig` significant
|
// Display a numerical matrix in a readable columnar format with `sig` significant
|
||||||
// digits. Values smaller than eps display as zero. If you give a description
|
// digits. Values smaller than eps display as zero. If you give a description
|
||||||
|
@ -135,14 +139,14 @@ module echo_matrix(M,description,sig=4,sep=1,eps=1e-9)
|
||||||
// Section: Matrix indexing
|
// Section: Matrix indexing
|
||||||
|
|
||||||
// Function: column()
|
// Function: column()
|
||||||
// Usage:
|
// Synopsis: Extract a column from a matrix.
|
||||||
// list = column(M, i);
|
|
||||||
// Topics: Matrices, List Handling, Arrays
|
// Topics: Matrices, List Handling, Arrays
|
||||||
// See Also: select(), slice()
|
// See Also: select(), slice()
|
||||||
|
// Usage:
|
||||||
|
// list = column(M, i);
|
||||||
// Description:
|
// Description:
|
||||||
// Extracts entry `i` from each list in M, or equivalently column i from the matrix M, and returns it as a vector.
|
// Extracts entry `i` from each list in M, or equivalently column i from the matrix M, and returns it as a vector.
|
||||||
// This function will return `undef` at all entry positions indexed by i not found in M.
|
// This function will return `undef` at all entry positions indexed by i not found in M.
|
||||||
// Synopsis: Extract a column from a matrix.
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// M = The given list of lists.
|
// M = The given list of lists.
|
||||||
// i = The index to fetch
|
// i = The index to fetch
|
||||||
|
@ -162,11 +166,11 @@ function column(M, i) =
|
||||||
|
|
||||||
|
|
||||||
// Function: submatrix()
|
// Function: submatrix()
|
||||||
// Usage:
|
// Synopsis: Extract a submatrix from a matrix
|
||||||
// mat = submatrix(M, idx1, idx2);
|
|
||||||
// Topics: Matrices, Arrays
|
// Topics: Matrices, Arrays
|
||||||
// See Also: column(), block_matrix(), submatrix_set()
|
// See Also: column(), block_matrix(), submatrix_set()
|
||||||
// Synopsis: Extract a submatrix from a matrix
|
// Usage:
|
||||||
|
// mat = submatrix(M, idx1, idx2);
|
||||||
// Description:
|
// Description:
|
||||||
// The input must be a list of lists (a matrix or 2d array). Returns a submatrix by selecting the rows listed in idx1 and columns listed in idx2.
|
// The input must be a list of lists (a matrix or 2d array). Returns a submatrix by selecting the rows listed in idx1 and columns listed in idx2.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -196,12 +200,13 @@ function submatrix(M,idx1,idx2) =
|
||||||
// Section: Matrix construction and modification
|
// Section: Matrix construction and modification
|
||||||
|
|
||||||
// Function: ident()
|
// Function: ident()
|
||||||
|
// Synopsis: Return identity matrix.
|
||||||
|
// Topics: Affine, Matrices, Transforms
|
||||||
|
// See Also: IDENT, submatrix(), column()
|
||||||
// Usage:
|
// Usage:
|
||||||
// mat = ident(n);
|
// mat = ident(n);
|
||||||
// Topics: Affine, Matrices, Transforms
|
|
||||||
// Description:
|
// Description:
|
||||||
// Create an `n` by `n` square identity matrix.
|
// Create an `n` by `n` square identity matrix.
|
||||||
// Synopsis: Return 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`.
|
||||||
// Example:
|
// Example:
|
||||||
|
@ -229,15 +234,15 @@ function ident(n) = [
|
||||||
|
|
||||||
|
|
||||||
// Function: diagonal_matrix()
|
// Function: diagonal_matrix()
|
||||||
// Usage:
|
// Synopsis: Make a diagonal matrix.
|
||||||
// mat = diagonal_matrix(diag, [offdiag]);
|
|
||||||
// Topics: Affine, Matrices
|
// Topics: Affine, Matrices
|
||||||
// See Also: column(), submatrix()
|
// See Also: column(), submatrix()
|
||||||
|
// Usage:
|
||||||
|
// mat = diagonal_matrix(diag, [offdiag]);
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a square matrix with the items in the list `diag` on
|
// Creates a square matrix with the items in the list `diag` on
|
||||||
// its diagonal. The off diagonal entries are set to offdiag,
|
// its diagonal. The off diagonal entries are set to offdiag,
|
||||||
// which is zero by default.
|
// which is zero by default.
|
||||||
// Synopsis: Make a diagonal matrix.
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// diag = A list of items to put in the diagnal cells of the matrix.
|
// diag = A list of items to put in the diagnal cells of the matrix.
|
||||||
// offdiag = Value to put in non-diagonal matrix cells.
|
// offdiag = Value to put in non-diagonal matrix cells.
|
||||||
|
@ -247,11 +252,11 @@ function diagonal_matrix(diag, offdiag=0) =
|
||||||
|
|
||||||
|
|
||||||
// Function: transpose()
|
// Function: transpose()
|
||||||
|
// Synopsis: Transpose a matrix
|
||||||
|
// Topics: Linear Algebra, Matrices
|
||||||
|
// See Also: submatrix(), block_matrix(), hstack(), flatten()
|
||||||
// Usage:
|
// Usage:
|
||||||
// M = transpose(M, [reverse]);
|
// M = transpose(M, [reverse]);
|
||||||
// Topics: Linear Algebra, Matrices
|
|
||||||
// Synopsis: Transpose a matrix
|
|
||||||
// See Also: submatrix(), block_matrix(), hstack(), flatten()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the transpose of the given input matrix. The input can be a matrix with arbitrary entries or
|
// Returns the transpose of the given input matrix. The input can be a matrix with arbitrary entries or
|
||||||
// a numerical vector. If you give a vector then transpose returns it unchanged.
|
// a numerical vector. If you give a vector then transpose returns it unchanged.
|
||||||
|
@ -326,10 +331,11 @@ function transpose(M, reverse=false) =
|
||||||
|
|
||||||
|
|
||||||
// Function: outer_product()
|
// Function: outer_product()
|
||||||
|
// Synopsis: Compute the outer product of two vectors.
|
||||||
|
// Topics: Linear Algebra, Matrices
|
||||||
|
// See Also: submatrix(), determinant()
|
||||||
// Usage:
|
// Usage:
|
||||||
// x = outer_product(u,v);
|
// x = outer_product(u,v);
|
||||||
// Topics: Linear Algebra, Matrices
|
|
||||||
// Synopsis: Compute the outer product of two vectors.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Compute the outer product of two vectors, which is a matrix.
|
// Compute the outer product of two vectors, which is a matrix.
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -339,11 +345,11 @@ function outer_product(u,v) =
|
||||||
[for(ui=u) ui*v];
|
[for(ui=u) ui*v];
|
||||||
|
|
||||||
// Function: submatrix_set()
|
// Function: submatrix_set()
|
||||||
// Usage:
|
// Synopsis: Takes a matrix as input and change values in a submatrix.
|
||||||
// mat = submatrix_set(M, A, [m], [n]);
|
|
||||||
// Topics: Matrices, Arrays
|
// Topics: Matrices, Arrays
|
||||||
// See Also: column(), submatrix()
|
// See Also: column(), submatrix()
|
||||||
// Synopsis: Takes a matrix as input and change values in a submatrix.
|
// Usage:
|
||||||
|
// mat = submatrix_set(M, A, [m], [n]);
|
||||||
// Description:
|
// Description:
|
||||||
// Sets a submatrix of M equal to the matrix A. By default the top left corner of M is set to A, but
|
// Sets a submatrix of M equal to the matrix A. By default the top left corner of M is set to A, but
|
||||||
// you can specify offset coordinates m and n. If A (as adjusted by m and n) extends beyond the bounds
|
// you can specify offset coordinates m and n. If A (as adjusted by m and n) extends beyond the bounds
|
||||||
|
@ -368,13 +374,13 @@ function submatrix_set(M,A,m=0,n=0) =
|
||||||
|
|
||||||
|
|
||||||
// Function: hstack()
|
// Function: hstack()
|
||||||
|
// Synopsis: Make a new matrix by stacking matrices horizontally.
|
||||||
|
// Topics: Matrices, Arrays
|
||||||
|
// See Also: column(), submatrix(), block_matrix()
|
||||||
// Usage:
|
// Usage:
|
||||||
// A = hstack(M1, M2)
|
// A = hstack(M1, M2)
|
||||||
// A = hstack(M1, M2, M3)
|
// A = hstack(M1, M2, M3)
|
||||||
// A = hstack([M1, M2, M3, ...])
|
// A = hstack([M1, M2, M3, ...])
|
||||||
// Synopsis: Make a new matrix by stacking matrices horizontally.
|
|
||||||
// Topics: Matrices, Arrays
|
|
||||||
// See Also: column(), submatrix(), block_matrix()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Constructs a matrix by horizontally "stacking" together compatible matrices or vectors. Vectors are treated as columsn in the stack.
|
// Constructs a matrix by horizontally "stacking" together compatible matrices or vectors. Vectors are treated as columsn in the stack.
|
||||||
// This command is the inverse of `column`. Note: strings given in vectors are broken apart into lists of characters. Strings given
|
// This command is the inverse of `column`. Note: strings given in vectors are broken apart into lists of characters. Strings given
|
||||||
|
@ -423,11 +429,11 @@ function hstack(M1, M2, M3) =
|
||||||
|
|
||||||
|
|
||||||
// Function: block_matrix()
|
// Function: block_matrix()
|
||||||
// Usage:
|
// Synopsis: Make a new matrix from a block of matrices.
|
||||||
// bmat = block_matrix([[M11, M12,...],[M21, M22,...], ... ]);
|
|
||||||
// Topics: Matrices, Arrays
|
// Topics: Matrices, Arrays
|
||||||
// See Also: column(), submatrix()
|
// See Also: column(), submatrix()
|
||||||
// Synopsis: Make a new matrix from a block of matrices.
|
// Usage:
|
||||||
|
// bmat = block_matrix([[M11, M12,...],[M21, M22,...], ... ]);
|
||||||
// Description:
|
// Description:
|
||||||
// Create a block matrix by supplying a matrix of matrices, which will
|
// Create a block matrix by supplying a matrix of matrices, which will
|
||||||
// be combined into one unified matrix. Every matrix in one row
|
// be combined into one unified matrix. Every matrix in one row
|
||||||
|
@ -471,10 +477,11 @@ function block_matrix(M) =
|
||||||
// Section: Solving Linear Equations and Matrix Factorizations
|
// Section: Solving Linear Equations and Matrix Factorizations
|
||||||
|
|
||||||
// Function: linear_solve()
|
// Function: linear_solve()
|
||||||
|
// Synopsis: Solve Ax=b or, for overdetermined case, solve the least square problem.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// solv = linear_solve(A,b,[pivot])
|
// solv = linear_solve(A,b,[pivot])
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Solve Ax=b or, for overdetermined case, solve the least square problem.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Solves the linear system Ax=b. If `A` is square and non-singular the unique solution is returned. If `A` is overdetermined
|
// Solves the linear system Ax=b. If `A` is square and non-singular the unique solution is returned. If `A` is overdetermined
|
||||||
// the least squares solution is returned. If `A` is underdetermined, the minimal norm solution is returned.
|
// the least squares solution is returned. If `A` is underdetermined, the minimal norm solution is returned.
|
||||||
|
@ -509,10 +516,11 @@ function linear_solve(A,b,pivot=true) =
|
||||||
|
|
||||||
|
|
||||||
// Function: linear_solve3()
|
// Function: linear_solve3()
|
||||||
|
// Synopsis: Fast solution to Ax=b where A is 3x3.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// x = linear_solve3(A,b)
|
// x = linear_solve3(A,b)
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Fast solution to Ax=b where A is 3x3.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Fast solution to a 3x3 linear system using Cramer's rule (which appears to be the fastest
|
// Fast solution to a 3x3 linear system using Cramer's rule (which appears to be the fastest
|
||||||
// method in OpenSCAD). The input `A` must be a 3x3 matrix. Returns undef if `A` is singular.
|
// method in OpenSCAD). The input `A` must be a 3x3 matrix. Returns undef if `A` is singular.
|
||||||
|
@ -535,10 +543,11 @@ function linear_solve3(A,b) =
|
||||||
|
|
||||||
|
|
||||||
// Function: matrix_inverse()
|
// Function: matrix_inverse()
|
||||||
|
// Synopsis: General matrix inverse.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve(), linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// mat = matrix_inverse(A)
|
// mat = matrix_inverse(A)
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: General matrix inverse.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Compute the matrix inverse of the square matrix `A`. If `A` is singular, returns `undef`.
|
// Compute the matrix inverse of the square matrix `A`. If `A` is singular, returns `undef`.
|
||||||
// Note that if you just want to solve a linear system of equations you should NOT use this function.
|
// Note that if you just want to solve a linear system of equations you should NOT use this function.
|
||||||
|
@ -550,10 +559,11 @@ function matrix_inverse(A) =
|
||||||
|
|
||||||
|
|
||||||
// Function: rot_inverse()
|
// Function: rot_inverse()
|
||||||
// Usage:
|
|
||||||
// B = rot_inverse(A)
|
|
||||||
// Synopsis: Invert 2d or 3d rotation transformations.
|
// Synopsis: Invert 2d or 3d rotation transformations.
|
||||||
// Topics: Matrices, Linear Algebra, Affine
|
// Topics: Matrices, Linear Algebra, Affine
|
||||||
|
// See Also: linear_solve(), linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
|
// Usage:
|
||||||
|
// B = rot_inverse(A)
|
||||||
// Description:
|
// Description:
|
||||||
// Inverts a 2d (3x3) or 3d (4x4) rotation matrix. The matrix can be a rotation around any center,
|
// Inverts a 2d (3x3) or 3d (4x4) rotation matrix. The matrix can be a rotation around any center,
|
||||||
// so it may include a translation. This is faster and likely to be more accurate than using `matrix_inverse()`.
|
// so it may include a translation. This is faster and likely to be more accurate than using `matrix_inverse()`.
|
||||||
|
@ -572,10 +582,11 @@ function rot_inverse(T) =
|
||||||
|
|
||||||
|
|
||||||
// Function: null_space()
|
// Function: null_space()
|
||||||
|
// Synopsis: Return basis for the null space of A.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve(), linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// x = null_space(A)
|
// x = null_space(A)
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Return basis for the null space of A.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns an orthonormal basis for the null space of `A`, namely the vectors {x} such that Ax=0.
|
// Returns an orthonormal basis for the null space of `A`, namely the vectors {x} such that Ax=0.
|
||||||
// If the null space is just the origin then returns an empty list.
|
// If the null space is just the origin then returns an empty list.
|
||||||
|
@ -590,10 +601,11 @@ function null_space(A,eps=1e-12) =
|
||||||
select(transpose(Q_R[0]), zrows);
|
select(transpose(Q_R[0]), zrows);
|
||||||
|
|
||||||
// Function: qr_factor()
|
// Function: qr_factor()
|
||||||
|
// Synopsis: Compute QR factorization of a matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve(), linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// qr = qr_factor(A,[pivot]);
|
// qr = qr_factor(A,[pivot]);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute QR factorization of a matrix.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Calculates the QR factorization of the input matrix A and returns it as the list [Q,R,P]. This factorization can be
|
// Calculates the QR factorization of the input matrix A and returns it as the list [Q,R,P]. This factorization can be
|
||||||
// used to solve linear systems of equations. The factorization is `A = Q*R*transpose(P)`. If pivot is false (the default)
|
// used to solve linear systems of equations. The factorization is `A = Q*R*transpose(P)`. If pivot is false (the default)
|
||||||
|
@ -642,10 +654,11 @@ function _swap_matrix(n,i,j) =
|
||||||
|
|
||||||
|
|
||||||
// Function: back_substitute()
|
// Function: back_substitute()
|
||||||
|
// Synopsis: Solve an upper triangular system, Rx=b.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve(), linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// x = back_substitute(R, b, [transpose]);
|
// x = back_substitute(R, b, [transpose]);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Solve an upper triangular system, Rx=b.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Solves the problem Rx=b where R is an upper triangular square matrix. The lower triangular entries of R are
|
// Solves the problem Rx=b where R is an upper triangular square matrix. The lower triangular entries of R are
|
||||||
// ignored. If transpose==true then instead solve transpose(R)*x=b.
|
// ignored. If transpose==true then instead solve transpose(R)*x=b.
|
||||||
|
@ -675,10 +688,11 @@ function _back_substitute(R, b, x=[]) =
|
||||||
|
|
||||||
|
|
||||||
// Function: cholesky()
|
// Function: cholesky()
|
||||||
|
// Synopsis: Compute the Cholesky factorization of a matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: linear_solve(), linear_solve3(), matrix_inverse(), rot_inverse(), back_substitute(), cholesky()
|
||||||
// Usage:
|
// Usage:
|
||||||
// L = cholesky(A);
|
// L = cholesky(A);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute the Cholesky factorization of a matrix.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Compute the cholesky factor, L, of the symmetric positive definite matrix A.
|
// Compute the cholesky factor, L, of the symmetric positive definite matrix A.
|
||||||
// The matrix L is lower triangular and `L * transpose(L) = A`. If the A is
|
// The matrix L is lower triangular and `L * transpose(L) = A`. If the A is
|
||||||
|
@ -712,10 +726,11 @@ function _cholesky(A,L,n) =
|
||||||
// Section: Matrix Properties: Determinants, Norm, Trace
|
// Section: Matrix Properties: Determinants, Norm, Trace
|
||||||
|
|
||||||
// Function: det2()
|
// Function: det2()
|
||||||
|
// Synopsis: Compute determinant of 2x2 matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: det2(), det3(), det4(), determinant(), norm_fro(), matrix_trace()
|
||||||
// Usage:
|
// Usage:
|
||||||
// d = det2(M);
|
// d = det2(M);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute determinant of 2x2 matrix.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Rturns the determinant for the given 2x2 matrix.
|
// Rturns the determinant for the given 2x2 matrix.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -729,10 +744,11 @@ function det2(M) =
|
||||||
|
|
||||||
|
|
||||||
// Function: det3()
|
// Function: det3()
|
||||||
|
// Synopsis: Compute determinant of 3x3 matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: det2(), det3(), det4(), determinant(), norm_fro(), matrix_trace()
|
||||||
// Usage:
|
// Usage:
|
||||||
// d = det3(M);
|
// d = det3(M);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute determinant of 3x3 matrix.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the determinant for the given 3x3 matrix.
|
// Returns the determinant for the given 3x3 matrix.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -747,10 +763,11 @@ function det3(M) =
|
||||||
M[2][0] * (M[0][1]*M[1][2]-M[1][1]*M[0][2]);
|
M[2][0] * (M[0][1]*M[1][2]-M[1][1]*M[0][2]);
|
||||||
|
|
||||||
// Function: det4()
|
// Function: det4()
|
||||||
|
// Synopsis: Compute determinant of 4x4 matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: det2(), det3(), det4(), determinant(), norm_fro(), matrix_trace()
|
||||||
// Usage:
|
// Usage:
|
||||||
// d = det4(M);
|
// d = det4(M);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute determinant of 4x4 matrix.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the determinant for the given 4x4 matrix.
|
// Returns the determinant for the given 4x4 matrix.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -770,12 +787,13 @@ function det4(M) =
|
||||||
- M[0][3]*M[1][0]*M[2][1]*M[3][2] - M[0][3]*M[1][1]*M[2][2]*M[3][0] - M[0][3]*M[1][2]*M[2][0]*M[3][1];
|
- M[0][3]*M[1][0]*M[2][1]*M[3][2] - M[0][3]*M[1][1]*M[2][2]*M[3][0] - M[0][3]*M[1][2]*M[2][0]*M[3][1];
|
||||||
|
|
||||||
// Function: determinant()
|
// Function: determinant()
|
||||||
|
// Synopsis: compute determinant of an arbitrary square matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: det2(), det3(), det4(), determinant(), norm_fro(), matrix_trace()
|
||||||
// Usage:
|
// Usage:
|
||||||
// d = determinant(M);
|
// d = determinant(M);
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Description:
|
// Description:
|
||||||
// Returns the determinant for the given square matrix.
|
// Returns the determinant for the given square matrix.
|
||||||
// Synopsis: compute determinant of an arbitrary square matrix.
|
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// M = The NxN square matrix to get the determinant of.
|
// M = The NxN square matrix to get the determinant of.
|
||||||
// Example:
|
// Example:
|
||||||
|
@ -804,10 +822,11 @@ function determinant(M) =
|
||||||
|
|
||||||
|
|
||||||
// Function: norm_fro()
|
// Function: norm_fro()
|
||||||
|
// Synopsis: Compute Frobenius norm of a matrix
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: det2(), det3(), det4(), determinant(), norm_fro(), matrix_trace()
|
||||||
// Usage:
|
// Usage:
|
||||||
// norm_fro(A)
|
// norm_fro(A)
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute Frobenius norm of a matrix
|
|
||||||
// Description:
|
// Description:
|
||||||
// Computes frobenius norm of input matrix. The frobenius norm is the square root of the sum of the
|
// Computes frobenius norm of input matrix. The frobenius norm is the square root of the sum of the
|
||||||
// squares of all of the entries of the matrix. On vectors it is the same as the usual 2-norm.
|
// squares of all of the entries of the matrix. On vectors it is the same as the usual 2-norm.
|
||||||
|
@ -818,10 +837,11 @@ function norm_fro(A) =
|
||||||
|
|
||||||
|
|
||||||
// Function: matrix_trace()
|
// Function: matrix_trace()
|
||||||
|
// Synopsis: Compute the trace of a square matrix.
|
||||||
|
// Topics: Matrices, Linear Algebra
|
||||||
|
// See Also: det2(), det3(), det4(), determinant(), norm_fro(), matrix_trace()
|
||||||
// Usage:
|
// Usage:
|
||||||
// matrix_trace(M)
|
// matrix_trace(M)
|
||||||
// Topics: Matrices, Linear Algebra
|
|
||||||
// Synopsis: Compute the trace of a square matrix.
|
|
||||||
// Description:
|
// Description:
|
||||||
// Computes the trace of a square matrix, the sum of the entries on the diagonal.
|
// Computes the trace of a square matrix, the sum of the entries on the diagonal.
|
||||||
function matrix_trace(M) =
|
function matrix_trace(M) =
|
||||||
|
|
|
@ -16,6 +16,7 @@ include <metric_screws.scad>
|
||||||
|
|
||||||
// Module: linear_bearing_housing()
|
// Module: linear_bearing_housing()
|
||||||
// Synopsis: Creates a generic linear bearing mount clamp.
|
// Synopsis: Creates a generic linear bearing mount clamp.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Bearings
|
// Topics: Parts, Bearings
|
||||||
// See Also: linear_bearing(), lmXuu_info(), ball_bearing()
|
// See Also: linear_bearing(), lmXuu_info(), ball_bearing()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -82,6 +83,7 @@ module linear_bearing_housing(d=15, l=24, tab=7, gap=5, wall=3, tabwall=5, screw
|
||||||
|
|
||||||
// Module: linear_bearing()
|
// Module: linear_bearing()
|
||||||
// Synopsis: Creates a generic linear bearing cartridge.
|
// Synopsis: Creates a generic linear bearing cartridge.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Bearings
|
// Topics: Parts, Bearings
|
||||||
// See Also: linear_bearing_housing(), lmXuu_info(), ball_bearing()
|
// See Also: linear_bearing_housing(), lmXuu_info(), ball_bearing()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -116,6 +118,7 @@ module linear_bearing(l, od=15, id=8, length, anchor=CTR, spin=0, orient=UP) {
|
||||||
|
|
||||||
// Module: lmXuu_housing()
|
// Module: lmXuu_housing()
|
||||||
// Synopsis: Creates a standardized LM*UU linear bearing mount clamp.
|
// Synopsis: Creates a standardized LM*UU linear bearing mount clamp.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Bearings
|
// Topics: Parts, Bearings
|
||||||
// See Also: linear_bearing(), linear_bearing_housing(), lmXuu_info(), lmXuu_bearing(), lmXuu_housing(), ball_bearing()
|
// See Also: linear_bearing(), linear_bearing_housing(), lmXuu_info(), lmXuu_bearing(), lmXuu_housing(), ball_bearing()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -146,6 +149,7 @@ module lmXuu_housing(size=8, tab=7, gap=5, wall=3, tabwall=5, screwsize=3, ancho
|
||||||
|
|
||||||
// Module: lmXuu_bearing()
|
// Module: lmXuu_bearing()
|
||||||
// Synopsis: Creates a standardized LM*UU linear bearing cartridge.
|
// Synopsis: Creates a standardized LM*UU linear bearing cartridge.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Bearings
|
// Topics: Parts, Bearings
|
||||||
// See Also: linear_bearing(), linear_bearing_housing(), lmXuu_info(), lmXuu_bearing(), lmXuu_housing(), ball_bearing()
|
// See Also: linear_bearing(), linear_bearing_housing(), lmXuu_info(), lmXuu_bearing(), lmXuu_housing(), ball_bearing()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -268,6 +268,7 @@ function slice(list,start=0,end=-1) =
|
||||||
)
|
)
|
||||||
[if (start<=end && end>=0 && start<=l) for (i=[max(start,0):1:min(end,l-1)]) list[i]];
|
[if (start<=end && end>=0 && start<=l) for (i=[max(start,0):1:min(end,l-1)]) list[i]];
|
||||||
|
|
||||||
|
|
||||||
// Function: last()
|
// Function: last()
|
||||||
// Synopsis: Returns the last item of a list.
|
// Synopsis: Returns the last item of a list.
|
||||||
// Topics: List Handling
|
// Topics: List Handling
|
||||||
|
|
13
masks3d.scad
13
masks3d.scad
|
@ -17,7 +17,7 @@
|
||||||
// Synopsis: Creates a shape to chamfer a 90° edge.
|
// Synopsis: Creates a shape to chamfer a 90° edge.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Chamfers, Shapes (3D)
|
// Topics: Masking, Chamfers, Shapes (3D)
|
||||||
// See Also: chamfer_corner_mask()
|
// See Also: chamfer_corner_mask(), chamfer_cylinder_mask(), chamfer_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// chamfer_edge_mask(l|h=|length=|height=, chamfer, [excess]) [ATTACHMENTS];
|
// chamfer_edge_mask(l|h=|length=|height=, chamfer, [excess]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -59,7 +59,7 @@ module chamfer_edge_mask(l, chamfer=1, excess=0.1, h, length, height, anchor=CEN
|
||||||
// Synopsis: Creates a shape to chamfer a 90° corner.
|
// Synopsis: Creates a shape to chamfer a 90° corner.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Chamfers, Shapes (3D)
|
// Topics: Masking, Chamfers, Shapes (3D)
|
||||||
// See Also: chamfer_edge_mask()
|
// See Also: chamfer_corner_mask(), chamfer_cylinder_mask(), chamfer_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// chamfer_corner_mask(chamfer) [ATTACHMENTS];
|
// chamfer_corner_mask(chamfer) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -98,6 +98,7 @@ module chamfer_corner_mask(chamfer=1, anchor=CENTER, spin=0, orient=UP) {
|
||||||
// Synopsis: Creates a shape to chamfer the end of a cylinder.
|
// Synopsis: Creates a shape to chamfer the end of a cylinder.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Chamfers, Cylinders
|
// Topics: Masking, Chamfers, Cylinders
|
||||||
|
// See Also: chamfer_corner_mask(), chamfer_cylinder_mask(), chamfer_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// chamfer_cylinder_mask(r|d=, chamfer, [ang], [from_end]) [ATTACHMENTS];
|
// chamfer_cylinder_mask(r|d=, chamfer, [ang], [from_end]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -419,7 +420,7 @@ module rounding_angled_corner_mask(r, ang=90, d, anchor=CENTER, spin=0, orient=U
|
||||||
// Synopsis: Creates a shape to round the end of a cylinder.
|
// Synopsis: Creates a shape to round the end of a cylinder.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Rounding, Cylinders
|
// Topics: Masking, Rounding, Cylinders
|
||||||
// See Also: rounding_hole_mask()
|
// See Also: rounding_hole_mask(), rounding_angled_edge_mask(), rounding_corner_mask(), rounding_angled_corner_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// rounding_cylinder_mask(r|d=, rounding);
|
// rounding_cylinder_mask(r|d=, rounding);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -471,7 +472,7 @@ module rounding_cylinder_mask(r, rounding, d, anchor=CENTER, spin=0, orient=UP)
|
||||||
// Synopsis: Creates a shape to round the edge of a round hole.
|
// Synopsis: Creates a shape to round the edge of a round hole.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Rounding
|
// Topics: Masking, Rounding
|
||||||
// See Also: rounding_cylinder_mask()
|
// See Also: rounding_cylinder_mask(), rounding_hole_mask(), rounding_angled_edge_mask(), rounding_corner_mask(), rounding_angled_corner_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// rounding_hole_mask(r|d, rounding, [excess]) [ATTACHMENTS];
|
// rounding_hole_mask(r|d, rounding, [excess]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -524,7 +525,7 @@ module rounding_hole_mask(r, rounding, excess=0.1, d, anchor=CENTER, spin=0, ori
|
||||||
// Synopsis: Creates a shape to round a 90° edge but limit the angle of overhang.
|
// Synopsis: Creates a shape to round a 90° edge but limit the angle of overhang.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Rounding, Shapes (3D), FDM Optimized
|
// Topics: Masking, Rounding, Shapes (3D), FDM Optimized
|
||||||
// See Also: teardrop_corner_mask()
|
// See Also: teardrop_corner_mask(), teardrop_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// teardrop_edge_mask(l|h=|length=|height=, r|d=, [angle], [excess], [anchor], [spin], [orient]) [ATTACHMENTS];
|
// teardrop_edge_mask(l|h=|length=|height=, r|d=, [angle], [excess], [anchor], [spin], [orient]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -567,7 +568,7 @@ module teardrop_edge_mask(l, r, angle=45, excess=0.1, d, anchor=CTR, spin=0, ori
|
||||||
// Synopsis: Creates a shape to round a 90° corner but limit the angle of overhang.
|
// Synopsis: Creates a shape to round a 90° corner but limit the angle of overhang.
|
||||||
// SynTags: Geom
|
// SynTags: Geom
|
||||||
// Topics: Masking, Rounding, Shapes (3D), FDM Optimized
|
// Topics: Masking, Rounding, Shapes (3D), FDM Optimized
|
||||||
// See Also: teardrop_edge_mask()
|
// See Also: teardrop_corner_mask(), teardrop_edge_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
// teardrop_corner_mask(r|d=, [angle], [excess], [anchor], [spin], [orient]) [ATTACHMENTS];
|
// teardrop_corner_mask(r|d=, [angle], [excess], [anchor], [spin], [orient]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
// Section: Modular Hose Parts
|
// Section: Modular Hose Parts
|
||||||
|
|
||||||
_small_end = [
|
_modhose_small_end = [
|
||||||
turtle([
|
turtle([
|
||||||
"left", 90-38.5, // 1/4" hose
|
"left", 90-38.5, // 1/4" hose
|
||||||
"arcsteps", 12,
|
"arcsteps", 12,
|
||||||
|
@ -57,7 +57,7 @@ _small_end = [
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
_big_end = [
|
_modhose_big_end = [
|
||||||
turtle([ // 1/4" hose
|
turtle([ // 1/4" hose
|
||||||
"left", 90-22,
|
"left", 90-22,
|
||||||
"move", 6.5,
|
"move", 6.5,
|
||||||
|
@ -116,7 +116,7 @@ _big_end = [
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
_hose_waist = [1.7698, 1.8251, 3.95998];
|
_modhose_waist = [1.7698, 1.8251, 3.95998];
|
||||||
|
|
||||||
|
|
||||||
// Module: modular_hose()
|
// Module: modular_hose()
|
||||||
|
@ -159,14 +159,14 @@ module modular_hose(size, type, clearance=0, waist_len, anchor=BOTTOM, spin=0,or
|
||||||
ind = search([size],[1/4, 1/2, 3/4])[0];
|
ind = search([size],[1/4, 1/2, 3/4])[0];
|
||||||
sbound =
|
sbound =
|
||||||
assert(ind!=[], "Must specify size as 1/4, 1/2 or 3/4")
|
assert(ind!=[], "Must specify size as 1/4, 1/2 or 3/4")
|
||||||
pointlist_bounds(_small_end[ind]);
|
pointlist_bounds(_modhose_small_end[ind]);
|
||||||
bbound = pointlist_bounds(_big_end[ind]);
|
bbound = pointlist_bounds(_modhose_big_end[ind]);
|
||||||
smallend =
|
smallend =
|
||||||
assert(is_vector(clearance,2), "Clearance must be a scalar or length 2 vector")
|
assert(is_vector(clearance,2), "Clearance must be a scalar or length 2 vector")
|
||||||
move([-clearance[0],-sbound[0].y],p=_small_end[ind]);
|
move([-clearance[0],-sbound[0].y],p=_modhose_small_end[ind]);
|
||||||
bigend = move([clearance[1], -bbound[0].y], p=_big_end[ind]);
|
bigend = move([clearance[1], -bbound[0].y], p=_modhose_big_end[ind]);
|
||||||
|
|
||||||
midlength = first_defined([waist_len, _hose_waist[ind]]);
|
midlength = first_defined([waist_len, _modhose_waist[ind]]);
|
||||||
dummy = assert(midlength>=0,"midlength must be nonnegative");
|
dummy = assert(midlength>=0,"midlength must be nonnegative");
|
||||||
|
|
||||||
goodtypes = ["small","big","segment","socket","ball"];
|
goodtypes = ["small","big","segment","socket","ball"];
|
||||||
|
@ -221,8 +221,8 @@ function modular_hose_radius(size, outer=false) =
|
||||||
)
|
)
|
||||||
assert(ind!=[], "Must specify size as 1/4, 1/2 or 3/4")
|
assert(ind!=[], "Must specify size as 1/4, 1/2 or 3/4")
|
||||||
let(
|
let(
|
||||||
b = select(_big_end[ind], [0,-1]),
|
b = select(_modhose_big_end[ind], [0,-1]),
|
||||||
s = select(_small_end[ind], [0,-1])
|
s = select(_modhose_small_end[ind], [0,-1])
|
||||||
)
|
)
|
||||||
outer ? b[1][0] : b[0][0];
|
outer ? b[1][0] : b[0][0];
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
// Module: bounding_box()
|
// Module: bounding_box()
|
||||||
// Synopsis: Creates the smallest bounding box that contains all the children.
|
// Synopsis: Creates the smallest bounding box that contains all the children.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Mutators, Bounds, Bounding Boxes
|
// Topics: Mutators, Bounds, Bounding Boxes
|
||||||
// See Also: pointlist_bounds()
|
// See Also: pointlist_bounds()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -109,6 +110,7 @@ module bounding_box(excess=0, planar=false) {
|
||||||
|
|
||||||
// Module: chain_hull()
|
// Module: chain_hull()
|
||||||
// Synopsis: Performs the union of hull operations between consecutive pairs of children.
|
// Synopsis: Performs the union of hull operations between consecutive pairs of children.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Mutators
|
// Topics: Mutators
|
||||||
// See Also: hull()
|
// See Also: hull()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -162,6 +164,7 @@ module chain_hull()
|
||||||
|
|
||||||
// Module: path_extrude2d()
|
// Module: path_extrude2d()
|
||||||
// Synopsis: Extrudes 2D children along a 2D path.
|
// Synopsis: Extrudes 2D children along a 2D path.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Mutators, Extrusion
|
// Topics: Mutators, Extrusion
|
||||||
// See Also: path_sweep(), path_extrude()
|
// See Also: path_sweep(), path_extrude()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -284,6 +287,7 @@ module path_extrude2d(path, caps=false, closed=false, s, convexity=10) {
|
||||||
|
|
||||||
// Module: cylindrical_extrude()
|
// Module: cylindrical_extrude()
|
||||||
// Synopsis: Extrudes 2D children outwards around a cylinder.
|
// Synopsis: Extrudes 2D children outwards around a cylinder.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Mutators, Extrusion, Rotation
|
// Topics: Mutators, Extrusion, Rotation
|
||||||
// See Also: heightfield(), cylindrical_heightfield(), cyl()
|
// See Also: heightfield(), cylindrical_heightfield(), cyl()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -349,7 +353,8 @@ module cylindrical_extrude(ir, or, od, id, size=1000, convexity=10, spin=0, orie
|
||||||
|
|
||||||
|
|
||||||
// Module: extrude_from_to()
|
// Module: extrude_from_to()
|
||||||
// Extrudes 2D children between two points in 3D space.
|
// Synopsis: Extrudes 2D children between two points in 3D space.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Extrusion, Mutators
|
// Topics: Extrusion, Mutators
|
||||||
// See Also: path_sweep(), path_extrude2d()
|
// See Also: path_sweep(), path_extrude2d()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -396,9 +401,11 @@ module extrude_from_to(pt1, pt2, convexity, twist, scale, slices) {
|
||||||
|
|
||||||
// Module: path_extrude()
|
// Module: path_extrude()
|
||||||
// Synopsis: Extrudes 2D children along a 3D path.
|
// Synopsis: Extrudes 2D children along a 3D path.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Paths, Extrusion, Mutators
|
// Topics: Paths, Extrusion, Mutators
|
||||||
// See Also: path_sweep(), path_extrude2d()
|
// See Also: path_sweep(), path_extrude2d()
|
||||||
// Usage: path_extrude(path, [convexity], [clipsize]) 2D-CHILDREN;
|
// Usage:
|
||||||
|
// path_extrude(path, [convexity], [clipsize]) 2D-CHILDREN;
|
||||||
// Description:
|
// Description:
|
||||||
// Extrudes 2D children along a 3D path. This may be slow and can have problems with twisting.
|
// Extrudes 2D children along a 3D path. This may be slow and can have problems with twisting.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -461,6 +468,7 @@ module path_extrude(path, convexity=10, clipsize=100) {
|
||||||
|
|
||||||
// Module: minkowski_difference()
|
// Module: minkowski_difference()
|
||||||
// Synopsis: Removes diff shapes from base shape surface.
|
// Synopsis: Removes diff shapes from base shape surface.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Mutators
|
// Topics: Mutators
|
||||||
// See Also: offset3d()
|
// See Also: offset3d()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -504,6 +512,7 @@ module minkowski_difference(planar=false) {
|
||||||
|
|
||||||
// Module: offset3d()
|
// Module: offset3d()
|
||||||
// Synopsis: Expands or contracts the surface of a 3D object.
|
// Synopsis: Expands or contracts the surface of a 3D object.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Mutators
|
// Topics: Mutators
|
||||||
// See Also: minkowski_difference(), round3d()
|
// See Also: minkowski_difference(), round3d()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -550,6 +559,7 @@ module offset3d(r, size=100, convexity=10) {
|
||||||
|
|
||||||
// Module: round3d()
|
// Module: round3d()
|
||||||
// Synopsis: Rounds arbitrary 3d objects.
|
// Synopsis: Rounds arbitrary 3d objects.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Rounding, Mutators
|
// Topics: Rounding, Mutators
|
||||||
// See Also: offset3d(), minkowski_difference()
|
// See Also: offset3d(), minkowski_difference()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
// Module: nema_stepper_motor()
|
// Module: nema_stepper_motor()
|
||||||
// Synopsis: Creates a NEMA standard stepper motor model.
|
// Synopsis: Creates a NEMA standard stepper motor model.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Motors
|
// Topics: Parts, Motors
|
||||||
// See Also: nema_stepper_motor(), nema_mount_mask()
|
// See Also: nema_stepper_motor(), nema_mount_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -119,6 +120,7 @@ module nema_stepper_motor(size=17, h=24, shaft_len=20, details=true, atype="body
|
||||||
|
|
||||||
// Module: nema_mount_mask()
|
// Module: nema_mount_mask()
|
||||||
// Synopsis: Creates a standard NEMA mount holes mask.
|
// Synopsis: Creates a standard NEMA mount holes mask.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Motors
|
// Topics: Parts, Motors
|
||||||
// See Also: nema_stepper_motor(), nema_mount_mask()
|
// See Also: nema_stepper_motor(), nema_mount_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
// Synopsis: Masks half of an object at a cut plane.
|
// Synopsis: Masks half of an object at a cut plane.
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: back_half(), front_half(), left_half(), right_half(), top_half(), bottom_half()
|
// See Also: back_half(), front_half(), left_half(), right_half(), top_half(), bottom_half(), intersection()
|
||||||
//
|
//
|
||||||
// Usage: as module
|
// Usage: as module
|
||||||
// half_of(v, [cp], [s], [planar]) CHILDREN;
|
// half_of(v, [cp], [s], [planar]) CHILDREN;
|
||||||
|
@ -23,12 +23,13 @@
|
||||||
// result = half_of(p,v,[cp]);
|
// result = half_of(p,v,[cp]);
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a cut plane, and masks away everything that is on one side. The v parameter is either a plane specification or
|
// Slices an object at a cut plane, and masks away everything that is on one side. The v parameter
|
||||||
// a normal vector. The s parameter is needed for the module
|
// is either a plane specification or a normal vector. The `s` parameter is needed for the module
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// version to control the size of the masking cube. If `s` is too large then the preview display
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// will flip around and display the wrong half, but if it is too small it won't fully mask your
|
||||||
// When called as a function, you must supply a vnf, path or region in p. If planar is set to true for the module version the operation
|
// model. When called as a function, you must supply a vnf, path or region in p. If planar is set
|
||||||
// is performed in 2D and UP and DOWN are treated as equivalent to BACK and FWD respectively.
|
// to true for the module version the operation is performed in 2D and UP and DOWN are treated as
|
||||||
|
// equivalent to BACK and FWD respectively.
|
||||||
//
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = path, region or VNF to slice. (Function version)
|
// p = path, region or VNF to slice. (Function version)
|
||||||
|
@ -125,7 +126,7 @@ function half_of(p, v=UP, cp) =
|
||||||
// Synopsis: Masks the right half of an object along the Y-Z plane, leaving the left half.
|
// Synopsis: Masks the right half of an object along the Y-Z plane, leaving the left half.
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: back_half(), front_half(), right_half(), top_half(), bottom_half(), half_of()
|
// See Also: back_half(), front_half(), right_half(), top_half(), bottom_half(), half_of(), intersection()
|
||||||
//
|
//
|
||||||
// Usage: as module
|
// Usage: as module
|
||||||
// left_half([s], [x]) CHILDREN;
|
// left_half([s], [x]) CHILDREN;
|
||||||
|
@ -135,9 +136,9 @@ function half_of(p, v=UP, cp) =
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a vertical Y-Z cut plane, and masks away everything that is right of it.
|
// Slices an object at a vertical Y-Z cut plane, and masks away everything that is right of it.
|
||||||
// The s parameter is needed for the module
|
// The `s` parameter is needed for the module version to control the size of the masking cube.
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// If `s` is too large then the preview display will flip around and display the wrong half,
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// but if it is too small it won't fully mask your model.
|
||||||
//
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = VNF, region or path to slice (function version)
|
// p = VNF, region or path to slice (function version)
|
||||||
|
@ -172,7 +173,7 @@ function left_half(p,x=0) = half_of(p, LEFT, [x,0,0]);
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Synopsis: Masks the left half of an object along the Y-Z plane, leaving the right half.
|
// Synopsis: Masks the left half of an object along the Y-Z plane, leaving the right half.
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: back_half(), front_half(), left_half(), top_half(), bottom_half(), half_of()
|
// See Also: back_half(), front_half(), left_half(), top_half(), bottom_half(), half_of(), intersection()
|
||||||
//
|
//
|
||||||
// Usage: as module
|
// Usage: as module
|
||||||
// right_half([s=], [x=]) CHILDREN;
|
// right_half([s=], [x=]) CHILDREN;
|
||||||
|
@ -182,9 +183,9 @@ function left_half(p,x=0) = half_of(p, LEFT, [x,0,0]);
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a vertical Y-Z cut plane, and masks away everything that is left of it.
|
// Slices an object at a vertical Y-Z cut plane, and masks away everything that is left of it.
|
||||||
// The s parameter is needed for the module
|
// The `s` parameter is needed for the module version to control the size of the masking cube.
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// If `s` is too large then the preview display will flip around and display the wrong half,
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// but if it is too small it won't fully mask your model.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = VNF, region or path to slice (function version)
|
// p = VNF, region or path to slice (function version)
|
||||||
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
||||||
|
@ -217,7 +218,7 @@ function right_half(p,x=0) = half_of(p, RIGHT, [x,0,0]);
|
||||||
// Synopsis: Masks the back half of an object along the X-Z plane, leaving the front half.
|
// Synopsis: Masks the back half of an object along the X-Z plane, leaving the front half.
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: back_half(), left_half(), right_half(), top_half(), bottom_half(), half_of()
|
// See Also: back_half(), left_half(), right_half(), top_half(), bottom_half(), half_of(), intersection()
|
||||||
//
|
//
|
||||||
// Usage:
|
// Usage:
|
||||||
// front_half([s], [y]) CHILDREN;
|
// front_half([s], [y]) CHILDREN;
|
||||||
|
@ -227,9 +228,9 @@ function right_half(p,x=0) = half_of(p, RIGHT, [x,0,0]);
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a vertical X-Z cut plane, and masks away everything that is behind it.
|
// Slices an object at a vertical X-Z cut plane, and masks away everything that is behind it.
|
||||||
// The s parameter is needed for the module
|
// The `s` parameter is needed for the module version to control the size of the masking cube.
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// If `s` is too large then the preview display will flip around and display the wrong half,
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// but if it is too small it won't fully mask your model.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = VNF, region or path to slice (function version)
|
// p = VNF, region or path to slice (function version)
|
||||||
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
||||||
|
@ -263,7 +264,7 @@ function front_half(p,y=0) = half_of(p, FRONT, [0,y,0]);
|
||||||
// Synopsis: Masks the front half of an object along the X-Z plane, leaving the back half.
|
// Synopsis: Masks the front half of an object along the X-Z plane, leaving the back half.
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: front_half(), left_half(), right_half(), top_half(), bottom_half(), half_of()
|
// See Also: front_half(), left_half(), right_half(), top_half(), bottom_half(), half_of(), intersection()
|
||||||
//
|
//
|
||||||
// Usage:
|
// Usage:
|
||||||
// back_half([s], [y]) CHILDREN;
|
// back_half([s], [y]) CHILDREN;
|
||||||
|
@ -273,9 +274,9 @@ function front_half(p,y=0) = half_of(p, FRONT, [0,y,0]);
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a vertical X-Z cut plane, and masks away everything that is in front of it.
|
// Slices an object at a vertical X-Z cut plane, and masks away everything that is in front of it.
|
||||||
// The s parameter is needed for the module
|
// The `s` parameter is needed for the module version to control the size of the masking cube.
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// If `s` is too large then the preview display will flip around and display the wrong half,
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// but if it is too small it won't fully mask your model.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = VNF, region or path to slice (function version)
|
// p = VNF, region or path to slice (function version)
|
||||||
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
||||||
|
@ -309,7 +310,7 @@ function back_half(p,y=0) = half_of(p, BACK, [0,y,0]);
|
||||||
// Synopsis: Masks the top half of an object along the X-Y plane, leaving the bottom half.
|
// Synopsis: Masks the top half of an object along the X-Y plane, leaving the bottom half.
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: back_half(), front_half(), left_half(), right_half(), top_half(), half_of()
|
// See Also: back_half(), front_half(), left_half(), right_half(), top_half(), half_of(), intersection()
|
||||||
//
|
//
|
||||||
// Usage:
|
// Usage:
|
||||||
// bottom_half([s], [z]) CHILDREN;
|
// bottom_half([s], [z]) CHILDREN;
|
||||||
|
@ -318,9 +319,9 @@ function back_half(p,y=0) = half_of(p, BACK, [0,y,0]);
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a horizontal X-Y cut plane, and masks away everything that is above it.
|
// Slices an object at a horizontal X-Y cut plane, and masks away everything that is above it.
|
||||||
// The s parameter is needed for the module
|
// The `s` parameter is needed for the module version to control the size of the masking cube.
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// If `s` is too large then the preview display will flip around and display the wrong half,
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// but if it is too small it won't fully mask your model.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = VNF, region or path to slice (function version)
|
// p = VNF, region or path to slice (function version)
|
||||||
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
||||||
|
@ -347,7 +348,7 @@ function bottom_half(p,z=0) = half_of(p,BOTTOM,[0,0,z]);
|
||||||
// Synopsis: Masks the bottom half of an object along the X-Y plane, leaving the top half.
|
// Synopsis: Masks the bottom half of an object along the X-Y plane, leaving the top half.
|
||||||
// SynTags: Geom, VNF, Path, Region
|
// SynTags: Geom, VNF, Path, Region
|
||||||
// Topics: Partitions, Masking
|
// Topics: Partitions, Masking
|
||||||
// See Also: back_half(), front_half(), left_half(), right_half(), bottom_half(), half_of()
|
// See Also: back_half(), front_half(), left_half(), right_half(), bottom_half(), half_of(), intersection()
|
||||||
//
|
//
|
||||||
// Usage: as module
|
// Usage: as module
|
||||||
// top_half([s], [z]) CHILDREN;
|
// top_half([s], [z]) CHILDREN;
|
||||||
|
@ -356,9 +357,9 @@ function bottom_half(p,z=0) = half_of(p,BOTTOM,[0,0,z]);
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Slices an object at a horizontal X-Y cut plane, and masks away everything that is below it.
|
// Slices an object at a horizontal X-Y cut plane, and masks away everything that is below it.
|
||||||
// The s parameter is needed for the module
|
// The `s` parameter is needed for the module version to control the size of the masking cube.
|
||||||
// version to control the size of the masking cube. If s is too large then the preview display will flip around and display the
|
// If `s` is too large then the preview display will flip around and display the wrong half,
|
||||||
// wrong half, but if it is too small it won't fully mask your model.
|
// but if it is too small it won't fully mask your model.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// p = VNF, region or path to slice (function version)
|
// p = VNF, region or path to slice (function version)
|
||||||
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
// s = Mask size to use. Use a number larger than twice your object's largest axis. If you make this too large, OpenSCAD's preview rendering may display the wrong half. (Module version) Default: 100
|
||||||
|
@ -433,7 +434,8 @@ function _partition_cutpath(l, h, cutsize, cutpath, gap) =
|
||||||
// Usage:
|
// Usage:
|
||||||
// partition_mask(l, w, h, [cutsize], [cutpath], [gap], [inverse], [$slop=], [anchor=], [spin=], [orient=]) [ATTACHMENTS];
|
// partition_mask(l, w, h, [cutsize], [cutpath], [gap], [inverse], [$slop=], [anchor=], [spin=], [orient=]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a mask that you can use to difference or intersect with an object to remove half of it, leaving behind a side designed to allow assembly of the sub-parts.
|
// Creates a mask that you can use to difference or intersect with an object to remove half of it,
|
||||||
|
// leaving behind a side designed to allow assembly of the sub-parts.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// l = The length of the cut axis.
|
// l = The length of the cut axis.
|
||||||
// w = The width of the part to be masked, back from the cut plane.
|
// w = The width of the part to be masked, back from the cut plane.
|
||||||
|
|
14
paths.scad
14
paths.scad
|
@ -78,14 +78,16 @@ function is_1region(path, name="path") =
|
||||||
|
|
||||||
// Function: force_path()
|
// Function: force_path()
|
||||||
// Synopsis: Checks that path is a region with one component.
|
// Synopsis: Checks that path is a region with one component.
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Paths, Regions
|
// Topics: Paths, Regions
|
||||||
// See Also: is_1region()
|
// See Also: is_1region()
|
||||||
// Usage:
|
// Usage:
|
||||||
// outpath = force_path(path, [name])
|
// outpath = force_path(path, [name])
|
||||||
// Description:
|
// Description:
|
||||||
// If `path` is a region with one component (a 1-region) then return that component as a path. If path is a region with more components
|
// If `path` is a region with one component (a 1-region) then returns that component as a path.
|
||||||
// then display an error message about the parameter `name` requiring a path or a single component region. If the input
|
// If path is a region with more components then displays an error message about the parameter
|
||||||
// is not a region then return the input without any checks. This function helps path functions accept 1-regions.
|
// `name` requiring a path or a single component region. If the input is not a region then
|
||||||
|
// returns the input without any checks. This function helps path functions accept 1-regions.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// path = input to process
|
// path = input to process
|
||||||
// name = name of parameter to use in error message. Default: "path"
|
// name = name of parameter to use in error message. Default: "path"
|
||||||
|
@ -129,6 +131,7 @@ function _path_select(path, s1, u1, s2, u2, closed=false) =
|
||||||
|
|
||||||
// Function: path_merge_collinear()
|
// Function: path_merge_collinear()
|
||||||
// Synopsis: Removes unnecessary points from a path.
|
// Synopsis: Removes unnecessary points from a path.
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Paths, Regions
|
// Topics: Paths, Regions
|
||||||
// Description:
|
// Description:
|
||||||
// Takes a path and removes unnecessary sequential collinear points.
|
// Takes a path and removes unnecessary sequential collinear points.
|
||||||
|
@ -316,6 +319,7 @@ function _sum_preserving_round(data, index=0) =
|
||||||
|
|
||||||
// Function: subdivide_path()
|
// Function: subdivide_path()
|
||||||
// Synopsis: Subdivides a path to produce a more finely sampled path.
|
// Synopsis: Subdivides a path to produce a more finely sampled path.
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Paths, Path Subdivision
|
// Topics: Paths, Path Subdivision
|
||||||
// See Also: subdivide_and_slice(), resample_path(), jittered_poly()
|
// See Also: subdivide_and_slice(), resample_path(), jittered_poly()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -461,6 +465,7 @@ function subdivide_path(path, n, refine, maxlen, closed=true, exact, method) =
|
||||||
|
|
||||||
// Function: resample_path()
|
// Function: resample_path()
|
||||||
// Synopsis: Returns an equidistant set of points along a path.
|
// Synopsis: Returns an equidistant set of points along a path.
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Paths
|
// Topics: Paths
|
||||||
// See Also: subdivide_path()
|
// See Also: subdivide_path()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -730,6 +735,7 @@ function path_torsion(path, closed=false) =
|
||||||
|
|
||||||
// Function: path_cut()
|
// Function: path_cut()
|
||||||
// Synopsis: Cuts a path into subpaths at various points.
|
// Synopsis: Cuts a path into subpaths at various points.
|
||||||
|
// SynTags: PathList
|
||||||
// Topics: Paths, Path Subdivision
|
// Topics: Paths, Path Subdivision
|
||||||
// See Also: split_path_at_self_crossings(), path_cut_points()
|
// See Also: split_path_at_self_crossings(), path_cut_points()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -929,6 +935,7 @@ function _cut_to_seg_u_form(pathcut, path, closed) =
|
||||||
|
|
||||||
// Function: split_path_at_self_crossings()
|
// Function: split_path_at_self_crossings()
|
||||||
// Synopsis: Split a 2D path wherever it crosses itself.
|
// Synopsis: Split a 2D path wherever it crosses itself.
|
||||||
|
// SynTags: PathList
|
||||||
// Topics: Paths, Path Subdivision
|
// Topics: Paths, Path Subdivision
|
||||||
// See Also: path_cut(), path_cut_points()
|
// See Also: path_cut(), path_cut_points()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -999,6 +1006,7 @@ function _tag_self_crossing_subpaths(path, nonzero, closed=true, eps=EPSILON) =
|
||||||
|
|
||||||
// Function: polygon_parts()
|
// Function: polygon_parts()
|
||||||
// Synopsis: Parses a self-intersecting polygon into a list of non-intersecting polygons.
|
// Synopsis: Parses a self-intersecting polygon into a list of non-intersecting polygons.
|
||||||
|
// SynTags: PathList
|
||||||
// Topics: Paths, Polygons
|
// Topics: Paths, Polygons
|
||||||
// See Also: split_path_at_self_crossings(), path_cut(), path_cut_points()
|
// See Also: split_path_at_self_crossings(), path_cut(), path_cut_points()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -38,6 +38,7 @@ function _unique_groups(m) = [
|
||||||
|
|
||||||
// Module: regular_polyhedron()
|
// Module: regular_polyhedron()
|
||||||
// Synopsis: Creates a regular polyhedron with optional rounding.
|
// Synopsis: Creates a regular polyhedron with optional rounding.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Polyhedra, Shapes, Parts
|
// Topics: Polyhedra, Shapes, Parts
|
||||||
// See Also: regular_polyhedron_info()
|
// See Also: regular_polyhedron_info()
|
||||||
// Usage: Selecting a polyhedron
|
// Usage: Selecting a polyhedron
|
||||||
|
|
|
@ -248,6 +248,7 @@ function is_region_simple(region, eps=EPSILON) =
|
||||||
|
|
||||||
// Function: make_region()
|
// Function: make_region()
|
||||||
// Synopsis: Converts lists of intersecting polygons into valid regions.
|
// Synopsis: Converts lists of intersecting polygons into valid regions.
|
||||||
|
// SynTags: Region
|
||||||
// Topics: Regions, Paths, Polygons, List Handling
|
// Topics: Regions, Paths, Polygons, List Handling
|
||||||
// See Also: force_region(), region()
|
// See Also: force_region(), region()
|
||||||
//
|
//
|
||||||
|
@ -281,6 +282,7 @@ function make_region(polys,nonzero=false,eps=EPSILON) =
|
||||||
|
|
||||||
// Function: force_region()
|
// Function: force_region()
|
||||||
// Synopsis: Given a polygon returns a region.
|
// Synopsis: Given a polygon returns a region.
|
||||||
|
// SynTags: Region
|
||||||
// Topics: Regions, Paths, Polygons, List Handling
|
// Topics: Regions, Paths, Polygons, List Handling
|
||||||
// See Also: make_region(), region()
|
// See Also: make_region(), region()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -296,6 +298,7 @@ function force_region(poly) = is_path(poly) ? [poly] : poly;
|
||||||
|
|
||||||
// Module: region()
|
// Module: region()
|
||||||
// Synopsis: Creates the 2D polygons described by the given region or list of polygons.
|
// Synopsis: Creates the 2D polygons described by the given region or list of polygons.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Regions, Paths, Polygons, List Handling
|
// Topics: Regions, Paths, Polygons, List Handling
|
||||||
// See Also: make_region(), region()
|
// See Also: make_region(), region()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -576,6 +579,7 @@ function split_region_at_region_crossings(region1, region2, closed1=true, closed
|
||||||
|
|
||||||
// Function: region_parts()
|
// Function: region_parts()
|
||||||
// Synopsis: Splits a region into a list of regions.
|
// Synopsis: Splits a region into a list of regions.
|
||||||
|
// SynTags: RegList
|
||||||
// Topics: Regions, List Handling
|
// Topics: Regions, List Handling
|
||||||
// See Also: split_region_at_region_crossings()
|
// See Also: split_region_at_region_crossings()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -739,6 +743,7 @@ function _point_dist(path,pathseg_unit,pathseg_len,pt) =
|
||||||
|
|
||||||
// Function: offset()
|
// Function: offset()
|
||||||
// Synopsis: Takes a 2D path, polygon or region and returns a path offset by an amount.
|
// Synopsis: Takes a 2D path, polygon or region and returns a path offset by an amount.
|
||||||
|
// SynTags: Path, Region
|
||||||
// Topics: Paths, Polygons, Regions
|
// Topics: Paths, Polygons, Regions
|
||||||
// Usage:
|
// Usage:
|
||||||
// offsetpath = offset(path, [r=|delta=], [chamfer=], [closed=], [check_valid=], [quality=], [same_length=])
|
// offsetpath = offset(path, [r=|delta=], [chamfer=], [closed=], [check_valid=], [quality=], [same_length=])
|
||||||
|
@ -1044,6 +1049,7 @@ function _list_three(a,b,c) =
|
||||||
|
|
||||||
// Function&Module: union()
|
// Function&Module: union()
|
||||||
// Synopsis: Performs a Boolean union operation.
|
// Synopsis: Performs a Boolean union operation.
|
||||||
|
// SynTags: Geom, Region
|
||||||
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
||||||
// See Also: difference(), intersection(), diff(), intersect(), exclusive_or()
|
// See Also: difference(), intersection(), diff(), intersect(), exclusive_or()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1077,6 +1083,7 @@ function union(regions=[],b=undef,c=undef,eps=EPSILON) =
|
||||||
|
|
||||||
// Function&Module: difference()
|
// Function&Module: difference()
|
||||||
// Synopsis: Performs a Boolean difference operation.
|
// Synopsis: Performs a Boolean difference operation.
|
||||||
|
// SynTags: Geom, Region
|
||||||
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
||||||
// See Also: union(), intersection(), diff(), intersect(), exclusive_or()
|
// See Also: union(), intersection(), diff(), intersect(), exclusive_or()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1112,6 +1119,7 @@ function difference(regions=[],b=undef,c=undef,eps=EPSILON) =
|
||||||
|
|
||||||
// Function&Module: intersection()
|
// Function&Module: intersection()
|
||||||
// Synopsis: Performs a Boolean intersection operation.
|
// Synopsis: Performs a Boolean intersection operation.
|
||||||
|
// SynTags: Geom, Region
|
||||||
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
||||||
// See Also: difference(), union(), diff(), intersect(), exclusive_or()
|
// See Also: difference(), union(), diff(), intersect(), exclusive_or()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1146,6 +1154,7 @@ function intersection(regions=[],b=undef,c=undef,eps=EPSILON) =
|
||||||
|
|
||||||
// Function&Module: exclusive_or()
|
// Function&Module: exclusive_or()
|
||||||
// Synopsis: Performs a Boolean exclusive-or operation.
|
// Synopsis: Performs a Boolean exclusive-or operation.
|
||||||
|
// SynTags: Geom, Region
|
||||||
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
// Topics: Boolean Operations, Regions, Polygons, Shapes2D, Shapes3D
|
||||||
// See Also: union(), difference(), intersection(), diff(), intersect()
|
// See Also: union(), difference(), intersection(), diff(), intersect()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -135,6 +135,7 @@ include <structs.scad>
|
||||||
|
|
||||||
// Function: round_corners()
|
// Function: round_corners()
|
||||||
// Synopsis: Round or chamfer the corners of a path (clipping them off).
|
// Synopsis: Round or chamfer the corners of a path (clipping them off).
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Rounding, Paths
|
// Topics: Rounding, Paths
|
||||||
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -597,6 +598,7 @@ function _rounding_offsets(edgespec,z_dir=1) =
|
||||||
|
|
||||||
// Function: smooth_path()
|
// Function: smooth_path()
|
||||||
// Synopsis: Create smoothed path that passes through all the points of a given path.
|
// Synopsis: Create smoothed path that passes through all the points of a given path.
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Rounding, Paths
|
// Topics: Rounding, Paths
|
||||||
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -695,6 +697,7 @@ function _scalar_to_vector(value,length,varname) =
|
||||||
|
|
||||||
// Function: path_join()
|
// Function: path_join()
|
||||||
// Synopsis: Join paths end to end with optional rounding.
|
// Synopsis: Join paths end to end with optional rounding.
|
||||||
|
// SynTags: Path
|
||||||
// Topics: Rounding, Paths
|
// Topics: Rounding, Paths
|
||||||
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -883,6 +886,7 @@ function _path_join(paths,joint,k=0.5,i=0,result=[],relocate=true,closed=false)
|
||||||
|
|
||||||
// Function&Module: offset_stroke()
|
// Function&Module: offset_stroke()
|
||||||
// Synopsis: Draws a line along a path with options to specify angles and roundings at the ends.
|
// Synopsis: Draws a line along a path with options to specify angles and roundings at the ends.
|
||||||
|
// SynTags: Path, Region
|
||||||
// Topics: Rounding, Paths
|
// Topics: Rounding, Paths
|
||||||
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
// See Also: round_corners(), smooth_path(), path_join(), offset_stroke()
|
||||||
// Usage: as module
|
// Usage: as module
|
||||||
|
@ -1263,10 +1267,11 @@ module offset_stroke(path, width=1, rounded=true, start, end, check_valid=true,
|
||||||
|
|
||||||
// Function&Module: offset_sweep()
|
// Function&Module: offset_sweep()
|
||||||
// Synopsis: Make a solid from a polygon with offset that changes along its length.
|
// Synopsis: Make a solid from a polygon with offset that changes along its length.
|
||||||
|
// SynTags: Geom, VNF
|
||||||
// Topics: Rounding, Offsets
|
// Topics: Rounding, Offsets
|
||||||
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
||||||
// Usage: most common module arguments. See Arguments list below for more.
|
// Usage: most common module arguments. See Arguments list below for more.
|
||||||
// offset_sweep(path, [height|length|h|l|], [bottom], [top], [offset=], [convexity=],...) [ATTACHMENTS];
|
// offset_sweep(path, [height|length|h|l|], [bottom], [top], [offset=], [convexity=],...) [ATTACHMENTS];
|
||||||
// Usage: most common function arguments. See Arguments list below for more.
|
// Usage: most common function arguments. See Arguments list below for more.
|
||||||
// vnf = offset_sweep(path, [height|h|l|length], [bottom], [top], [offset=], ...);
|
// vnf = offset_sweep(path, [height|h|l|length], [bottom], [top], [offset=], ...);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -1732,6 +1737,7 @@ function os_mask(mask, out=false, extra,check_valid, quality, offset) =
|
||||||
|
|
||||||
// Module: convex_offset_extrude()
|
// Module: convex_offset_extrude()
|
||||||
// Synopsis: Make a solid from geometry where offset changes along the object's length.
|
// Synopsis: Make a solid from geometry where offset changes along the object's length.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Rounding, Offsets
|
// Topics: Rounding, Offsets
|
||||||
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
||||||
// Usage: Basic usage. See below for full options
|
// Usage: Basic usage. See below for full options
|
||||||
|
@ -1969,6 +1975,7 @@ function _rp_compute_patches(top, bot, rtop, rsides, ktop, ksides, concave) =
|
||||||
|
|
||||||
// Function&Module: rounded_prism()
|
// Function&Module: rounded_prism()
|
||||||
// Synopsis: Make a rounded 3d object by connecting two polygons with the same vertex count.
|
// Synopsis: Make a rounded 3d object by connecting two polygons with the same vertex count.
|
||||||
|
// SynTags: Geom, VNF
|
||||||
// Topics: Rounding, Offsets
|
// Topics: Rounding, Offsets
|
||||||
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
||||||
// Usage: as a module
|
// Usage: as a module
|
||||||
|
@ -2285,6 +2292,7 @@ function _circle_mask(r) =
|
||||||
|
|
||||||
// Module: bent_cutout_mask()
|
// Module: bent_cutout_mask()
|
||||||
// Synopsis: Create a mask for making a round-edged cutout in a cylindrical shell.
|
// Synopsis: Create a mask for making a round-edged cutout in a cylindrical shell.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Rounding, Offsets
|
// Topics: Rounding, Offsets
|
||||||
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -2513,6 +2521,7 @@ Access to the derivative smoothing parameter?
|
||||||
|
|
||||||
// Function&Module: join_prism()
|
// Function&Module: join_prism()
|
||||||
// Synopsis: Join an arbitrary prism to a plane, sphere, cylinder or another arbitrary prism with a fillet.
|
// Synopsis: Join an arbitrary prism to a plane, sphere, cylinder or another arbitrary prism with a fillet.
|
||||||
|
// SynTags: Geom, VNF
|
||||||
// Topics: Rounding, Offsets
|
// Topics: Rounding, Offsets
|
||||||
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
// See Also: offset_sweep(), convex_offset_extrude(), rounded_prism(), bent_cutout_mask(), join_prism()
|
||||||
// Usage: The two main forms with most common options
|
// Usage: The two main forms with most common options
|
||||||
|
|
|
@ -15,6 +15,7 @@ include <structs.scad>
|
||||||
|
|
||||||
// Module: phillips_mask()
|
// Module: phillips_mask()
|
||||||
// Synopsis: Creates a mask for a Philips screw drive.
|
// Synopsis: Creates a mask for a Philips screw drive.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Screws, Masks
|
// Topics: Screws, Masks
|
||||||
// See Also: hex_drive_mask(), phillips_depth(), phillips_diam(), torx_mask(), robertson_mask()
|
// See Also: hex_drive_mask(), phillips_depth(), phillips_diam(), torx_mask(), robertson_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -139,6 +140,7 @@ function phillips_diam(size, depth) =
|
||||||
|
|
||||||
// Module: hex_drive_mask()
|
// Module: hex_drive_mask()
|
||||||
// Synopsis: Creates a mask for a hex drive recess.
|
// Synopsis: Creates a mask for a hex drive recess.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Screws, Masks
|
// Topics: Screws, Masks
|
||||||
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), robertson_mask()
|
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), robertson_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -161,6 +163,7 @@ function hex_drive_mask(size,length,l,h,height,anchor,spin,orient) = no_function
|
||||||
|
|
||||||
// Module: torx_mask()
|
// Module: torx_mask()
|
||||||
// Synopsis: Creates a mask for a torx drive recess.
|
// Synopsis: Creates a mask for a torx drive recess.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Screws, Masks
|
// Topics: Screws, Masks
|
||||||
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), robertson_mask()
|
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), robertson_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -191,6 +194,7 @@ module torx_mask(size, l=5, center, anchor, spin=0, orient=UP) {
|
||||||
|
|
||||||
// Module: torx_mask2d()
|
// Module: torx_mask2d()
|
||||||
// Synopsis: Creates the 2D cross section for a torx drive recess.
|
// Synopsis: Creates the 2D cross section for a torx drive recess.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Screws, Masks
|
// Topics: Screws, Masks
|
||||||
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), torx_info(), robertson_mask()
|
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), torx_info(), robertson_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -313,6 +317,7 @@ function torx_depth(size) = torx_info(size)[2];
|
||||||
|
|
||||||
// Module: robertson_mask()
|
// Module: robertson_mask()
|
||||||
// Synopsis: Creates a mask for a Robertson/Square drive recess.
|
// Synopsis: Creates a mask for a Robertson/Square drive recess.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Screws, Masks
|
// Topics: Screws, Masks
|
||||||
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), torx_info(), robertson_mask()
|
// See Also: phillips_mask(), hex_drive_mask(), torx_mask(), phillips_depth(), phillips_diam(), torx_info(), robertson_mask()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -189,6 +189,7 @@ Torx values: https://www.stanleyengineeredfastening.com/-/media/web/sef/resourc
|
||||||
|
|
||||||
// Module: screw()
|
// Module: screw()
|
||||||
// Synopsis: Creates a standard screw with optional tolerances.
|
// Synopsis: Creates a standard screw with optional tolerances.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw_hole(), shoulder_screw()
|
// See Also: screw_hole(), shoulder_screw()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -720,6 +721,7 @@ module screw(spec, head, drive, thread, drive_size,
|
||||||
|
|
||||||
// Module: screw_hole()
|
// Module: screw_hole()
|
||||||
// Synopsis: Creates a screw hole.
|
// Synopsis: Creates a screw hole.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw()
|
// See Also: screw()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -977,6 +979,7 @@ module screw_hole(spec, head, thread, oversize, hole_oversize, head_oversize,
|
||||||
|
|
||||||
// Module: shoulder_screw()
|
// Module: shoulder_screw()
|
||||||
// Synopsis: Creates a shoulder screw.
|
// Synopsis: Creates a shoulder screw.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw(), screw_hole()
|
// See Also: screw(), screw_hole()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1390,6 +1393,7 @@ function _parse_drive(drive=undef, drive_size=undef) =
|
||||||
|
|
||||||
// Module: screw_head()
|
// Module: screw_head()
|
||||||
// Synopsis: Creates a screw head.
|
// Synopsis: Creates a screw head.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw(), screw_hole()
|
// See Also: screw(), screw_hole()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1493,6 +1497,7 @@ module screw_head(screw_info,details=false, counterbore=0,flat_height,teardrop=f
|
||||||
|
|
||||||
// Module: nut()
|
// Module: nut()
|
||||||
// Synopsis: Creates a standard nut.
|
// Synopsis: Creates a standard nut.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw(), screw_hole()
|
// See Also: screw(), screw_hole()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1615,6 +1620,7 @@ module nut(spec, shape, thickness, nutwidth, thread, tolerance, hole_oversize,
|
||||||
|
|
||||||
// Module: nut_trap_side()
|
// Module: nut_trap_side()
|
||||||
// Synopsis: Creates a side nut trap mask.
|
// Synopsis: Creates a side nut trap mask.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw(), screw_hole()
|
// See Also: screw(), screw_hole()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1705,6 +1711,7 @@ module nut_trap_side(trap_width, spec, shape, thickness, nutwidth, anchor=BOT, o
|
||||||
|
|
||||||
// Module: nut_trap_inline()
|
// Module: nut_trap_inline()
|
||||||
// Synopsis: Creates an inline nut trap mask.
|
// Synopsis: Creates an inline nut trap mask.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Threading, Screws
|
// Topics: Threading, Screws
|
||||||
// See Also: screw(), screw_hole()
|
// See Also: screw(), screw_hole()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -90,7 +90,7 @@ function cube(size=1, center, anchor, spin=0, orient=UP) =
|
||||||
|
|
||||||
// Module: cuboid()
|
// Module: cuboid()
|
||||||
// Synopsis: Creates a cube with chamfering and roundovers.
|
// Synopsis: Creates a cube with chamfering and roundovers.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom
|
||||||
// Topics: Shapes (3D), Attachable, VNF Generators
|
// Topics: Shapes (3D), Attachable, VNF Generators
|
||||||
// See Also: prismoid(), rounded_prism()
|
// See Also: prismoid(), rounded_prism()
|
||||||
// Usage: Standard Cubes
|
// Usage: Standard Cubes
|
||||||
|
@ -816,7 +816,7 @@ function octahedron(size=1, anchor=CENTER, spin=0, orient=UP) =
|
||||||
|
|
||||||
// Module: rect_tube()
|
// Module: rect_tube()
|
||||||
// Synopsis: Creates a rectangular tube.
|
// Synopsis: Creates a rectangular tube.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom
|
||||||
// Topics: Shapes (3D), Attachable, VNF Generators
|
// Topics: Shapes (3D), Attachable, VNF Generators
|
||||||
// See Also: tube()
|
// See Also: tube()
|
||||||
// Usage: Typical Rectangular Tubes
|
// Usage: Typical Rectangular Tubes
|
||||||
|
@ -1694,7 +1694,7 @@ module cyl(
|
||||||
|
|
||||||
// Module: xcyl()
|
// Module: xcyl()
|
||||||
// Synopsis: creates a cylinder oriented along the X axis.
|
// Synopsis: creates a cylinder oriented along the X axis.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom
|
||||||
// Topics: Cylinders, Textures, Rounding, Chamfers
|
// Topics: Cylinders, Textures, Rounding, Chamfers
|
||||||
// See Also: texture(), rotate_sweep(), cyl()
|
// See Also: texture(), rotate_sweep(), cyl()
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -1777,7 +1777,7 @@ module xcyl(
|
||||||
|
|
||||||
// Module: ycyl()
|
// Module: ycyl()
|
||||||
// Synopsis: Creates a cylinder oriented along the y axis.
|
// Synopsis: Creates a cylinder oriented along the y axis.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom
|
||||||
// Topics: Cylinders, Textures, Rounding, Chamfers
|
// Topics: Cylinders, Textures, Rounding, Chamfers
|
||||||
// See Also: texture(), rotate_sweep(), cyl()
|
// See Also: texture(), rotate_sweep(), cyl()
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -1862,7 +1862,7 @@ module ycyl(
|
||||||
|
|
||||||
// Module: zcyl()
|
// Module: zcyl()
|
||||||
// Synopsis: Creates a cylinder oriented along the Z axis.
|
// Synopsis: Creates a cylinder oriented along the Z axis.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom
|
||||||
// Topics: Cylinders, Textures, Rounding, Chamfers
|
// Topics: Cylinders, Textures, Rounding, Chamfers
|
||||||
// See Also: texture(), rotate_sweep(), cyl()
|
// See Also: texture(), rotate_sweep(), cyl()
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -1946,7 +1946,7 @@ module zcyl(
|
||||||
|
|
||||||
// Module: tube()
|
// Module: tube()
|
||||||
// Synopsis: Creates a cylindrical or conical tube.
|
// Synopsis: Creates a cylindrical or conical tube.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom
|
||||||
// Topics: Shapes (3D), Attachable, VNF Generators
|
// Topics: Shapes (3D), Attachable, VNF Generators
|
||||||
// See Also: rect_tube()
|
// See Also: rect_tube()
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -3248,10 +3248,10 @@ module path_text(path, text, font, size, thickness, lettersize, offset=0, revers
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Topics: Shapes (3D), Attachable
|
|
||||||
// Module: fillet()
|
// Module: fillet()
|
||||||
// Synopsis: Creates a smooth fillet between two faces.
|
// Synopsis: Creates a smooth fillet between two faces.
|
||||||
// SynTags: Geom, VNF
|
// SynTags: Geom, VNF
|
||||||
|
// Topics: Shapes (3D), Attachable
|
||||||
// See Also: mask2d_roundover()
|
// See Also: mask2d_roundover()
|
||||||
// Description:
|
// Description:
|
||||||
// Creates a shape that can be unioned into a concave joint between two faces, to fillet them.
|
// Creates a shape that can be unioned into a concave joint between two faces, to fillet them.
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
// Module: slider()
|
// Module: slider()
|
||||||
// Synopsis: Creates a V-groove slider.
|
// Synopsis: Creates a V-groove slider.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Sliders
|
// Topics: Parts, Sliders
|
||||||
// See Also: rail()
|
// See Also: rail()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -67,6 +68,7 @@ module slider(l=30, w=10, h=10, base=10, wall=5, ang=30, anchor=BOTTOM, spin=0,
|
||||||
|
|
||||||
// Module: rail()
|
// Module: rail()
|
||||||
// Synopsis: Creates a V-groove rail.
|
// Synopsis: Creates a V-groove rail.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts, Sliders
|
// Topics: Parts, Sliders
|
||||||
// See Also: slider()
|
// See Also: slider()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
243
transforms.scad
243
transforms.scad
|
@ -74,6 +74,11 @@ _NO_ARG = [true,[123232345],false];
|
||||||
// Function&Module: move()
|
// Function&Module: move()
|
||||||
// Aliases: translate()
|
// Aliases: translate()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children in an arbitrary direction.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: left(), right(), fwd(), back(), down(), up(), spherical_to_xyz(), altaz_to_xyz(), cylindrical_to_xyz(), polar_to_xy()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// move(v) CHILDREN;
|
// move(v) CHILDREN;
|
||||||
// Usage: As a function to translate points, VNF, or Bezier patches
|
// Usage: As a function to translate points, VNF, or Bezier patches
|
||||||
|
@ -82,11 +87,6 @@ _NO_ARG = [true,[123232345],false];
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = move(v);
|
// mat = move(v);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children in an arbitrary direction.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: left(), right(), fwd(), back(), down(), up(), spherical_to_xyz(), altaz_to_xyz(), cylindrical_to_xyz(), polar_to_xy()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Translates position by the given amount.
|
// Translates position by the given amount.
|
||||||
// * Called as a module, moves/translates all children.
|
// * Called as a module, moves/translates all children.
|
||||||
|
@ -160,6 +160,11 @@ function translate(v=[0,0,0], p=_NO_ARG) = move(v=v, p=p);
|
||||||
|
|
||||||
// Function&Module: left()
|
// Function&Module: left()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children leftwards (X-).
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: move(), right(), fwd(), back(), down(), up()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// left(x) CHILDREN;
|
// left(x) CHILDREN;
|
||||||
// Usage: Translate Points
|
// Usage: Translate Points
|
||||||
|
@ -167,11 +172,6 @@ function translate(v=[0,0,0], p=_NO_ARG) = move(v=v, p=p);
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = left(x);
|
// mat = left(x);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children leftwards (X-).
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: move(), right(), fwd(), back(), down(), up()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// If called as a module, moves/translates all children left (in the X- direction) by the given amount.
|
// If called as a module, moves/translates all children left (in the X- direction) by the given amount.
|
||||||
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
||||||
|
@ -205,6 +205,11 @@ function left(x=0, p=_NO_ARG) =
|
||||||
// Function&Module: right()
|
// Function&Module: right()
|
||||||
// Aliases: xmove()
|
// Aliases: xmove()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children rightwards (X+).
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: move(), left(), fwd(), back(), down(), up()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// right(x) CHILDREN;
|
// right(x) CHILDREN;
|
||||||
// Usage: Translate Points
|
// Usage: Translate Points
|
||||||
|
@ -212,11 +217,6 @@ function left(x=0, p=_NO_ARG) =
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = right(x);
|
// mat = right(x);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children rightwards (X+).
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: move(), left(), fwd(), back(), down(), up()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// If called as a module, moves/translates all children right (in the X+ direction) by the given amount.
|
// If called as a module, moves/translates all children right (in the X+ direction) by the given amount.
|
||||||
// If called as a function with the `p` argument, returns the translated VNF point or list of points.
|
// If called as a function with the `p` argument, returns the translated VNF point or list of points.
|
||||||
|
@ -260,6 +260,11 @@ function xmove(x=0, p=_NO_ARG) =
|
||||||
|
|
||||||
// Function&Module: fwd()
|
// Function&Module: fwd()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children forwards (Y-).
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: move(), left(), right(), back(), down(), up()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// fwd(y) CHILDREN;
|
// fwd(y) CHILDREN;
|
||||||
// Usage: Translate Points
|
// Usage: Translate Points
|
||||||
|
@ -267,11 +272,6 @@ function xmove(x=0, p=_NO_ARG) =
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = fwd(y);
|
// mat = fwd(y);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children forwards (Y-).
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: move(), left(), right(), back(), down(), up()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// If called as a module, moves/translates all children forward (in the Y- direction) by the given amount.
|
// If called as a module, moves/translates all children forward (in the Y- direction) by the given amount.
|
||||||
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
||||||
|
@ -305,6 +305,11 @@ function fwd(y=0, p=_NO_ARG) =
|
||||||
// Function&Module: back()
|
// Function&Module: back()
|
||||||
// Aliases: ymove()
|
// Aliases: ymove()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children backwards (Y+).
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: move(), left(), right(), fwd(), down(), up()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// back(y) CHILDREN;
|
// back(y) CHILDREN;
|
||||||
// Usage: Translate Points
|
// Usage: Translate Points
|
||||||
|
@ -312,11 +317,6 @@ function fwd(y=0, p=_NO_ARG) =
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = back(y);
|
// mat = back(y);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children backwards (Y+).
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: move(), left(), right(), fwd(), down(), up()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// If called as a module, moves/translates all children back (in the Y+ direction) by the given amount.
|
// If called as a module, moves/translates all children back (in the Y+ direction) by the given amount.
|
||||||
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
||||||
|
@ -360,6 +360,11 @@ function ymove(y=0,p=_NO_ARG) =
|
||||||
|
|
||||||
// Function&Module: down()
|
// Function&Module: down()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children downwards (Z-).
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: move(), left(), right(), fwd(), back(), up()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// down(z) CHILDREN;
|
// down(z) CHILDREN;
|
||||||
// Usage: Translate Points
|
// Usage: Translate Points
|
||||||
|
@ -367,11 +372,6 @@ function ymove(y=0,p=_NO_ARG) =
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = down(z);
|
// mat = down(z);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children downwards (Z-).
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: move(), left(), right(), fwd(), back(), up()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// If called as a module, moves/translates all children down (in the Z- direction) by the given amount.
|
// If called as a module, moves/translates all children down (in the Z- direction) by the given amount.
|
||||||
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
||||||
|
@ -403,6 +403,11 @@ function down(z=0, p=_NO_ARG) =
|
||||||
// Function&Module: up()
|
// Function&Module: up()
|
||||||
// Aliases: zmove()
|
// Aliases: zmove()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Translates children upwards (Z+).
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Translation
|
||||||
|
// See Also: move(), left(), right(), fwd(), back(), down()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// up(z) CHILDREN;
|
// up(z) CHILDREN;
|
||||||
// Usage: Translate Points
|
// Usage: Translate Points
|
||||||
|
@ -410,11 +415,6 @@ function down(z=0, p=_NO_ARG) =
|
||||||
// Usage: Get Translation Matrix
|
// Usage: Get Translation Matrix
|
||||||
// mat = up(z);
|
// mat = up(z);
|
||||||
//
|
//
|
||||||
// Synopsis: Translates children upwards (Z+).
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Translation
|
|
||||||
// See Also: move(), left(), right(), fwd(), back(), down()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// If called as a module, moves/translates all children up (in the Z+ direction) by the given amount.
|
// If called as a module, moves/translates all children up (in the Z+ direction) by the given amount.
|
||||||
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
// If called as a function with the `p` argument, returns the translated VNF, point or list of points.
|
||||||
|
@ -463,6 +463,11 @@ function zmove(z=0, p=_NO_ARG) =
|
||||||
|
|
||||||
// Function&Module: rot()
|
// Function&Module: rot()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Rotates children in various ways.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Rotation
|
||||||
|
// See Also: xrot(), yrot(), zrot()
|
||||||
|
//
|
||||||
// Usage: As a Module
|
// Usage: As a Module
|
||||||
// rot(a, [cp=], [reverse=]) CHILDREN;
|
// rot(a, [cp=], [reverse=]) CHILDREN;
|
||||||
// rot([X,Y,Z], [cp=], [reverse=]) CHILDREN;
|
// rot([X,Y,Z], [cp=], [reverse=]) CHILDREN;
|
||||||
|
@ -479,11 +484,6 @@ function zmove(z=0, p=_NO_ARG) =
|
||||||
// M = rot(a, v, [cp=], [reverse=]);
|
// M = rot(a, v, [cp=], [reverse=]);
|
||||||
// M = rot(from=, to=, [a=], [reverse=]);
|
// M = rot(from=, to=, [a=], [reverse=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Rotates children in various ways.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Rotation
|
|
||||||
// See Also: xrot(), yrot(), zrot()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// This is a shorthand version of the built-in `rotate()`, and operates similarly, with a few additional capabilities.
|
// This is a shorthand version of the built-in `rotate()`, and operates similarly, with a few additional capabilities.
|
||||||
// You can specify the rotation to perform in one of several ways:
|
// You can specify the rotation to perform in one of several ways:
|
||||||
|
@ -569,6 +569,11 @@ function rot(a=0, v, cp, from, to, reverse=false, p=_NO_ARG, _m) =
|
||||||
|
|
||||||
// Function&Module: xrot()
|
// Function&Module: xrot()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Rotates children around the X axis using the right-hand rule.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Rotation
|
||||||
|
// See Also: rot(), yrot(), zrot()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// xrot(a, [cp=]) CHILDREN;
|
// xrot(a, [cp=]) CHILDREN;
|
||||||
// Usage: As a function to rotate points
|
// Usage: As a function to rotate points
|
||||||
|
@ -576,11 +581,6 @@ function rot(a=0, v, cp, from, to, reverse=false, p=_NO_ARG, _m) =
|
||||||
// Usage: As a function to return rotation matrix
|
// Usage: As a function to return rotation matrix
|
||||||
// mat = xrot(a, [cp=]);
|
// mat = xrot(a, [cp=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Rotates children around the X axis using the right-hand rule.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Rotation
|
|
||||||
// See Also: rot(), yrot(), zrot()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Rotates around the X axis by the given number of degrees. If `cp` is given, rotations are performed around that centerpoint.
|
// Rotates around the X axis by the given number of degrees. If `cp` is given, rotations are performed around that centerpoint.
|
||||||
// * Called as a module, rotates all children.
|
// * Called as a module, rotates all children.
|
||||||
|
@ -617,6 +617,11 @@ function xrot(a=0, p=_NO_ARG, cp) = rot([a,0,0], cp=cp, p=p);
|
||||||
|
|
||||||
// Function&Module: yrot()
|
// Function&Module: yrot()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Rotates children around the Y axis using the right-hand rule.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Rotation
|
||||||
|
// See Also: rot(), xrot(), zrot()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// yrot(a, [cp=]) CHILDREN;
|
// yrot(a, [cp=]) CHILDREN;
|
||||||
// Usage: Rotate Points
|
// Usage: Rotate Points
|
||||||
|
@ -624,11 +629,6 @@ function xrot(a=0, p=_NO_ARG, cp) = rot([a,0,0], cp=cp, p=p);
|
||||||
// Usage: Get Rotation Matrix
|
// Usage: Get Rotation Matrix
|
||||||
// mat = yrot(a, [cp=]);
|
// mat = yrot(a, [cp=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Rotates children around the Y axis using the right-hand rule.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Rotation
|
|
||||||
// See Also: rot(), xrot(), zrot()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Rotates around the Y axis by the given number of degrees. If `cp` is given, rotations are performed around that centerpoint.
|
// Rotates around the Y axis by the given number of degrees. If `cp` is given, rotations are performed around that centerpoint.
|
||||||
// * Called as a module, rotates all children.
|
// * Called as a module, rotates all children.
|
||||||
|
@ -665,6 +665,11 @@ function yrot(a=0, p=_NO_ARG, cp) = rot([0,a,0], cp=cp, p=p);
|
||||||
|
|
||||||
// Function&Module: zrot()
|
// Function&Module: zrot()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Rotates children around the Z axis using the right-hand rule.
|
||||||
|
// Topics: Affine, Matrices, Transforms, Rotation
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// See Also: rot(), xrot(), yrot()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// zrot(a, [cp=]) CHILDREN;
|
// zrot(a, [cp=]) CHILDREN;
|
||||||
// Usage: As Function to rotate points
|
// Usage: As Function to rotate points
|
||||||
|
@ -672,11 +677,6 @@ function yrot(a=0, p=_NO_ARG, cp) = rot([0,a,0], cp=cp, p=p);
|
||||||
// Usage: As Function to return rotation matrix
|
// Usage: As Function to return rotation matrix
|
||||||
// mat = zrot(a, [cp=]);
|
// mat = zrot(a, [cp=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Rotates children around the Z axis using the right-hand rule.
|
|
||||||
// Topics: Affine, Matrices, Transforms, Rotation
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// See Also: rot(), xrot(), yrot()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Rotates around the Z axis by the given number of degrees. If `cp` is given, rotations are performed around that centerpoint.
|
// Rotates around the Z axis by the given number of degrees. If `cp` is given, rotations are performed around that centerpoint.
|
||||||
// * Called as a module, rotates all children.
|
// * Called as a module, rotates all children.
|
||||||
|
@ -718,6 +718,12 @@ function zrot(a=0, p=_NO_ARG, cp) = rot(a, cp=cp, p=p);
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: scale()
|
// Function&Module: scale()
|
||||||
|
//
|
||||||
|
// Synopsis: Scales children arbitrarily.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Scaling
|
||||||
|
// See Also: xscale(), yscale(), zscale()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// scale(SCALAR) CHILDREN;
|
// scale(SCALAR) CHILDREN;
|
||||||
// scale([X,Y,Z]) CHILDREN;
|
// scale([X,Y,Z]) CHILDREN;
|
||||||
|
@ -725,10 +731,7 @@ function zrot(a=0, p=_NO_ARG, cp) = rot(a, cp=cp, p=p);
|
||||||
// pts = scale(v, p, [cp=]);
|
// pts = scale(v, p, [cp=]);
|
||||||
// Usage: Get Scaling Matrix
|
// Usage: Get Scaling Matrix
|
||||||
// mat = scale(v, [cp=]);
|
// mat = scale(v, [cp=]);
|
||||||
// Synopsis: Scales children arbitrarily.
|
//
|
||||||
// Topics: Affine, Matrices, Transforms, Scaling
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// See Also: xscale(), yscale(), zscale()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Scales by the [X,Y,Z] scaling factors given in `v`. If `v` is given as a scalar number, all axes are scaled uniformly by that amount.
|
// Scales by the [X,Y,Z] scaling factors given in `v`. If `v` is given as a scalar number, all axes are scaled uniformly by that amount.
|
||||||
// * Called as the built-in module, scales all children.
|
// * Called as the built-in module, scales all children.
|
||||||
|
@ -738,17 +741,20 @@ function zrot(a=0, p=_NO_ARG, cp) = rot(a, cp=cp, p=p);
|
||||||
// * Called as a function with a [VNF structure](vnf.scad) in the `p` argument, returns the scaled VNF.
|
// * Called as a function with a [VNF structure](vnf.scad) in the `p` argument, returns the scaled VNF.
|
||||||
// * Called as a function without a `p` argument, and a 2D list of scaling factors in `v`, returns an affine2d scaling matrix.
|
// * Called as a function without a `p` argument, and a 2D list of scaling factors in `v`, returns an affine2d scaling matrix.
|
||||||
// * Called as a function without a `p` argument, and a 3D list of scaling factors in `v`, returns an affine3d scaling matrix.
|
// * Called as a function without a `p` argument, and a 3D list of scaling factors in `v`, returns an affine3d scaling matrix.
|
||||||
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// v = Either a numeric uniform scaling factor, or a list of [X,Y,Z] scaling factors. Default: 1
|
// v = Either a numeric uniform scaling factor, or a list of [X,Y,Z] scaling factors. Default: 1
|
||||||
// p = If called as a function, the point or list of points to scale.
|
// p = If called as a function, the point or list of points to scale.
|
||||||
// ---
|
// ---
|
||||||
// cp = If given, centers the scaling on the point `cp`.
|
// cp = If given, centers the scaling on the point `cp`.
|
||||||
|
//
|
||||||
// Example(NORENDER):
|
// Example(NORENDER):
|
||||||
// pt1 = scale(3, p=[3,1,4]); // Returns: [9,3,12]
|
// pt1 = scale(3, p=[3,1,4]); // Returns: [9,3,12]
|
||||||
// pt2 = scale([2,3,4], p=[3,1,4]); // Returns: [6,3,16]
|
// pt2 = scale([2,3,4], p=[3,1,4]); // Returns: [6,3,16]
|
||||||
// pt3 = scale([2,3,4], p=[[1,2,3],[4,5,6]]); // Returns: [[2,6,12], [8,15,24]]
|
// pt3 = scale([2,3,4], p=[[1,2,3],[4,5,6]]); // Returns: [[2,6,12], [8,15,24]]
|
||||||
// mat2d = scale([2,3]); // Returns: [[2,0,0],[0,3,0],[0,0,1]]
|
// mat2d = scale([2,3]); // Returns: [[2,0,0],[0,3,0],[0,0,1]]
|
||||||
// mat3d = scale([2,3,4]); // Returns: [[2,0,0,0],[0,3,0,0],[0,0,4,0],[0,0,0,1]]
|
// mat3d = scale([2,3,4]); // Returns: [[2,0,0,0],[0,3,0,0],[0,0,4,0],[0,0,0,1]]
|
||||||
|
//
|
||||||
// Example(2D):
|
// Example(2D):
|
||||||
// path = circle(d=50,$fn=12);
|
// path = circle(d=50,$fn=12);
|
||||||
// #stroke(path,closed=true);
|
// #stroke(path,closed=true);
|
||||||
|
@ -770,6 +776,11 @@ function scale(v=1, p=_NO_ARG, cp=[0,0,0]) =
|
||||||
|
|
||||||
// Function&Module: xscale()
|
// Function&Module: xscale()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Scales children along the X axis.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Scaling
|
||||||
|
// See Also: scale(), yscale(), zscale()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// xscale(x, [cp=]) CHILDREN;
|
// xscale(x, [cp=]) CHILDREN;
|
||||||
// Usage: Scale Points
|
// Usage: Scale Points
|
||||||
|
@ -777,11 +788,6 @@ function scale(v=1, p=_NO_ARG, cp=[0,0,0]) =
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = xscale(x, [cp=]);
|
// mat = xscale(x, [cp=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Scales children along the X axis.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Scaling
|
|
||||||
// See Also: scale(), yscale(), zscale()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Scales along the X axis by the scaling factor `x`.
|
// Scales along the X axis by the scaling factor `x`.
|
||||||
// * Called as the built-in module, scales all children.
|
// * Called as the built-in module, scales all children.
|
||||||
|
@ -826,6 +832,11 @@ function xscale(x=1, p=_NO_ARG, cp=0) =
|
||||||
|
|
||||||
// Function&Module: yscale()
|
// Function&Module: yscale()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Scales children along the Y axis.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Scaling
|
||||||
|
// See Also: scale(), xscale(), zscale()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// yscale(y, [cp=]) CHILDREN;
|
// yscale(y, [cp=]) CHILDREN;
|
||||||
// Usage: Scale Points
|
// Usage: Scale Points
|
||||||
|
@ -833,11 +844,6 @@ function xscale(x=1, p=_NO_ARG, cp=0) =
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = yscale(y, [cp=]);
|
// mat = yscale(y, [cp=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Scales children along the Y axis.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Scaling
|
|
||||||
// See Also: scale(), xscale(), zscale()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Scales along the Y axis by the scaling factor `y`.
|
// Scales along the Y axis by the scaling factor `y`.
|
||||||
// * Called as the built-in module, scales all children.
|
// * Called as the built-in module, scales all children.
|
||||||
|
@ -882,6 +888,11 @@ function yscale(y=1, p=_NO_ARG, cp=0) =
|
||||||
|
|
||||||
// Function&Module: zscale()
|
// Function&Module: zscale()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Scales children along the Z axis.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Scaling
|
||||||
|
// See Also: scale(), xscale(), yscale()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// zscale(z, [cp=]) CHILDREN;
|
// zscale(z, [cp=]) CHILDREN;
|
||||||
// Usage: Scale Points
|
// Usage: Scale Points
|
||||||
|
@ -889,11 +900,6 @@ function yscale(y=1, p=_NO_ARG, cp=0) =
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = zscale(z, [cp=]);
|
// mat = zscale(z, [cp=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Scales children along the Z axis.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Scaling
|
|
||||||
// See Also: scale(), xscale(), yscale()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Scales along the Z axis by the scaling factor `z`.
|
// Scales along the Z axis by the scaling factor `z`.
|
||||||
// * Called as the built-in module, scales all children.
|
// * Called as the built-in module, scales all children.
|
||||||
|
@ -941,16 +947,19 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// Function&Module: mirror()
|
// Function&Module: mirror()
|
||||||
|
//
|
||||||
|
// Synopsis: Reflects children across an arbitrary plane.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
||||||
|
// See Also: xflip(), yflip(), zflip()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// mirror(v) CHILDREN;
|
// mirror(v) CHILDREN;
|
||||||
// Usage: As Function
|
// Usage: As Function
|
||||||
// pt = mirror(v, p);
|
// pt = mirror(v, p);
|
||||||
// Usage: Get Reflection/Mirror Matrix
|
// Usage: Get Reflection/Mirror Matrix
|
||||||
// mat = mirror(v);
|
// mat = mirror(v);
|
||||||
// Synopsis: Reflects children across an arbitrary plane.
|
//
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
|
||||||
// See Also: xflip(), yflip(), zflip()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Mirrors/reflects across the plane or line whose normal vector is given in `v`.
|
// Mirrors/reflects across the plane or line whose normal vector is given in `v`.
|
||||||
// * Called as the built-in module, mirrors all children across the line/plane.
|
// * Called as the built-in module, mirrors all children across the line/plane.
|
||||||
|
@ -960,9 +969,11 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
// * Called as a function with a [VNF structure](vnf.scad) in the `p` argument, returns the mirrored VNF.
|
// * Called as a function with a [VNF structure](vnf.scad) in the `p` argument, returns the mirrored VNF.
|
||||||
// * Called as a function without a `p` argument, and with a 2D normal vector `v`, returns the affine2d 3x3 mirror matrix.
|
// * Called as a function without a `p` argument, and with a 2D normal vector `v`, returns the affine2d 3x3 mirror matrix.
|
||||||
// * Called as a function without a `p` argument, and with a 3D normal vector `v`, returns the affine3d 4x4 mirror matrix.
|
// * Called as a function without a `p` argument, and with a 3D normal vector `v`, returns the affine3d 4x4 mirror matrix.
|
||||||
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// v = The normal vector of the line or plane to mirror across.
|
// v = The normal vector of the line or plane to mirror across.
|
||||||
// p = If called as a function, the point or list of points to scale.
|
// p = If called as a function, the point or list of points to scale.
|
||||||
|
//
|
||||||
// Example:
|
// Example:
|
||||||
// n = [1,0,0];
|
// n = [1,0,0];
|
||||||
// module obj() right(20) rotate([0,15,-15]) cube([40,30,20]);
|
// module obj() right(20) rotate([0,15,-15]) cube([40,30,20]);
|
||||||
|
@ -972,6 +983,7 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
// color("red") anchor_arrow(s=20, flag=false);
|
// color("red") anchor_arrow(s=20, flag=false);
|
||||||
// color("#7777") cube([75,75,0.1], center=true);
|
// color("#7777") cube([75,75,0.1], center=true);
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
// Example:
|
// Example:
|
||||||
// n = [1,1,0];
|
// n = [1,1,0];
|
||||||
// module obj() right(20) rotate([0,15,-15]) cube([40,30,20]);
|
// module obj() right(20) rotate([0,15,-15]) cube([40,30,20]);
|
||||||
|
@ -981,6 +993,7 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
// color("red") anchor_arrow(s=20, flag=false);
|
// color("red") anchor_arrow(s=20, flag=false);
|
||||||
// color("#7777") cube([75,75,0.1], center=true);
|
// color("#7777") cube([75,75,0.1], center=true);
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
// Example:
|
// Example:
|
||||||
// n = [1,1,1];
|
// n = [1,1,1];
|
||||||
// module obj() right(20) rotate([0,15,-15]) cube([40,30,20]);
|
// module obj() right(20) rotate([0,15,-15]) cube([40,30,20]);
|
||||||
|
@ -990,6 +1003,7 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
// color("red") anchor_arrow(s=20, flag=false);
|
// color("red") anchor_arrow(s=20, flag=false);
|
||||||
// color("#7777") cube([75,75,0.1], center=true);
|
// color("#7777") cube([75,75,0.1], center=true);
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
// Example(2D):
|
// Example(2D):
|
||||||
// n = [0,1];
|
// n = [0,1];
|
||||||
// path = rot(30, p=square([50,30]));
|
// path = rot(30, p=square([50,30]));
|
||||||
|
@ -997,6 +1011,7 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
// color("red") stroke([[0,0],10*n],endcap2="arrow2");
|
// color("red") stroke([[0,0],10*n],endcap2="arrow2");
|
||||||
// #stroke(path,closed=true);
|
// #stroke(path,closed=true);
|
||||||
// stroke(mirror(n, p=path),closed=true);
|
// stroke(mirror(n, p=path),closed=true);
|
||||||
|
//
|
||||||
// Example(2D):
|
// Example(2D):
|
||||||
// n = [1,1];
|
// n = [1,1];
|
||||||
// path = rot(30, p=square([50,30]));
|
// path = rot(30, p=square([50,30]));
|
||||||
|
@ -1004,6 +1019,7 @@ function zscale(z=1, p=_NO_ARG, cp=0) =
|
||||||
// color("red") stroke([[0,0],10*n],endcap2="arrow2");
|
// color("red") stroke([[0,0],10*n],endcap2="arrow2");
|
||||||
// #stroke(path,closed=true);
|
// #stroke(path,closed=true);
|
||||||
// stroke(mirror(n, p=path),closed=true);
|
// stroke(mirror(n, p=path),closed=true);
|
||||||
|
//
|
||||||
function mirror(v, p=_NO_ARG) =
|
function mirror(v, p=_NO_ARG) =
|
||||||
assert(is_vector(v))
|
assert(is_vector(v))
|
||||||
assert(p==_NO_ARG || is_list(p),"Invalid pointlist")
|
assert(p==_NO_ARG || is_list(p),"Invalid pointlist")
|
||||||
|
@ -1013,6 +1029,11 @@ function mirror(v, p=_NO_ARG) =
|
||||||
|
|
||||||
// Function&Module: xflip()
|
// Function&Module: xflip()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Reflects children across the YZ plane.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
||||||
|
// See Also: mirror(), yflip(), zflip()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// xflip([x=]) CHILDREN;
|
// xflip([x=]) CHILDREN;
|
||||||
// Usage: As Function
|
// Usage: As Function
|
||||||
|
@ -1020,11 +1041,6 @@ function mirror(v, p=_NO_ARG) =
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = xflip([x=]);
|
// mat = xflip([x=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Reflects children across the YZ plane.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
|
||||||
// See Also: mirror(), yflip(), zflip()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Mirrors/reflects across the origin [0,0,0], along the X axis. If `x` is given, reflects across [x,0,0] instead.
|
// Mirrors/reflects across the origin [0,0,0], along the X axis. If `x` is given, reflects across [x,0,0] instead.
|
||||||
// * Called as the built-in module, mirrors all children across the line/plane.
|
// * Called as the built-in module, mirrors all children across the line/plane.
|
||||||
|
@ -1069,6 +1085,11 @@ function xflip(p=_NO_ARG, x=0) =
|
||||||
|
|
||||||
// Function&Module: yflip()
|
// Function&Module: yflip()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Reflects children across the XZ plane.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
||||||
|
// See Also: mirror(), xflip(), zflip()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// yflip([y=]) CHILDREN;
|
// yflip([y=]) CHILDREN;
|
||||||
// Usage: As Function
|
// Usage: As Function
|
||||||
|
@ -1076,11 +1097,6 @@ function xflip(p=_NO_ARG, x=0) =
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = yflip([y=]);
|
// mat = yflip([y=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Reflects children across the XZ plane.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
|
||||||
// See Also: mirror(), xflip(), zflip()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Mirrors/reflects across the origin [0,0,0], along the Y axis. If `y` is given, reflects across [0,y,0] instead.
|
// Mirrors/reflects across the origin [0,0,0], along the Y axis. If `y` is given, reflects across [0,y,0] instead.
|
||||||
// * Called as the built-in module, mirrors all children across the line/plane.
|
// * Called as the built-in module, mirrors all children across the line/plane.
|
||||||
|
@ -1125,6 +1141,11 @@ function yflip(p=_NO_ARG, y=0) =
|
||||||
|
|
||||||
// Function&Module: zflip()
|
// Function&Module: zflip()
|
||||||
//
|
//
|
||||||
|
// Synopsis: Reflects children across the XY plane.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
||||||
|
// See Also: mirror(), xflip(), yflip()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// zflip([z=]) CHILDREN;
|
// zflip([z=]) CHILDREN;
|
||||||
// Usage: As Function
|
// Usage: As Function
|
||||||
|
@ -1132,11 +1153,6 @@ function yflip(p=_NO_ARG, y=0) =
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = zflip([z=]);
|
// mat = zflip([z=]);
|
||||||
//
|
//
|
||||||
// Synopsis: Reflects children across the XY plane.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Reflection, Mirroring
|
|
||||||
// See Also: mirror(), xflip(), yflip()
|
|
||||||
//
|
|
||||||
// Description:
|
// Description:
|
||||||
// Mirrors/reflects across the origin [0,0,0], along the Z axis. If `z` is given, reflects across [0,0,z] instead.
|
// Mirrors/reflects across the origin [0,0,0], along the Z axis. If `z` is given, reflects across [0,0,z] instead.
|
||||||
// * Called as the built-in module, mirrors all children across the line/plane.
|
// * Called as the built-in module, mirrors all children across the line/plane.
|
||||||
|
@ -1180,6 +1196,12 @@ function zflip(p=_NO_ARG, z=0) =
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// Function&Module: frame_map()
|
// Function&Module: frame_map()
|
||||||
|
//
|
||||||
|
// Synopsis: Rotates and possibly skews children from one frame of reference to another.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Rotation
|
||||||
|
// See Also: rot(), xrot(), yrot(), zrot()
|
||||||
|
//
|
||||||
// Usage: As module
|
// Usage: As module
|
||||||
// frame_map(v1, v2, v3, [reverse=]) CHILDREN;
|
// frame_map(v1, v2, v3, [reverse=]) CHILDREN;
|
||||||
// Usage: As function to remap points
|
// Usage: As function to remap points
|
||||||
|
@ -1189,10 +1211,7 @@ function zflip(p=_NO_ARG, z=0) =
|
||||||
// map = frame_map(x=VECTOR1, y=VECTOR2, [reverse=]);
|
// map = frame_map(x=VECTOR1, y=VECTOR2, [reverse=]);
|
||||||
// map = frame_map(x=VECTOR1, z=VECTOR2, [reverse=]);
|
// map = frame_map(x=VECTOR1, z=VECTOR2, [reverse=]);
|
||||||
// map = frame_map(y=VECTOR1, z=VECTOR2, [reverse=]);
|
// map = frame_map(y=VECTOR1, z=VECTOR2, [reverse=]);
|
||||||
// Synopsis: Rotates and possibly skews children from one frame of reference to another.
|
//
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
// Topics: Affine, Matrices, Transforms, Rotation
|
|
||||||
// See Also: rot(), xrot(), yrot(), zrot()
|
|
||||||
// Description:
|
// Description:
|
||||||
// Maps one coordinate frame to another. You must specify two or
|
// 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, so if you
|
// three of `x`, `y`, and `z`. The specified axes are mapped to the vectors you supplied, so if you
|
||||||
|
@ -1204,19 +1223,24 @@ function zflip(p=_NO_ARG, z=0) =
|
||||||
// You cannot use the `reverse` option with non-orthogonal inputs. Note that only the direction
|
// You cannot use the `reverse` option with non-orthogonal inputs. Note that only the direction
|
||||||
// of the specified vectors matters: the transformation will not apply scaling, though it can
|
// of the specified vectors matters: the transformation will not apply scaling, though it can
|
||||||
// skew if your provide non-orthogonal axes.
|
// skew if your provide non-orthogonal axes.
|
||||||
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// x = Destination 3D vector for x axis.
|
// x = Destination 3D vector for x axis.
|
||||||
// y = Destination 3D vector for y axis.
|
// y = Destination 3D vector for y axis.
|
||||||
// z = Destination 3D vector for z axis.
|
// z = Destination 3D vector for z axis.
|
||||||
// p = If given, the point, path, patch, or VNF to operate on. Function use only.
|
// p = If given, the point, path, patch, or VNF to operate on. Function use only.
|
||||||
// reverse = reverse direction of the map for orthogonal inputs. Default: false
|
// reverse = reverse direction of the map for orthogonal inputs. Default: false
|
||||||
|
//
|
||||||
// Example: Remap axes after linear extrusion
|
// Example: Remap axes after linear extrusion
|
||||||
// frame_map(x=[0,1,0], y=[0,0,1]) linear_extrude(height=10) square(3);
|
// frame_map(x=[0,1,0], y=[0,0,1]) linear_extrude(height=10) square(3);
|
||||||
|
//
|
||||||
// Example: This map is just a rotation around the z axis
|
// Example: This map is just a rotation around the z axis
|
||||||
// mat = frame_map(x=[1,1,0], y=[-1,1,0]);
|
// mat = frame_map(x=[1,1,0], y=[-1,1,0]);
|
||||||
// multmatrix(mat) frame_ref();
|
// multmatrix(mat) frame_ref();
|
||||||
|
//
|
||||||
// Example: This map is not a rotation because x and y aren't orthogonal
|
// Example: This map is not a rotation because x and y aren't orthogonal
|
||||||
// frame_map(x=[1,0,0], y=[1,1,0]) cube(10);
|
// frame_map(x=[1,0,0], y=[1,1,0]) cube(10);
|
||||||
|
//
|
||||||
// Example: This sends [1,1,0] to [0,1,1] and [-1,1,0] to [0,-1,1]. (Original directions shown in light shade, final directions shown dark.)
|
// Example: This sends [1,1,0] to [0,1,1] and [-1,1,0] to [0,-1,1]. (Original directions shown in light shade, final directions shown dark.)
|
||||||
// mat = frame_map(x=[0,1,1], y=[0,-1,1]) * frame_map(x=[1,1,0], y=[-1,1,0],reverse=true);
|
// mat = frame_map(x=[0,1,1], y=[0,-1,1]) * frame_map(x=[1,1,0], y=[-1,1,0],reverse=true);
|
||||||
// color("purple",alpha=.2) stroke([[0,0,0],10*[1,1,0]]);
|
// color("purple",alpha=.2) stroke([[0,0,0],10*[1,1,0]]);
|
||||||
|
@ -1225,6 +1249,7 @@ function zflip(p=_NO_ARG, z=0) =
|
||||||
// color("purple") stroke([[0,0,0],10*[1,1,0]]);
|
// color("purple") stroke([[0,0,0],10*[1,1,0]]);
|
||||||
// color("green") stroke([[0,0,0],10*[-1,1,0]]);
|
// color("green") stroke([[0,0,0],10*[-1,1,0]]);
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
function frame_map(x,y,z, p=_NO_ARG, reverse=false) =
|
function frame_map(x,y,z, p=_NO_ARG, reverse=false) =
|
||||||
p != _NO_ARG
|
p != _NO_ARG
|
||||||
? apply(frame_map(x,y,z,reverse=reverse), p)
|
? apply(frame_map(x,y,z,reverse=reverse), p)
|
||||||
|
@ -1270,15 +1295,18 @@ module frame_map(x,y,z,p,reverse=false)
|
||||||
|
|
||||||
|
|
||||||
// Function&Module: skew()
|
// Function&Module: skew()
|
||||||
|
//
|
||||||
|
// Synopsis: Skews children along various axes.
|
||||||
|
// SynTags: Trans, Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms, Skewing
|
||||||
|
// See Also: move(), rot(), scale()
|
||||||
|
//
|
||||||
// Usage: As Module
|
// Usage: As Module
|
||||||
// skew([sxy=]|[axy=], [sxz=]|[axz=], [syx=]|[ayx=], [syz=]|[ayz=], [szx=]|[azx=], [szy=]|[azy=]) CHILDREN;
|
// skew([sxy=]|[axy=], [sxz=]|[axz=], [syx=]|[ayx=], [syz=]|[ayz=], [szx=]|[azx=], [szy=]|[azy=]) CHILDREN;
|
||||||
// Usage: As Function
|
// Usage: As Function
|
||||||
// pts = skew(p, [sxy=]|[axy=], [sxz=]|[axz=], [syx=]|[ayx=], [syz=]|[ayz=], [szx=]|[azx=], [szy=]|[azy=]);
|
// pts = skew(p, [sxy=]|[axy=], [sxz=]|[axz=], [syx=]|[ayx=], [syz=]|[ayz=], [szx=]|[azx=], [szy=]|[azy=]);
|
||||||
// Usage: Get Affine Matrix
|
// Usage: Get Affine Matrix
|
||||||
// mat = skew([sxy=]|[axy=], [sxz=]|[axz=], [syx=]|[ayx=], [syz=]|[ayz=], [szx=]|[azx=], [szy=]|[azy=]);
|
// mat = skew([sxy=]|[axy=], [sxz=]|[axz=], [syx=]|[ayx=], [syz=]|[ayz=], [szx=]|[azx=], [szy=]|[azy=]);
|
||||||
// Topics: Affine, Matrices, Transforms, Skewing
|
|
||||||
// Synopsis: Skews children along various axes.
|
|
||||||
// SynTags: Trans, Path, VNF, Mat
|
|
||||||
//
|
//
|
||||||
// Description:
|
// Description:
|
||||||
// Skews geometry by the given skew factors.
|
// Skews geometry by the given skew factors.
|
||||||
|
@ -1399,11 +1427,15 @@ function is_2d_transform(t) = // z-parameters are zero, except we allow t[2][
|
||||||
|
|
||||||
|
|
||||||
// Function: apply()
|
// Function: apply()
|
||||||
|
//
|
||||||
|
// Synopsis: Applies a transformation matrix to a point, list of points, array of points, or a VNF.
|
||||||
|
// SynTags: Path, VNF, Mat
|
||||||
|
// Topics: Affine, Matrices, Transforms
|
||||||
|
// See Also: move(), rot(), scale(), skew()
|
||||||
|
//
|
||||||
// Usage:
|
// Usage:
|
||||||
// pts = apply(transform, points);
|
// pts = apply(transform, points);
|
||||||
// Topics: Affine, Matrices, Transforms
|
//
|
||||||
// Synopsis: Applies a transformation matrix to a point, list of points, array of points, or VNF.
|
|
||||||
// SynTags: Path, VNF, Mat
|
|
||||||
// Description:
|
// Description:
|
||||||
// Applies the specified transformation matrix `transform` to a point, point list, bezier patch or VNF.
|
// Applies the specified transformation matrix `transform` to a point, point list, bezier patch or VNF.
|
||||||
// When `points` contains 2D or 3D points the transform matrix may be a 4x4 affine matrix or a 3x4
|
// When `points` contains 2D or 3D points the transform matrix may be a 4x4 affine matrix or a 3x4
|
||||||
|
@ -1418,27 +1450,32 @@ function is_2d_transform(t) = // z-parameters are zero, except we allow t[2][
|
||||||
// If the transform matrix is square then apply() checks the determinant and if it is negative, apply() reverses the face order so that
|
// If the transform matrix is square then apply() checks the determinant and if it is negative, apply() reverses the face order so that
|
||||||
// the transformed VNF has faces with the same winding direction as the original VNF. This adjustment applies
|
// the transformed VNF has faces with the same winding direction as the original VNF. This adjustment applies
|
||||||
// only to VNFs, not to beziers or point lists.
|
// only to VNFs, not to beziers or point lists.
|
||||||
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// transform = The 2D (3x3 or 2x3) or 3D (4x4 or 3x4) transformation matrix to apply.
|
// transform = The 2D (3x3 or 2x3) or 3D (4x4 or 3x4) transformation matrix to apply.
|
||||||
// points = The point, point list, bezier patch, or VNF to apply the transformation to.
|
// points = The point, point list, bezier patch, or VNF to apply the transformation to.
|
||||||
|
//
|
||||||
// Example(3D):
|
// Example(3D):
|
||||||
// path1 = path3d(circle(r=40));
|
// path1 = path3d(circle(r=40));
|
||||||
// tmat = xrot(45);
|
// tmat = xrot(45);
|
||||||
// path2 = apply(tmat, path1);
|
// path2 = apply(tmat, path1);
|
||||||
// #stroke(path1,closed=true);
|
// #stroke(path1,closed=true);
|
||||||
// stroke(path2,closed=true);
|
// stroke(path2,closed=true);
|
||||||
|
//
|
||||||
// Example(2D):
|
// Example(2D):
|
||||||
// path1 = circle(r=40);
|
// path1 = circle(r=40);
|
||||||
// tmat = translate([10,5]);
|
// tmat = translate([10,5]);
|
||||||
// path2 = apply(tmat, path1);
|
// path2 = apply(tmat, path1);
|
||||||
// #stroke(path1,closed=true);
|
// #stroke(path1,closed=true);
|
||||||
// stroke(path2,closed=true);
|
// stroke(path2,closed=true);
|
||||||
|
//
|
||||||
// Example(2D):
|
// Example(2D):
|
||||||
// path1 = circle(r=40);
|
// path1 = circle(r=40);
|
||||||
// tmat = rot(30) * back(15) * scale([1.5,0.5,1]);
|
// tmat = rot(30) * back(15) * scale([1.5,0.5,1]);
|
||||||
// path2 = apply(tmat, path1);
|
// path2 = apply(tmat, path1);
|
||||||
// #stroke(path1,closed=true);
|
// #stroke(path1,closed=true);
|
||||||
// stroke(path2,closed=true);
|
// stroke(path2,closed=true);
|
||||||
|
//
|
||||||
function apply(transform,points) =
|
function apply(transform,points) =
|
||||||
points==[] ? []
|
points==[] ? []
|
||||||
: is_vector(points) ? _apply(transform, [points])[0] // point
|
: is_vector(points) ? _apply(transform, [points])[0] // point
|
||||||
|
|
|
@ -11,7 +11,9 @@
|
||||||
|
|
||||||
// Module: manfrotto_rc2_plate()
|
// Module: manfrotto_rc2_plate()
|
||||||
// Synopsis: Creates a Manfrotto RC2 tripod quick release mount plate.
|
// Synopsis: Creates a Manfrotto RC2 tripod quick release mount plate.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Parts
|
// Topics: Parts
|
||||||
|
// See Also: threaded_rod()
|
||||||
// Usage:
|
// Usage:
|
||||||
// manfrotto_rc2_plate([chamfer],[anchor],[orient],[spin]) [ATTACHMENTS];
|
// manfrotto_rc2_plate([chamfer],[anchor],[orient],[spin]) [ATTACHMENTS];
|
||||||
// Description:
|
// Description:
|
||||||
|
|
|
@ -21,10 +21,13 @@ function _rotpart(T) = [for(i=[0:3]) [for(j=[0:3]) j<3 || i==3 ? T[i][j] : 0]];
|
||||||
|
|
||||||
// Function: turtle3d()
|
// Function: turtle3d()
|
||||||
// Synopsis: Extends [turtle graphics](https://en.wikipedia.org/wiki/Turtle_graphics) to 3d. Generates a 3D path or returns a list of transforms.
|
// Synopsis: Extends [turtle graphics](https://en.wikipedia.org/wiki/Turtle_graphics) to 3d. Generates a 3D path or returns a list of transforms.
|
||||||
|
// SynTags: MatList, Path
|
||||||
// Topics: Shapes (3D), Path Generators (3D), Mini-Language
|
// Topics: Shapes (3D), Path Generators (3D), Mini-Language
|
||||||
// See Also: turtle()
|
// See Also: turtle()
|
||||||
// Usage:
|
// Usage:
|
||||||
// turtle3d(commands, [state], [transforms], [full_state], [repeat])
|
// path = turtle3d(commands, [state=], [repeat=]);
|
||||||
|
// mats = turtle3d(commands, transforms=true, [state=], [repeat=]);
|
||||||
|
// state = turtle3d(commands, full_state=true, [state=], [repeat=]);
|
||||||
// Description:
|
// Description:
|
||||||
// Like the classic two dimensional turtle, the 3d turtle flies through space following a sequence
|
// Like the classic two dimensional turtle, the 3d turtle flies through space following a sequence
|
||||||
// of turtle graphics commands to generate either a sequence of transformations (suitable for input
|
// of turtle graphics commands to generate either a sequence of transformations (suitable for input
|
||||||
|
|
18
utility.scad
18
utility.scad
|
@ -73,10 +73,11 @@ function is_type(x,types) =
|
||||||
|
|
||||||
|
|
||||||
// Function: is_def()
|
// Function: is_def()
|
||||||
// Usage:
|
// Synopsis: Returns true if `x` is not `undef`.
|
||||||
// bool = is_def(x);
|
|
||||||
// Topics: Type Checking
|
// Topics: Type Checking
|
||||||
// See Also: typeof(), is_type(), is_str()
|
// See Also: typeof(), is_type(), is_str()
|
||||||
|
// Usage:
|
||||||
|
// bool = is_def(x);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns true if `x` is not `undef`. False if `x==undef`.
|
// Returns true if `x` is not `undef`. False if `x==undef`.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -108,8 +109,8 @@ function is_str(x) = is_string(x);
|
||||||
|
|
||||||
|
|
||||||
// Function: is_int()
|
// Function: is_int()
|
||||||
// Synopsis: Returns true if the argument is an integer.
|
|
||||||
// Alias: is_integer()
|
// Alias: is_integer()
|
||||||
|
// Synopsis: Returns true if the argument is an integer.
|
||||||
// Topics: Type Checking
|
// Topics: Type Checking
|
||||||
// See Also: typeof(), is_type(), is_str(), is_def()
|
// See Also: typeof(), is_type(), is_str(), is_def()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -197,10 +198,10 @@ function is_finite(x) = is_num(x) && !is_nan(0*x);
|
||||||
|
|
||||||
// Function: is_range()
|
// Function: is_range()
|
||||||
// Synopsis: Returns true if the argument is a range.
|
// Synopsis: Returns true if the argument is a range.
|
||||||
// Usage:
|
|
||||||
// bool = is_range(x);
|
|
||||||
// Topics: Type Checking
|
// Topics: Type Checking
|
||||||
// See Also: typeof(), is_type(), is_str(), is_def(), is_int()
|
// See Also: typeof(), is_type(), is_str(), is_def(), is_int()
|
||||||
|
// Usage:
|
||||||
|
// bool = is_range(x);
|
||||||
// Description:
|
// Description:
|
||||||
// Returns true if its argument is a range
|
// Returns true if its argument is a range
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
@ -768,6 +769,7 @@ function scalar_vec3(v, dflt) =
|
||||||
// Function: segs()
|
// Function: segs()
|
||||||
// Synopsis: Returns the number of sides for a circle given `$fn`, `$fa`, and `$fs`.
|
// Synopsis: Returns the number of sides for a circle given `$fn`, `$fa`, and `$fs`.
|
||||||
// Topics: Geometry
|
// Topics: Geometry
|
||||||
|
// See Also: circle(), cyl()
|
||||||
// Usage:
|
// Usage:
|
||||||
// sides = segs(r);
|
// sides = segs(r);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -831,10 +833,10 @@ module req_children(count) {
|
||||||
|
|
||||||
// Function: no_function()
|
// Function: no_function()
|
||||||
// Synopsis: Assert that the argument exists only as a module and not as a function.
|
// Synopsis: Assert that the argument exists only as a module and not as a function.
|
||||||
// Usage:
|
|
||||||
// dummy = no_function(name)
|
|
||||||
// Topics: Error Checking
|
// Topics: Error Checking
|
||||||
// See Also: no_children(), no_module()
|
// See Also: no_children(), no_module()
|
||||||
|
// Usage:
|
||||||
|
// dummy = no_function(name)
|
||||||
// Description:
|
// Description:
|
||||||
// Asserts that the function, "name", only exists as a module.
|
// Asserts that the function, "name", only exists as a module.
|
||||||
// Example:
|
// Example:
|
||||||
|
@ -860,6 +862,8 @@ module no_module() {
|
||||||
|
|
||||||
// Module: deprecate()
|
// Module: deprecate()
|
||||||
// Synopsis: Display a console note that a module is deprecated and suggest a replacement.
|
// Synopsis: Display a console note that a module is deprecated and suggest a replacement.
|
||||||
|
// Topics: Error Checking
|
||||||
|
// See Also: no_function(), no_module()
|
||||||
// Usage:
|
// Usage:
|
||||||
// deprecate(new_name);
|
// deprecate(new_name);
|
||||||
// Description:
|
// Description:
|
||||||
|
|
|
@ -339,7 +339,7 @@ function vector_bisect(v1,v2) =
|
||||||
let(
|
let(
|
||||||
axis = vector_axis(v1,v2),
|
axis = vector_axis(v1,v2),
|
||||||
ang = vector_angle(v1,v2),
|
ang = vector_angle(v1,v2),
|
||||||
v3 = rot(ang/2, v=axis, p=v1)
|
v3 = unit(rot(ang/2, v=axis, p=v1))
|
||||||
) v3;
|
) v3;
|
||||||
|
|
||||||
|
|
||||||
|
|
22
vnf.scad
22
vnf.scad
|
@ -29,6 +29,7 @@ EMPTY_VNF = [[],[]]; // The standard empty VNF with no vertices or faces.
|
||||||
|
|
||||||
// Function: vnf_vertex_array()
|
// Function: vnf_vertex_array()
|
||||||
// Synopsis: Returns a VNF structure from a rectangular vertex list.
|
// Synopsis: Returns a VNF structure from a rectangular vertex list.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Generators, Lists
|
// Topics: VNF Generators, Lists
|
||||||
// See Also: vnf_tri_array(), vnf_join(), vnf_from_polygons(), vnf_from_region()
|
// See Also: vnf_tri_array(), vnf_join(), vnf_from_polygons(), vnf_from_region()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -232,6 +233,7 @@ function vnf_vertex_array(
|
||||||
|
|
||||||
// Function: vnf_tri_array()
|
// Function: vnf_tri_array()
|
||||||
// Synopsis: Returns a VNF from an array of points.
|
// Synopsis: Returns a VNF from an array of points.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Generators, Lists
|
// Topics: VNF Generators, Lists
|
||||||
// See Also: vnf_vertex_array(), vnf_join(), vnf_from_polygons(), vnf_from_region()
|
// See Also: vnf_vertex_array(), vnf_join(), vnf_from_polygons(), vnf_from_region()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -327,6 +329,7 @@ function vnf_tri_array(points, row_wrap=false, reverse=false) =
|
||||||
|
|
||||||
// Function: vnf_join()
|
// Function: vnf_join()
|
||||||
// Synopsis: Returns a single VNF structure from a list of VNF structures.
|
// Synopsis: Returns a single VNF structure from a list of VNF structures.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Generators, Lists
|
// Topics: VNF Generators, Lists
|
||||||
// See Also: vnf_tri_array(), vnf_vertex_array(), vnf_from_polygons(), vnf_from_region()
|
// See Also: vnf_tri_array(), vnf_vertex_array(), vnf_from_polygons(), vnf_from_region()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -413,6 +416,7 @@ function vnf_join(vnfs) =
|
||||||
|
|
||||||
// Function: vnf_from_polygons()
|
// Function: vnf_from_polygons()
|
||||||
// Synopsis: Returns a VNF from a list of 3D polygons.
|
// Synopsis: Returns a VNF from a list of 3D polygons.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Generators, Lists
|
// Topics: VNF Generators, Lists
|
||||||
// See Also: vnf_tri_array(), vnf_join(), vnf_vertex_array(), vnf_from_region()
|
// See Also: vnf_tri_array(), vnf_join(), vnf_vertex_array(), vnf_from_region()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -579,8 +583,9 @@ function _bridge(pt, outer,eps) =
|
||||||
|
|
||||||
|
|
||||||
// Function: vnf_from_region()
|
// Function: vnf_from_region()
|
||||||
// Topics: VNF Generators, Lists
|
|
||||||
// Synopsis: Returns a 3D VNF given a 2D region.
|
// Synopsis: Returns a 3D VNF given a 2D region.
|
||||||
|
// SynTags: VNF
|
||||||
|
// Topics: VNF Generators, Lists
|
||||||
// See Also: vnf_vertex_array(), vnf_tri_array(), vnf_join(), vnf_from_polygons()
|
// See Also: vnf_vertex_array(), vnf_tri_array(), vnf_join(), vnf_from_polygons()
|
||||||
// Usage:
|
// Usage:
|
||||||
// vnf = vnf_from_region(region, [transform], [reverse]);
|
// vnf = vnf_from_region(region, [transform], [reverse]);
|
||||||
|
@ -672,6 +677,7 @@ function vnf_faces(vnf) = vnf[1];
|
||||||
|
|
||||||
// Function: vnf_reverse_faces()
|
// Function: vnf_reverse_faces()
|
||||||
// Synopsis: Reverses the faces of a VNF.
|
// Synopsis: Reverses the faces of a VNF.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_quantize(), vnf_merge_points(), vnf_drop_unused_points(), vnf_triangulate(), vnf_slice()
|
// See Also: vnf_quantize(), vnf_merge_points(), vnf_drop_unused_points(), vnf_triangulate(), vnf_slice()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -684,6 +690,7 @@ function vnf_reverse_faces(vnf) =
|
||||||
|
|
||||||
// Function: vnf_quantize()
|
// Function: vnf_quantize()
|
||||||
// Synopsis: Quantizes the vertex coordinates of a VNF.
|
// Synopsis: Quantizes the vertex coordinates of a VNF.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_reverse_faces(), vnf_merge_points(), vnf_drop_unused_points(), vnf_triangulate(), vnf_slice()
|
// See Also: vnf_reverse_faces(), vnf_merge_points(), vnf_drop_unused_points(), vnf_triangulate(), vnf_slice()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -699,7 +706,8 @@ function vnf_quantize(vnf,q=pow(2,-12)) =
|
||||||
|
|
||||||
|
|
||||||
// Function: vnf_merge_points()
|
// Function: vnf_merge_points()
|
||||||
// Synopsis: COnsolidates duplicate vertices of a VNF.
|
// Synopsis: Consolidates duplicate vertices of a VNF.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_drop_unused_points(), vnf_triangulate(), vnf_slice()
|
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_drop_unused_points(), vnf_triangulate(), vnf_slice()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -735,6 +743,7 @@ function vnf_merge_points(vnf,eps=EPSILON) =
|
||||||
|
|
||||||
// Function: vnf_drop_unused_points()
|
// Function: vnf_drop_unused_points()
|
||||||
// Synopsis: Removes unreferenced vertices from a VNF.
|
// Synopsis: Removes unreferenced vertices from a VNF.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_merge_points(), vnf_triangulate(), vnf_slice()
|
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_merge_points(), vnf_triangulate(), vnf_slice()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -766,6 +775,7 @@ function _link_indicator(l,imin,imax) =
|
||||||
|
|
||||||
// Function: vnf_triangulate()
|
// Function: vnf_triangulate()
|
||||||
// Synopsis: Triangulates the faces of a VNF.
|
// Synopsis: Triangulates the faces of a VNF.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_merge_points(), vnf_drop_unused_points(), vnf_slice()
|
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_merge_points(), vnf_drop_unused_points(), vnf_slice()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -809,6 +819,7 @@ function _vnf_sort_vertices(vnf, idx=[2,1,0]) =
|
||||||
|
|
||||||
// Function: vnf_slice()
|
// Function: vnf_slice()
|
||||||
// Synopsis: Slice the faces of a VNF along an axis.
|
// Synopsis: Slice the faces of a VNF along an axis.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_merge_points(), vnf_drop_unused_points(), vnf_triangulate()
|
// See Also: vnf_reverse_faces(), vnf_quantize(), vnf_merge_points(), vnf_drop_unused_points(), vnf_triangulate()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -937,6 +948,7 @@ function _slice_3dpolygons(polys, dir, cuts) =
|
||||||
|
|
||||||
// Module: vnf_polyhedron()
|
// Module: vnf_polyhedron()
|
||||||
// Synopsis: Returns a polyhedron from a VNF or list of VNFs.
|
// Synopsis: Returns a polyhedron from a VNF or list of VNFs.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_wireframe()
|
// See Also: vnf_wireframe()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -970,6 +982,7 @@ module vnf_polyhedron(vnf, convexity=2, extent=true, cp="centroid", anchor="orig
|
||||||
|
|
||||||
// Module: vnf_wireframe()
|
// Module: vnf_wireframe()
|
||||||
// Synopsis: Creates a wireframe model from a VNF.
|
// Synopsis: Creates a wireframe model from a VNF.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_polyhedron()
|
// See Also: vnf_polyhedron()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1082,9 +1095,9 @@ function _vnf_centroid(vnf,eps=EPSILON) =
|
||||||
|
|
||||||
// Function: vnf_halfspace()
|
// Function: vnf_halfspace()
|
||||||
// Synopsis: Returns the intersection of the vnf with a half space.
|
// Synopsis: Returns the intersection of the vnf with a half space.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_volume(), vnf_area(), vnf_bend()
|
// See Also: vnf_volume(), vnf_area(), vnf_bend()
|
||||||
|
|
||||||
// Usage:
|
// Usage:
|
||||||
// newvnf = vnf_halfspace(plane, vnf, [closed], [boundary]);
|
// newvnf = vnf_halfspace(plane, vnf, [closed], [boundary]);
|
||||||
// Description:
|
// Description:
|
||||||
|
@ -1286,6 +1299,7 @@ function _triangulate_planar_convex_polygons(polys) =
|
||||||
|
|
||||||
// Function: vnf_bend()
|
// Function: vnf_bend()
|
||||||
// Synopsis: Bends a VNF around an axis.
|
// Synopsis: Bends a VNF around an axis.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation
|
// Topics: VNF Manipulation
|
||||||
// See Also: vnf_volume(), vnf_area(), vnf_halfspace()
|
// See Also: vnf_volume(), vnf_area(), vnf_halfspace()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1495,6 +1509,7 @@ module _show_faces(vertices, faces, size=1, filter) {
|
||||||
|
|
||||||
// Module: debug_vnf()
|
// Module: debug_vnf()
|
||||||
// Synopsis: A replacement for `vnf_polyhedron()` to help with debugging.
|
// Synopsis: A replacement for `vnf_polyhedron()` to help with debugging.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation, Debugging
|
// Topics: VNF Manipulation, Debugging
|
||||||
// See Also: vnf_validate()
|
// See Also: vnf_validate()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
@ -1538,6 +1553,7 @@ module debug_vnf(vnf, faces=true, vertices=true, opacity=0.5, size=1, convexity=
|
||||||
|
|
||||||
// Module: vnf_validate()
|
// Module: vnf_validate()
|
||||||
// Synopsis: Echos non-manifold VNF errors to the console.
|
// Synopsis: Echos non-manifold VNF errors to the console.
|
||||||
|
// SynTags: VNF
|
||||||
// Topics: VNF Manipulation, Debugging
|
// Topics: VNF Manipulation, Debugging
|
||||||
// See Also: debug_vnf()
|
// See Also: debug_vnf()
|
||||||
//
|
//
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
// Module: sparse_wall()
|
// Module: sparse_wall()
|
||||||
// Synopsis: Makes an open cross-braced rectangular wall.
|
// Synopsis: Makes an open cross-braced rectangular wall.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: FDM Optimized, Walls
|
// Topics: FDM Optimized, Walls
|
||||||
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
||||||
//
|
//
|
||||||
|
@ -88,6 +89,7 @@ module sparse_wall(h=50, l=100, thick=4, maxang=30, strut=5, max_bridge=20, anch
|
||||||
|
|
||||||
// Module: corrugated_wall()
|
// Module: corrugated_wall()
|
||||||
// Synopsis: Makes a corrugated rectangular wall.
|
// Synopsis: Makes a corrugated rectangular wall.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: FDM Optimized, Walls
|
// Topics: FDM Optimized, Walls
|
||||||
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
||||||
//
|
//
|
||||||
|
@ -147,6 +149,7 @@ module corrugated_wall(h=50, l=100, thick=5, strut=5, wall=2, anchor=CENTER, spi
|
||||||
|
|
||||||
// Module: thinning_wall()
|
// Module: thinning_wall()
|
||||||
// Synopsis: Makes a rectangular wall with a thin middle.
|
// Synopsis: Makes a rectangular wall with a thin middle.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: FDM Optimized, Walls
|
// Topics: FDM Optimized, Walls
|
||||||
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
||||||
//
|
//
|
||||||
|
@ -331,6 +334,7 @@ module thinning_wall(h=50, l=100, thick=5, ang=30, braces=false, strut, wall, an
|
||||||
|
|
||||||
// Module: thinning_triangle()
|
// Module: thinning_triangle()
|
||||||
// Synopsis: Makes a triangular wall with a thin middle.
|
// Synopsis: Makes a triangular wall with a thin middle.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: FDM Optimized, Walls
|
// Topics: FDM Optimized, Walls
|
||||||
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
||||||
//
|
//
|
||||||
|
@ -399,6 +403,7 @@ module thinning_triangle(h=50, l=100, thick=5, ang=30, strut=5, wall=3, diagonly
|
||||||
|
|
||||||
// Module: narrowing_strut()
|
// Module: narrowing_strut()
|
||||||
// Synopsis: Makes a strut like an extruded baseball home plate.
|
// Synopsis: Makes a strut like an extruded baseball home plate.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: FDM Optimized
|
// Topics: FDM Optimized
|
||||||
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
// See Also: sparse_wall(), corrugated_wall(), thinning_wall(), thinning_triangle(), narrowing_strut()
|
||||||
//
|
//
|
||||||
|
|
|
@ -55,6 +55,7 @@ function _hex_offsets(n, d, lev=0, arr=[]) =
|
||||||
|
|
||||||
// Module: wire_bundle()
|
// Module: wire_bundle()
|
||||||
// Synopsis: Creates a wire bundle for a given number of wires.
|
// Synopsis: Creates a wire bundle for a given number of wires.
|
||||||
|
// SynTags: Geom
|
||||||
// Topics: Wiring
|
// Topics: Wiring
|
||||||
// See Also: path_sweep(), path_sweep2d()
|
// See Also: path_sweep(), path_sweep2d()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
Loading…
Reference in a new issue