diff options
author | erorcun <erorcunerorcun@hotmail.com.tr> | 2021-01-27 22:51:43 +0100 |
---|---|---|
committer | erorcun <erorcunerorcun@hotmail.com.tr> | 2021-01-27 22:51:43 +0100 |
commit | be88a42bad207a2c723c3cdb152a872e1a7f14af (patch) | |
tree | 5d8feabe58566914f6f08d2e4a5d49e3321e28c4 /src/collision | |
parent | Change joystick DB with latest offical one (diff) | |
download | re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.tar re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.tar.gz re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.tar.bz2 re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.tar.lz re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.tar.xz re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.tar.zst re3-be88a42bad207a2c723c3cdb152a872e1a7f14af.zip |
Diffstat (limited to 'src/collision')
-rw-r--r-- | src/collision/Collision.cpp | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/src/collision/Collision.cpp b/src/collision/Collision.cpp index bead5183..50c22e32 100644 --- a/src/collision/Collision.cpp +++ b/src/collision/Collision.cpp @@ -307,8 +307,16 @@ CCollision::TestLineTriangle(const CColLine &line, const CompressedVector *verts if(plane.CalcPoint(line.p0) * plane.CalcPoint(line.p1) > 0.0f) return false; + float p0dist = DotProduct(line.p1 - line.p0, normal); + +#ifdef FIX_BUGS + // line lines in the plane, assume no collision + if (p0dist == 0.0f) + return false; +#endif + // intersection parameter on line - t = -plane.CalcPoint(line.p0) / DotProduct(line.p1 - line.p0, normal); + t = -plane.CalcPoint(line.p0) / p0dist; // find point of intersection CVector p = line.p0 + (line.p1-line.p0)*t; @@ -1127,8 +1135,17 @@ CCollision::ProcessLineTriangle(const CColLine &line, if(plane.CalcPoint(line.p0) * plane.CalcPoint(line.p1) > 0.0f) return false; + float p0dist = DotProduct(line.p1 - line.p0, normal); + +#ifdef FIX_BUGS + // line lines in the plane, assume no collision + if (p0dist == 0.0f) + return false; +#endif + // intersection parameter on line - t = -plane.CalcPoint(line.p0) / DotProduct(line.p1 - line.p0, normal); + t = -plane.CalcPoint(line.p0) / p0dist; + // early out if we're beyond the mindist if(t >= mindist) return false; |