如何确定两条3D线段是否与每条线的起点和终点的XYZ坐标相交?如果他们确实相交,那是什么XYZ?
我只能找到2D线的答案:How do you detect where two line segments intersect?
答案 0 :(得分:5)
让我们的起点是P0,Q0,终点是P1,Q1。
Direction vectors
DP = P1 - P0
DQ = Q1 - Q0
start difference vector
PQ = Q0 - P0
以参数形式分段:
P = P0 + t * DP
Q = Q0 + u * DQ
查找值
a = Dot(DP, DP)
b = Dot(DP, DQ)
c = Dot(DQ, DQ)
d = Dot(DP, PQ)
e = Dot(DQ, PQ)
查找判别
DD = a * c- b * b
如果DD = 0,则段是并行的,并考虑(部分)重合的特殊情况,否则
查找线上最近点的参数
tt = (b * e - c * d) / DD
uu = (a * e - b * d) / DD
如果任何参数超出范围0..1,则段不相交,否则
找出点之间的距离
P(tt) = P0 + tt * DP
Q(uu) = Q0 + uu * DQ
Dist = Length(Q(uu) - P(tt))
如果Dist为零(或由于数值误差而小于一些小的Epsilon值,如1.0E-12),那么段在这一点上相交P(tt)