Fixed segment intersection routines for FP rounding issues.

This commit is contained in:
Revar Desmera 2019-05-29 18:01:00 -07:00
parent ac71eb67e8
commit 78510c0b33

View file

@ -159,8 +159,11 @@ function line_intersection(l1,l2) = let( isect = _general_line_intersection(l1,l
// Arguments: // Arguments:
// s1 = First 2D segment, given as a list of the two 2D endpoints of the line segment. // s1 = First 2D segment, given as a list of the two 2D endpoints of the line segment.
// s2 = Second 2D segment, given as a list of the two 2D endpoints of the line segment. // s2 = Second 2D segment, given as a list of the two 2D endpoints of the line segment.
function segment_intersection(s1,s2) = let( isect = _general_line_intersection(s1,s2)) function segment_intersection(s1,s2) =
isect[1]<0 || isect[1]>1 || isect[2]<0 || isect[2]>1 ? undef : isect[0]; let(
isect = _general_line_intersection(s1,s2),
eps=EPSILON
) isect[1]<0-eps || isect[1]>1+eps || isect[2]<0-eps || isect[2]>1+eps ? undef : isect[0];
// Function: line_segment_intersection() // Function: line_segment_intersection()
@ -172,9 +175,12 @@ function segment_intersection(s1,s2) = let( isect = _general_line_intersection(s
// Arguments: // Arguments:
// line = The unbounded 2D line, defined by two 2D points on the line. // line = The unbounded 2D line, defined by two 2D points on the line.
// segment = The bounded 2D line segment, given as a list of the two 2D endpoints of the segment. // segment = The bounded 2D line segment, given as a list of the two 2D endpoints of the segment.
function line_segment_intersection(line,segment) = let( function line_segment_intersection(line,segment) =
isect = _general_line_intersection(line,segment) let(
) isect[2]<0 || isect[2]>1 ? undef : isect[0]; isect = _general_line_intersection(line,segment),
eps = EPSILON
) isect[2]<0-eps || isect[2]>1+eps ? undef : isect[0];
// Function: triangle_area2d() // Function: triangle_area2d()
// Usage: // Usage: