1
0
mirror of https://github.com/JustinSDK/dotSCAD.git synced 2025-08-21 14:04:53 +02:00

fix error tri_incenter

This commit is contained in:
Justin Lin
2021-07-10 15:36:45 +08:00
parent 3ea7909853
commit 21012a76fe

View File

@@ -1,21 +1,18 @@
use <triangle/tri_incenter.scad>; use <triangle/tri_incenter.scad>;
function convex_offset(vertices, d) = function convex_offset(vertices, d) =
let( let(leng_vertices = len(vertices))
c = tri_incenter(vertices),
leng_vertices = len(vertices)
)
[ [
for(i = [0:leng_vertices - 1]) for(i = [0:leng_vertices - 1])
let( let(
curr_p = vertices[i], curr_p = vertices[i],
next_p = vertices[(i + 1) % leng_vertices], next_p = vertices[(i + 1) % leng_vertices],
v1 = c - curr_p, pre_p = vertices[(i + leng_vertices - 1) % leng_vertices],
v1 = pre_p - curr_p,
v2 = next_p - curr_p, v2 = next_p - curr_p,
leng_v1 = norm(v1), a = acos((v1 * v2) / (norm(v1) * norm(v2))),
leng_v2 = norm(v2), leng = -d * sin(a / 2),
a = acos((v1 * v2) / (leng_v1 * leng_v2)), v = tri_incenter([curr_p, next_p, pre_p]) - curr_p
leng = -d / sin(a)
) )
v1 / leng_v1 * leng + curr_p v / norm(v) * leng + curr_p
]; ];