判断三维空间中的一个点是否在三角形内,边上的一种算法
来源:互联网 发布:彩票关注源码 编辑:程序博客网 时间:2024/04/26 15:58
网上判断点是否处于三角内内部,边上的方法有很多,但是比较简洁的方法,比如面积法,即判断三角形PAB,PAC,PBC之和与三角形ABC的面积。如果S(PAB+PAC+PBC)=S(ABC),则点位于三角形内部,或边上。但是上述方法由于涉及到平方和开根号,计算量比较大。
令向量(B-A)=(X1,Y1,Z1);向量(C-A)=(X2,Y2,Z2);向量(P-A)=(X3,Y3,Z3);
假设点P位于三角形ABC所在的平面,则向量(P-A)可以用向量(B-A)和(C-A)表示,即(P-A)=m*(B-A)+n(C-A);只要求出m,n的值即可判断点与三角形的关系。如果没有解,那么p不在三角形所在平面,如果有解,那么:
则P在三角形内部。
所以,问题的关键是要计算m,n的值,从而可以得到点和三角形的空间关系。
具体步骤如下:
由(P-A)=m*(B-A)+n(C-A)得到(X3,Y3,Z3)=m*(X1,Y1,Z1)+n*(X2,Y2,Z2),写成矩阵形式,得到:
X1 X2
Y1 Y2*
Z1 Z2
令矩阵K为
其中K的加号逆为
- 判断三维空间中的一个点是否在三角形内,边上的一种算法
- 判断一个点是否在三角形内
- 判断一个点是否在三角形内
- 判断一个点是否在三角形内
- 判断一个点是否在三角形内
- 判断一个点是否在三角形内
- 判断一个点是否在三角形内
- 一个判断点是否在三角形内的简单方法
- 求判断点是否在三角形内的最佳算法
- 判断一个点是否在一个三角形内(二维)
- 转载:判断一个点是否在一个三角形面内
- Algorithm: 如何判断一个点是否在一个三角形内
- Java 判断一个点是否在一个三角形内
- 判断一个点是否在一个三角形内(平面)
- Qt 判断一个点是否落在三角形内(算法)
- 如何判断一个点是否在三角形内
- 如何判断一个点是否在三角形内
- 判断一个点是否在 2D 三角形内
- POJ 1001解题思路
- 微软2014编程之美挑战赛初赛第二场 题目2 : 字符串压缩
- HDU 2842 Chinese Rings(矩阵快速幂)
- 人到中年,生活是怎样?
- 一个不错的学习编程的网站推荐ZenTut
- 判断三维空间中的一个点是否在三角形内,边上的一种算法
- Go语言 时间处理详解
- linux 下安装node.js 报You need to be root to perform this command
- 福昕pdf使用技巧
- EDK-II常用库函数及API
- 编程之美挑战赛初赛第二场题目2
- Leetcode_restore-ip-addresses
- 个生日个
- Oracle(3)数据库