fixed invalid implementations of Plane::intersects_segment and Plane::intersects_ray
This commit is contained in:
parent
27d7772381
commit
2c36078be4
1 changed files with 3 additions and 5 deletions
|
@ -115,15 +115,14 @@ bool Plane::intersects_ray(const Vector3 &p_from, const Vector3 &p_dir, Vector3
|
||||||
return false;
|
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);
|
//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;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
dist = -dist;
|
|
||||||
*p_intersection = p_from + segment * dist;
|
*p_intersection = p_from + segment * dist;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -140,7 +139,7 @@ bool Plane::intersects_segment(const Vector3 &p_begin, const Vector3 &p_end, Vec
|
||||||
return false;
|
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);
|
//printf("dist is %i\n",dist);
|
||||||
|
|
||||||
if (dist < -CMP_EPSILON || dist > (1.0 + CMP_EPSILON)) {
|
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;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
dist = -dist;
|
|
||||||
*p_intersection = p_begin + segment * dist;
|
*p_intersection = p_begin + segment * dist;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Reference in a new issue