more fixes

This commit is contained in:
Adrian Mariano 2021-11-16 23:12:03 -05:00
parent cd664f830c
commit 2bfb4e39e7
3 changed files with 14 additions and 9 deletions

View file

@ -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 = (

View file

@ -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;

View file

@ -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([