浏览代码

Merge pull request #24897 from GlaDos28/master

fixed invalid implementation of Plane::intersects_segment and Plane::intersects_ray
Rémi Verschelde 6 年之前
父节点
当前提交
3652442a92
共有 1 个文件被更改,包括 3 次插入5 次删除
  1. 3 5
      core/math/plane.cpp

+ 3 - 5
core/math/plane.cpp

@@ -115,15 +115,14 @@ bool Plane::intersects_ray(const Vector3 &p_from, const Vector3 &p_dir, Vector3
 		return false;
 	}
 
-	real_t dist = (normal.dot(p_from) - d) / den;
+	real_t dist = (-normal.dot(p_from) - d) / den;
 	//printf("dist is %i\n",dist);
 
-	if (dist > CMP_EPSILON) { //this is a ray, before the emitting pos (p_from) doesn't exist
+	if (dist < -CMP_EPSILON) { //this is a ray, before the emitting pos (p_from) doesn't exist
 
 		return false;
 	}
 
-	dist = -dist;
 	*p_intersection = p_from + segment * dist;
 
 	return true;
@@ -140,7 +139,7 @@ bool Plane::intersects_segment(const Vector3 &p_begin, const Vector3 &p_end, Vec
 		return false;
 	}
 
-	real_t dist = (normal.dot(p_begin) - d) / den;
+	real_t dist = (-normal.dot(p_begin) - d) / den;
 	//printf("dist is %i\n",dist);
 
 	if (dist < -CMP_EPSILON || dist > (1.0 + CMP_EPSILON)) {
@@ -148,7 +147,6 @@ bool Plane::intersects_segment(const Vector3 &p_begin, const Vector3 &p_end, Vec
 		return false;
 	}
 
-	dist = -dist;
 	*p_intersection = p_begin + segment * dist;
 
 	return true;