您的位置:首页 > 其它

判断一个点是否在三角形区域内

2017-12-14 10:13 337 查看
float TriangleArea (float v0x, float v0y, float v1x, float v1y, float v2x, float v2y)
{
return Mathf.Abs ((v0x * v1y + v1x * v2y + v2x * v0y
- v1x * v0y - v2x * v1y - v0x * v2y) / 2f);
}
public bool IsINTriangle (Vector3 point, Vector3 v0, Vector3 v1, Vector3 v2)
{
float x = point.x;
float y = point.z;

float v0x = v0.x;
float v0y = v0.z;

float v1x = v1.x;
float v1y = v1.z;

float v2x = v2.x;
float v2y = v2.z;

float t = TriangleArea (v0x, v0y, v1x, v1y, v2x, v2y);
float a = TriangleArea (v0x, v0y, v1x, v1y, x, y) + TriangleArea (v0x, v0y, x, y, v2x, v2y) + TriangleArea (x, y, v1x, v1y, v2x, v2y);

if (Mathf.Abs (t - a) <= 0.01f) {
return true;
} else {
return false;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: