mirror of
https://github.com/BelfrySCAD/BOSL2.git
synced 2025-01-01 09:49:45 +00:00
more fixes
This commit is contained in:
parent
cd664f830c
commit
2bfb4e39e7
3 changed files with 14 additions and 9 deletions
|
@ -1518,15 +1518,20 @@ function _get_cp(geom) =
|
||||||
let(cp=select(geom,-3))
|
let(cp=select(geom,-3))
|
||||||
is_vector(cp) ? cp
|
is_vector(cp) ? cp
|
||||||
: let(
|
: let(
|
||||||
|
f=echo(type=geom[0]),
|
||||||
type = in_list(geom[0],["vnf_extent","vnf_isect"]) ? "vnf"
|
type = in_list(geom[0],["vnf_extent","vnf_isect"]) ? "vnf"
|
||||||
: in_list(geom[0],["rgn_extent","rgn_isect"]) ? "path"
|
: in_list(geom[0],["rgn_extent","rgn_isect"]) ? "path"
|
||||||
|
: in_list(geom[0],["xrgn_extent","xrgn_isect"]) ? "xpath"
|
||||||
: "other"
|
: "other"
|
||||||
)
|
)
|
||||||
assert(type!="other", "Invalid cp value")
|
assert(type!="other", "Invalid cp value")
|
||||||
cp=="centroid" ? centroid(geom[1])
|
cp=="centroid" ? (
|
||||||
|
type=="vnf" && (len(geom[1][0])==0 || len(geom[1][1])==0) ? [0,0,0] :
|
||||||
|
[each centroid(geom[1]), if (type=="xpath") geom[2]/2]
|
||||||
|
)
|
||||||
: let(points = type=="vnf"?geom[1][0]:flatten(force_region(geom[1])))
|
: let(points = type=="vnf"?geom[1][0]:flatten(force_region(geom[1])))
|
||||||
cp=="mean" ? mean(points)
|
cp=="mean" ? [each mean(points), if (type=="xpath") geom[2]/2]
|
||||||
: cp=="box" ? mean(pointlist_bounds(points))
|
: cp=="box" ?[each mean(pointlist_bounds(points)), if (type=="xpath") geom[2]/2]
|
||||||
: assert(false,"Invalid cp specification");
|
: assert(false,"Invalid cp specification");
|
||||||
|
|
||||||
|
|
||||||
|
@ -1758,7 +1763,7 @@ function _find_anchor(anchor, geom) =
|
||||||
pos = point2d(cp) + rot(from=RIGHT, to=anchor, p=[maxx,midy])
|
pos = point2d(cp) + rot(from=RIGHT, to=anchor, p=[maxx,midy])
|
||||||
) [anchor, pos, anchor, 0]
|
) [anchor, pos, anchor, 0]
|
||||||
) : type == "xrgn_isect"? ( //region
|
) : type == "xrgn_isect"? ( //region
|
||||||
assert(anchor.z==0, "The Z component of an anchor for a 2D shape must be 0.")
|
assert(in_list(anchor.z,[-1,0,1]), "The Z component of an anchor for an extruded 2D shape must be -1, 0, or 1.")
|
||||||
let(
|
let(
|
||||||
rgn_raw = move(-point2d(cp), p=geom[1]),
|
rgn_raw = move(-point2d(cp), p=geom[1]),
|
||||||
l = geom[2],
|
l = geom[2],
|
||||||
|
@ -1788,10 +1793,10 @@ function _find_anchor(anchor, geom) =
|
||||||
oang = approx(xyvec, [0,0])? 0 : atan2(xyvec.y, xyvec.x) + 90
|
oang = approx(xyvec, [0,0])? 0 : atan2(xyvec.y, xyvec.x) + 90
|
||||||
) [anchor, pos, vec, oang]
|
) [anchor, pos, vec, oang]
|
||||||
) : type == "xrgn_extent"? ( //region
|
) : type == "xrgn_extent"? ( //region
|
||||||
assert(anchor.z==0, "The Z component of an anchor for a 2D shape must be 0.")
|
assert(in_list(anchor.z,[-1,0,1]), "The Z component of an anchor for an extruded 2D shape must be -1, 0, or 1.")
|
||||||
let(
|
let(
|
||||||
rgn_raw = geom[1], l = geom[2],
|
rgn = force_region(geom[1]),
|
||||||
rgn = is_region(rgn_raw)? rgn_raw : [rgn_raw],
|
l = geom[2],
|
||||||
anchor = point3d(anchor),
|
anchor = point3d(anchor),
|
||||||
xyanch = point2d(anchor),
|
xyanch = point2d(anchor),
|
||||||
m = (
|
m = (
|
||||||
|
|
|
@ -637,7 +637,7 @@ function region_parts(region) =
|
||||||
// mrgn = union(rgn1,rgn2);
|
// mrgn = union(rgn1,rgn2);
|
||||||
// orgn = difference(mrgn,rgn3);
|
// orgn = difference(mrgn,rgn3);
|
||||||
// linear_sweep(orgn,height=20,convexity=16) show_anchors();
|
// linear_sweep(orgn,height=20,convexity=16) show_anchors();
|
||||||
module linear_sweep(region, height=1, center, twist=0, scale=1, slices, maxseg, style="default", convexity, anchor_isect=false, spin=0, orient=UP, cp="centroid", anchor="origin") {
|
module linear_sweep(region, height=1, center, twist=0, scale=1, slices, maxseg, style="default", convexity, anchor_isect=false, spin=0, orient=UP, cp="centroid", anchor="origin", atype="hull") {
|
||||||
region = force_region(region);
|
region = force_region(region);
|
||||||
dummy=assert(is_region(region),"Input is not a region");
|
dummy=assert(is_region(region),"Input is not a region");
|
||||||
anchor = center ? "zcenter" : anchor;
|
anchor = center ? "zcenter" : anchor;
|
||||||
|
|
2
vnf.scad
2
vnf.scad
|
@ -877,7 +877,7 @@ function vnf_area(vnf) =
|
||||||
/// The centroid of a tetrahedron is the average of its vertices.
|
/// The centroid of a tetrahedron is the average of its vertices.
|
||||||
/// The centroid of the total is the volume weighted average.
|
/// The centroid of the total is the volume weighted average.
|
||||||
function _vnf_centroid(vnf,eps=EPSILON) =
|
function _vnf_centroid(vnf,eps=EPSILON) =
|
||||||
assert(is_vnf(vnf) && len(vnf[0])!=0 )
|
assert(is_vnf(vnf) && len(vnf[0])!=0 && len(vnf[1])!=0,"Invalid or empty VNF given to centroid")
|
||||||
let(
|
let(
|
||||||
verts = vnf[0],
|
verts = vnf[0],
|
||||||
pos = sum([
|
pos = sum([
|
||||||
|
|
Loading…
Reference in a new issue