diff options
author | eray orçunus <erayorcunus@gmail.com> | 2020-06-13 22:39:14 +0200 |
---|---|---|
committer | eray orçunus <erayorcunus@gmail.com> | 2020-06-14 21:57:26 +0200 |
commit | db6110e996756672595f3d0e69b8e96977a534e0 (patch) | |
tree | 56ac3029546f7e0892aff6364efc40bb5451a974 /src/core/Collision.cpp | |
parent | script fix (diff) | |
download | re3-db6110e996756672595f3d0e69b8e96977a534e0.tar re3-db6110e996756672595f3d0e69b8e96977a534e0.tar.gz re3-db6110e996756672595f3d0e69b8e96977a534e0.tar.bz2 re3-db6110e996756672595f3d0e69b8e96977a534e0.tar.lz re3-db6110e996756672595f3d0e69b8e96977a534e0.tar.xz re3-db6110e996756672595f3d0e69b8e96977a534e0.tar.zst re3-db6110e996756672595f3d0e69b8e96977a534e0.zip |
Diffstat (limited to '')
-rw-r--r-- | src/core/Collision.cpp | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/core/Collision.cpp b/src/core/Collision.cpp index b68214af..77e28a10 100644 --- a/src/core/Collision.cpp +++ b/src/core/Collision.cpp @@ -1801,6 +1801,21 @@ CColSphere::Set(float radius, const CVector ¢er, uint8 surf, uint8 piece) this->piece = piece; } +bool +CColSphere::IntersectRay(CVector const& from, CVector const& dir, CVector &entry, CVector &exit) +{ + CVector distToCenter = from - center; + float distToTouchSqr = distToCenter.MagnitudeSqr() - sq(radius); + float root1, root2; + + if (!CGeneral::SolveQuadratic(1.0f, DotProduct(distToCenter, dir) * 2.f, distToTouchSqr, root1, root2)) + return false; + + entry = from + dir * root1; + exit = from + dir * root2; + return true; +} + void CColBox::Set(const CVector &min, const CVector &max, uint8 surf, uint8 piece) { |