mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-19 19:09:36 +00:00
Merge branch 'master' into revarbat_dev
This commit is contained in:
commit
052a381f80
4 changed files with 15 additions and 10 deletions
18
beziers.scad
18
beziers.scad
|
@ -238,19 +238,20 @@ function bezier_curvature(curve, u) =
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Function: bezier_curve()
|
// Function: bezier_curve()
|
||||||
// Usage:
|
// Usage:
|
||||||
// bezier_curve(curve, n);
|
// bezier_curve(curve, n, [endpoint]);
|
||||||
// Description:
|
// Description:
|
||||||
// Takes a list of bezier curve control points, and a count of path points to generate. The points
|
// Takes a list of bezier curve control points and generates n points along the bezier path.
|
||||||
// returned will be along the curve, starting at the first control point, then about every `1/n`th
|
// Points start at the first control point and are sampled every `1/n`th
|
||||||
// of the way along the curve, ending about `1/n`th of the way *before* the final control point.
|
// of the way along the bezier parameter, ending *before* the final control point by default.
|
||||||
// The distance between the points will *not* be equidistant. The degree of the curve, N, is one
|
// The distance between the points will *not* be equidistant. If you wish to add the
|
||||||
|
// endpoint you can set `endpoint` to true. The degree of the bezier curve is one
|
||||||
// less than the number of points in `curve`.
|
// less than the number of points in `curve`.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// curve = The list of endpoints and control points for this bezier segment.
|
// curve = The list of endpoints and control points for this bezier segment.
|
||||||
// n = The number of points to generate along the bezier curve.
|
// n = The number of points to generate along the bezier curve.
|
||||||
|
// endpoint = if true then add the endpoint (an extra point, giving n+1 points output). Default: False
|
||||||
// Example(2D): Quadratic (Degree 2) Bezier.
|
// Example(2D): Quadratic (Degree 2) Bezier.
|
||||||
// bez = [[0,0], [30,30], [80,0]];
|
// bez = [[0,0], [30,30], [80,0]];
|
||||||
// move_copies(bezier_curve(bez, 8)) sphere(r=1.5, $fn=12);
|
// move_copies(bezier_curve(bez, 8)) sphere(r=1.5, $fn=12);
|
||||||
|
@ -263,8 +264,9 @@ function bezier_curvature(curve, u) =
|
||||||
// bez = [[0,0], [5,15], [40,20], [60,-15], [80,0]];
|
// bez = [[0,0], [5,15], [40,20], [60,-15], [80,0]];
|
||||||
// move_copies(bezier_curve(bez, 8)) sphere(r=1.5, $fn=12);
|
// move_copies(bezier_curve(bez, 8)) sphere(r=1.5, $fn=12);
|
||||||
// trace_bezier(bez, N=len(bez)-1);
|
// trace_bezier(bez, N=len(bez)-1);
|
||||||
function bezier_curve(curve,n) = bezier_points(curve, [0:1/n:(n-0.5)/n]);
|
function bezier_curve(curve,n,endpoint) = [each bezier_points(curve, [0:1/n:(n-0.5)/n]),
|
||||||
|
if (endpoint) curve[len(curve)-1]
|
||||||
|
];
|
||||||
|
|
||||||
// Function: bezier_segment_closest_point()
|
// Function: bezier_segment_closest_point()
|
||||||
// Usage:
|
// Usage:
|
||||||
|
|
|
@ -121,6 +121,7 @@ function _unique_groups(m) = [
|
||||||
//
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// name = Name of polyhedron to create.
|
// name = Name of polyhedron to create.
|
||||||
|
// ---
|
||||||
// index = Index to select from polyhedron list. Default: 0.
|
// index = Index to select from polyhedron list. Default: 0.
|
||||||
// type = Type of polyhedron: "platonic", "archimedean", "catalan".
|
// type = Type of polyhedron: "platonic", "archimedean", "catalan".
|
||||||
// faces = Number of faces.
|
// faces = Number of faces.
|
||||||
|
@ -564,6 +565,7 @@ _stellated_polyhedra_ = [
|
||||||
//
|
//
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// name = Name of polyhedron to create.
|
// name = Name of polyhedron to create.
|
||||||
|
// ---
|
||||||
// index = Index to select from polyhedron list. Default: 0.
|
// index = Index to select from polyhedron list. Default: 0.
|
||||||
// type = Type of polyhedron: "platonic", "archimedean", "catalan".
|
// type = Type of polyhedron: "platonic", "archimedean", "catalan".
|
||||||
// faces = Number of faces.
|
// faces = Number of faces.
|
||||||
|
|
|
@ -308,7 +308,7 @@ function _bezcorner(points, parm) =
|
||||||
] : _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_segment_length(P)/$fs))
|
||||||
)
|
)
|
||||||
bezier_curve(P,N);
|
bezier_curve(P,N,endpoint=true);
|
||||||
|
|
||||||
function _chamfcorner(points, parm) =
|
function _chamfcorner(points, parm) =
|
||||||
let(
|
let(
|
||||||
|
@ -329,7 +329,7 @@ function _circlecorner(points, parm) =
|
||||||
start = points[1]+prev*d,
|
start = points[1]+prev*d,
|
||||||
end = points[1]+next*d
|
end = points[1]+next*d
|
||||||
) // 90-angle is half the angle of the circular arc
|
) // 90-angle is half the angle of the circular arc
|
||||||
arc(max(3,(90-angle)/180*segs(r)), cp=center, points=[start,end]);
|
arc(max(3,ceil((90-angle)/180*segs(r))), cp=center, points=[start,end]);
|
||||||
|
|
||||||
|
|
||||||
// Used by offset_sweep and convex_offset_extrude:
|
// Used by offset_sweep and convex_offset_extrude:
|
||||||
|
|
|
@ -381,6 +381,7 @@ function arc(N, r, angle, d, cp, points, width, thickness, start, wedge=false, l
|
||||||
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")
|
||||||
slice(arc(N,r,angle,d,cp,points,width,thickness,start,wedge,long,cw,ccw,true),0,-2) :
|
slice(arc(N,r,angle,d,cp,points,width,thickness,start,wedge,long,cw,ccw,true),0,-2) :
|
||||||
|
assert(is_undef(N) || is_integer(N), "Number of points must be an integer")
|
||||||
// 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)? (
|
||||||
assert(!any_defined([r,cp,points]) && !any([cw,ccw,long]),"Conflicting or invalid parameters to arc")
|
assert(!any_defined([r,cp,points]) && !any([cw,ccw,long]),"Conflicting or invalid parameters to arc")
|
||||||
|
|
Loading…
Reference in a new issue