mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-17 01:49:48 +00:00
add fast option to hull_points and tweak docs
This commit is contained in:
parent
19abb5d2c3
commit
68d911618b
1 changed files with 5 additions and 2 deletions
|
@ -1665,7 +1665,9 @@ function sphere(r, d, circum=false, style="orig", anchor=CENTER, spin=0, orient=
|
||||||
// a new polyhedron whose vertices are obtained from the faces of the parent polyhedron.
|
// a new polyhedron whose vertices are obtained from the faces of the parent polyhedron.
|
||||||
// The "orig" and "align" forms are duals of each other. If you request a circumscribing polyhedron in
|
// The "orig" and "align" forms are duals of each other. If you request a circumscribing polyhedron in
|
||||||
// these styles then the polyhedron will look the same as the default inscribing form. But for the other
|
// these styles then the polyhedron will look the same as the default inscribing form. But for the other
|
||||||
// styles, the duals are completely different from their parents, and from each other.
|
// styles, the duals are completely different from their parents, and from each other. Generation of the circumscribed versions (duals)
|
||||||
|
// for "octa" and "icosa" is fast if you use the module form but can be very slow (several minutes) if you use the functional
|
||||||
|
// form and choose a large $fn value.
|
||||||
// Arguments:
|
// Arguments:
|
||||||
// r = Radius of the spheroid.
|
// r = Radius of the spheroid.
|
||||||
// style = The style of the spheroid's construction. One of "orig", "aligned", "stagger", "octa", or "icosa". Default: "aligned"
|
// style = The style of the spheroid's construction. One of "orig", "aligned", "stagger", "octa", or "icosa". Default: "aligned"
|
||||||
|
@ -1741,7 +1743,7 @@ module spheroid(r, style="aligned", d, circum=false, dual=false, anchor=CENTER,
|
||||||
else if (circum && (style=="octa" || style=="icosa")) {
|
else if (circum && (style=="octa" || style=="icosa")) {
|
||||||
orig_sphere = spheroid(r,style,circum=false);
|
orig_sphere = spheroid(r,style,circum=false);
|
||||||
dualvert = _dual_vertices(orig_sphere);
|
dualvert = _dual_vertices(orig_sphere);
|
||||||
hull_points(dualvert);
|
hull_points(dualvert,fast=true);
|
||||||
} else {
|
} else {
|
||||||
vnf = spheroid(r=r, circum=circum, style=style);
|
vnf = spheroid(r=r, circum=circum, style=style);
|
||||||
vnf_polyhedron(vnf, convexity=2);
|
vnf_polyhedron(vnf, convexity=2);
|
||||||
|
@ -1769,6 +1771,7 @@ function _dual_vertices(vnf) =
|
||||||
|
|
||||||
function spheroid(r, style="aligned", d, circum=false, anchor=CENTER, spin=0, orient=UP) =
|
function spheroid(r, style="aligned", d, circum=false, anchor=CENTER, spin=0, orient=UP) =
|
||||||
let(
|
let(
|
||||||
|
ff=echo("running sphereoid with ",circum=circum),
|
||||||
r = get_radius(r=r, d=d, dflt=1),
|
r = get_radius(r=r, d=d, dflt=1),
|
||||||
hsides = segs(r),
|
hsides = segs(r),
|
||||||
vsides = max(2,ceil(hsides/2)),
|
vsides = max(2,ceil(hsides/2)),
|
||||||
|
|
Loading…
Reference in a new issue