From 7daa16f2382d62e7acd01363a35feb95c6d158c3 Mon Sep 17 00:00:00 2001 From: Garth Minette Date: Mon, 17 Aug 2020 18:11:49 -0700 Subject: [PATCH] Fixed VNF attachment normal vector. --- attachments.scad | 17 +++++++++++++++-- version.scad | 2 +- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/attachments.scad b/attachments.scad index 2ac4367..c2c969e 100644 --- a/attachments.scad +++ b/attachments.scad @@ -473,7 +473,7 @@ function find_anchor(anchor, geom) = pt = polygon_line_intersection(poly, [cp,cp+anchor], bounded=[true,false], eps=eps) ) if (!is_undef(pt)) let( plane = plane_from_polygon(poly), - n = plane_normal(plane) + n = unit(plane_normal(plane)) ) [norm(pt-cp), n, pt] ] @@ -483,7 +483,20 @@ function find_anchor(anchor, geom) = furthest = max_index(subindex(hits,0)), dist = hits[furthest][0], pos = hits[furthest][2], - n = unit(sum([for (hit = hits) if (approx(hit[0],dist,eps=eps)) hit[1]])) + hitnorms = [for (hit = hits) if (approx(hit[0],dist,eps=eps)) hit[1]], + unorms = len(hitnorms) > 7 + ? unique([for (nn = hitnorms) quant(nn,1e-9)]) + : [ + for (i = idx(hitnorms)) let( + nn = hitnorms[i], + isdup = [ + for (j = [i+1:1:len(hitnorms)-1]) + if (approx(nn, hitnorms[j])) 1 + ] != [] + ) if (!isdup) nn + ], + n = unit(sum(unorms)), + oang = approx(point2d(n), [0,0])? 0 : atan2(n.y, n.x) + 90 ) [anchor, pos, n, oang] ) : type == "vnf_extent"? ( //vnf diff --git a/version.scad b/version.scad index 85cad34..1420f58 100644 --- a/version.scad +++ b/version.scad @@ -8,7 +8,7 @@ ////////////////////////////////////////////////////////////////////// -BOSL_VERSION = [2,0,404]; +BOSL_VERSION = [2,0,405]; // Section: BOSL Library Version Functions