mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
misc doc fixes and organization
beziers reorg arc bug fix for endpoint=false and N=undef
This commit is contained in:
parent
1df2d49e3c
commit
d8aa4ced71
10 changed files with 777 additions and 868 deletions
|
@ -1274,25 +1274,6 @@ module attachable(
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Function: named_anchor()
|
|
||||||
// Usage:
|
|
||||||
// a = named_anchor(name, pos, [orient], [spin]);
|
|
||||||
// Topics: Attachments
|
|
||||||
// See Also: reorient(), attachable()
|
|
||||||
// Description:
|
|
||||||
// Creates an anchor data structure. For a more step-by-step explanation of attachments,
|
|
||||||
// see the [[Attachments Tutorial|Tutorial-Attachments]].
|
|
||||||
// Arguments:
|
|
||||||
// name = The string name of the anchor. Lowercase. Words separated by single dashes. No spaces.
|
|
||||||
// pos = The [X,Y,Z] position of the anchor.
|
|
||||||
// orient = A vector pointing in the direction parts should project from the anchor position.
|
|
||||||
// spin = If needed, the angle to rotate the part around the direction vector.
|
|
||||||
function named_anchor(name, pos=[0,0,0], orient=UP, spin=0) = [name, pos, orient, spin];
|
|
||||||
|
|
||||||
|
|
||||||
// Function: reorient()
|
// Function: reorient()
|
||||||
//
|
//
|
||||||
// Usage: Square/Trapezoid Geometry
|
// Usage: Square/Trapezoid Geometry
|
||||||
|
@ -1418,6 +1399,24 @@ function reorient(
|
||||||
) _attach_transform(anchor,spin,orient,geom,p);
|
) _attach_transform(anchor,spin,orient,geom,p);
|
||||||
|
|
||||||
|
|
||||||
|
// Function: named_anchor()
|
||||||
|
// Usage:
|
||||||
|
// a = named_anchor(name, pos, [orient], [spin]);
|
||||||
|
// Topics: Attachments
|
||||||
|
// See Also: reorient(), attachable()
|
||||||
|
// Description:
|
||||||
|
// Creates an anchor data structure. For a more step-by-step explanation of attachments,
|
||||||
|
// see the [[Attachments Tutorial|Tutorial-Attachments]].
|
||||||
|
// Arguments:
|
||||||
|
// name = The string name of the anchor. Lowercase. Words separated by single dashes. No spaces.
|
||||||
|
// pos = The [X,Y,Z] position of the anchor.
|
||||||
|
// orient = A vector pointing in the direction parts should project from the anchor position.
|
||||||
|
// spin = If needed, the angle to rotate the part around the direction vector.
|
||||||
|
function named_anchor(name, pos=[0,0,0], orient=UP, spin=0) = [name, pos, orient, spin];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
|
|
1573
beziers.scad
1573
beziers.scad
File diff suppressed because it is too large
Load diff
|
@ -172,6 +172,10 @@ CENTER = [ 0, 0, 0]; // Centered zero vector.
|
||||||
CTR = CENTER;
|
CTR = CENTER;
|
||||||
|
|
||||||
|
|
||||||
|
// Section: Line specifiers
|
||||||
|
// Used by functions in geometry.scad for specifying whether two points
|
||||||
|
// are treated as an unbounded line, a ray with one endpoint, or a segment
|
||||||
|
// with two endpoints.
|
||||||
|
|
||||||
// Constant: SEGMENT
|
// Constant: SEGMENT
|
||||||
// Topics: Constants, Lines
|
// Topics: Constants, Lines
|
||||||
|
|
|
@ -650,7 +650,7 @@ module dashed_stroke(path, dashpat=[3,3], width=1, closed=false) {
|
||||||
function arc(N, r, angle, d, cp, points, width, thickness, start, wedge=false, long=false, cw=false, ccw=false, endpoint=true) =
|
function arc(N, r, angle, d, cp, points, width, thickness, start, wedge=false, long=false, cw=false, ccw=false, endpoint=true) =
|
||||||
assert(is_bool(endpoint))
|
assert(is_bool(endpoint))
|
||||||
!endpoint ? assert(!wedge, "endpoint cannot be false if wedge is true")
|
!endpoint ? assert(!wedge, "endpoint cannot be false if wedge is true")
|
||||||
list_head(arc(N+1,r,angle,d,cp,points,width,thickness,start,wedge,long,cw,ccw,true)) :
|
list_head(arc(u_add(N,1),r,angle,d,cp,points,width,thickness,start,wedge,long,cw,ccw,true)) :
|
||||||
assert(is_undef(N) || (is_integer(N) && N>=2), "Number of points must be an integer 2 or larger")
|
assert(is_undef(N) || (is_integer(N) && N>=2), "Number of points must be an integer 2 or larger")
|
||||||
// First try for 2D arc specified by width and thickness
|
// First try for 2D arc specified by width and thickness
|
||||||
is_def(width) && is_def(thickness)? (
|
is_def(width) && is_def(thickness)? (
|
||||||
|
|
|
@ -996,8 +996,8 @@ module rabbit_clip(type, length, width, snap, thickness, depth, compression=0.1
|
||||||
? concat(pin_smooth, reverse(pin_smooth))
|
? concat(pin_smooth, reverse(pin_smooth))
|
||||||
: let(side_smooth=select(pin_smooth, 0, 2))
|
: let(side_smooth=select(pin_smooth, 0, 2))
|
||||||
concat(side_smooth, [socket_smooth], reverse(side_smooth));
|
concat(side_smooth, [socket_smooth], reverse(side_smooth));
|
||||||
bez = path_to_bezier(path,relsize=smoothing,tangents=tangent);
|
bez = path_to_bezpath(path,relsize=smoothing,tangents=tangent);
|
||||||
rounded = bezier_path(bez,splinesteps=splinesteps);
|
rounded = bezpath_curve(bez,splinesteps=splinesteps);
|
||||||
bounds = pointlist_bounds(rounded);
|
bounds = pointlist_bounds(rounded);
|
||||||
extrapt = is_pin ? [] : [rounded[0] - [0,extra]];
|
extrapt = is_pin ? [] : [rounded[0] - [0,extra]];
|
||||||
finalpath = is_pin ? rounded
|
finalpath = is_pin ? rounded
|
||||||
|
|
|
@ -387,6 +387,7 @@ function repeat(val, n, i=0) =
|
||||||
// s = The starting value of the list of numbers.
|
// s = The starting value of the list of numbers.
|
||||||
// step = The amount to increment successive numbers in the list.
|
// step = The amount to increment successive numbers in the list.
|
||||||
// reverse = Reverse the list. Default: false.
|
// reverse = Reverse the list. Default: false.
|
||||||
|
// See Also: idx()
|
||||||
// Example:
|
// Example:
|
||||||
// nl1 = count(5); // Returns: [0,1,2,3,4]
|
// nl1 = count(5); // Returns: [0,1,2,3,4]
|
||||||
// nl2 = count(5,3); // Returns: [3,4,5,6,7]
|
// nl2 = count(5,3); // Returns: [3,4,5,6,7]
|
||||||
|
@ -851,9 +852,10 @@ function idx(list, s=0, e=-1, step=1) =
|
||||||
// Topics: List Handling, Iteration
|
// Topics: List Handling, Iteration
|
||||||
// See Also: idx(), triplet(), combinations(), permutations()
|
// See Also: idx(), triplet(), combinations(), permutations()
|
||||||
// Description:
|
// Description:
|
||||||
// Takes a list, and returns a list of adjacent pairs from it, optionally wrapping back to the front.
|
// Returns a list of all of the pairs of adjacent items from a list, optionally wrapping back to the front. The pairs overlap, and
|
||||||
|
// are returned in order starting with the first two entries in the list. If the list has less than two elements, the empty list is returned.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// list = The list to iterate.
|
// list = The list to use for making pairs
|
||||||
// wrap = If true, wrap back to the start from the end. ie: return the last and first items as the last pair. Default: false
|
// wrap = If true, wrap back to the start from the end. ie: return the last and first items as the last pair. Default: false
|
||||||
// Example(2D): Does NOT wrap from end to start,
|
// Example(2D): Does NOT wrap from end to start,
|
||||||
// for (p = pair(circle(d=40, $fn=12)))
|
// for (p = pair(circle(d=40, $fn=12)))
|
||||||
|
@ -883,7 +885,7 @@ function pair(list, wrap=false) =
|
||||||
// Topics: List Handling, Iteration
|
// Topics: List Handling, Iteration
|
||||||
// See Also: idx(), pair(), combinations(), permutations()
|
// See Also: idx(), pair(), combinations(), permutations()
|
||||||
// Description:
|
// Description:
|
||||||
// Takes a list, and returns a list of adjacent triplets from it, optionally wrapping back to the front.
|
// Returns a list of all adjacent triplets from a list, optionally wrapping back to the front.
|
||||||
// If you set `wrap` to true then the first triplet is the one centered on the first list element, so it includes
|
// If you set `wrap` to true then the first triplet is the one centered on the first list element, so it includes
|
||||||
// the last element and the first two elements. If the list has fewer than three elements then the empty list is returned.
|
// the last element and the first two elements. If the list has fewer than three elements then the empty list is returned.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
|
|
|
@ -176,7 +176,7 @@ module chain_hull()
|
||||||
// trapezoid(w1=10, w2=5, h=10, anchor=BACK);
|
// trapezoid(w1=10, w2=5, h=10, anchor=BACK);
|
||||||
// Example:
|
// Example:
|
||||||
// include <BOSL2/beziers.scad>
|
// include <BOSL2/beziers.scad>
|
||||||
// path = bezier_path([
|
// path = bezpath_curve([
|
||||||
// [-50,0], [-25,50], [0,0], [50,0]
|
// [-50,0], [-25,50], [0,0], [50,0]
|
||||||
// ]);
|
// ]);
|
||||||
// path_extrude2d(path, caps=false)
|
// path_extrude2d(path, caps=false)
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
// Includes:
|
// Includes:
|
||||||
// include <BOSL2/std.scad>
|
// include <BOSL2/std.scad>
|
||||||
// FileGroup: Advanced Modeling
|
// FileGroup: Advanced Modeling
|
||||||
// FileSummary: Work with arbitrary 2D or 3D paths.
|
// FileSummary: Operations on paths: length, resampling, tangents, splitting into subpaths
|
||||||
// FileFootnotes: STD=Included in std.scad
|
// FileFootnotes: STD=Included in std.scad
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
|
@ -345,7 +345,7 @@ function _bezcorner(points, parm) =
|
||||||
points[1]+k*d*next,
|
points[1]+k*d*next,
|
||||||
points[1]+d*next
|
points[1]+d*next
|
||||||
] : _smooth_bez_fill(points,parm),
|
] : _smooth_bez_fill(points,parm),
|
||||||
N = max(3,$fn>0 ?$fn : ceil(bezier_segment_length(P)/$fs))
|
N = max(3,$fn>0 ?$fn : ceil(bezier_length(P)/$fs))
|
||||||
)
|
)
|
||||||
bezier_curve(P,N+1,endpoint=true);
|
bezier_curve(P,N+1,endpoint=true);
|
||||||
|
|
||||||
|
@ -450,7 +450,7 @@ function _rounding_offsets(edgespec,z_dir=1) =
|
||||||
// in which case the size parameter specifies the sum of the deviations of the two peaks of the curve. In 3-space
|
// in which case the size parameter specifies the sum of the deviations of the two peaks of the curve. In 3-space
|
||||||
// the bezier curve may have three extrema: two maxima and one minimum. In this case the size specifies
|
// the bezier curve may have three extrema: two maxima and one minimum. In this case the size specifies
|
||||||
// the sum of the maxima minus the minimum. At a given segment there is a maximum size: if your size
|
// the sum of the maxima minus the minimum. At a given segment there is a maximum size: if your size
|
||||||
// value is too large it will be rounded down. See also path_to_bezier().
|
// value is too large it will be rounded down. See also path_to_bezpath().
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// path = path to smooth
|
// path = path to smooth
|
||||||
// tangents = tangents constraining curve direction at each point. Default: computed automatically
|
// tangents = tangents constraining curve direction at each point. Default: computed automatically
|
||||||
|
@ -503,9 +503,9 @@ module smooth_path(path, tangents, size, relsize, splinesteps=10, uniform=false,
|
||||||
function smooth_path(path, tangents, size, relsize, splinesteps=10, uniform=false, closed) =
|
function smooth_path(path, tangents, size, relsize, splinesteps=10, uniform=false, closed) =
|
||||||
is_1region(path) ? smooth_path(path[0], tangents, size, relsize, splinesteps, uniform, default(closed,true)) :
|
is_1region(path) ? smooth_path(path[0], tangents, size, relsize, splinesteps, uniform, default(closed,true)) :
|
||||||
let (
|
let (
|
||||||
bez = path_to_bezier(path, tangents=tangents, size=size, relsize=relsize, uniform=uniform, closed=default(closed,false))
|
bez = path_to_bezpath(path, tangents=tangents, size=size, relsize=relsize, uniform=uniform, closed=default(closed,false))
|
||||||
)
|
)
|
||||||
bezier_path(bez,splinesteps=splinesteps);
|
bezpath_curve(bez,splinesteps=splinesteps);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -665,7 +665,7 @@ function _path_join(paths,joint,k=0.5,i=0,result=[],relocate=true,closed=false)
|
||||||
loop?"closing the path":str("adding path ",i+1)))
|
loop?"closing the path":str("adding path ",i+1)))
|
||||||
let(
|
let(
|
||||||
bezpts = _smooth_bez_fill([firstcut[0], corner, nextcut[0]],k[i]),
|
bezpts = _smooth_bez_fill([firstcut[0], corner, nextcut[0]],k[i]),
|
||||||
N = max(3,$fn>0 ?$fn : ceil(bezier_segment_length(bezpts)/$fs)),
|
N = max(3,$fn>0 ?$fn : ceil(bezier_length(bezpts)/$fs)),
|
||||||
bezpath = approx(firstcut[0],corner) && approx(corner,nextcut[0])
|
bezpath = approx(firstcut[0],corner) && approx(corner,nextcut[0])
|
||||||
? []
|
? []
|
||||||
: bezier_curve(bezpts,N),
|
: bezier_curve(bezpts,N),
|
||||||
|
|
|
@ -1281,8 +1281,7 @@ function skew(p=_NO_ARG, sxy=0, sxz=0, syx=0, syz=0, szx=0, szy=0) =
|
||||||
p==_NO_ARG? m : apply(m, p);
|
p==_NO_ARG? m : apply(m, p);
|
||||||
|
|
||||||
|
|
||||||
// Section: Applying transformation matrices to
|
// Section: Applying transformation matrices to data
|
||||||
|
|
||||||
|
|
||||||
/// Internal Function: is_2d_transform()
|
/// Internal Function: is_2d_transform()
|
||||||
/// Usage:
|
/// Usage:
|
||||||
|
|
Loading…
Reference in a new issue