Merge pull request #170 from lioncash/collision

CollisionUtil: Replace FINDMINMAX macro with std::minmax()
This commit is contained in:
Luke S 2020-02-28 10:36:46 -05:00 committed by GitHub
commit 55521fb5df
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 6 additions and 14 deletions

View File

@ -1,5 +1,8 @@
#include "Runtime/Collision/CollisionUtil.hpp" #include "Runtime/Collision/CollisionUtil.hpp"
#include <algorithm>
#include <tuple>
#include "Runtime/Collision/CCollisionInfo.hpp" #include "Runtime/Collision/CCollisionInfo.hpp"
#include "Runtime/Collision/CCollisionInfoList.hpp" #include "Runtime/Collision/CCollisionInfoList.hpp"
@ -390,17 +393,6 @@ bool AABoxAABoxIntersection(const zeus::CAABox& aabb0, const zeus::CAABox& aabb1
/* Thanks to David Hunt for finding a ">="-bug! */ /* Thanks to David Hunt for finding a ">="-bug! */
/********************************************************/ /********************************************************/
#define FINDMINMAX(x0, x1, x2, min, max) \
min = max = x0; \
if (x1 < min) \
min = x1; \
if (x1 > max) \
max = x1; \
if (x2 < min) \
min = x2; \
if (x2 > max) \
max = x2;
static bool planeBoxOverlap(const zeus::CVector3f& normal, float d, const zeus::CVector3f& maxbox) { static bool planeBoxOverlap(const zeus::CVector3f& normal, float d, const zeus::CVector3f& maxbox) {
zeus::CVector3f vmin, vmax; zeus::CVector3f vmin, vmax;
for (int q = 0; q <= 2; q++) { for (int q = 0; q <= 2; q++) {
@ -563,17 +555,17 @@ bool TriBoxOverlap(const zeus::CVector3f& boxcenter, const zeus::CVector3f& boxh
/* the triangle against the AABB */ /* the triangle against the AABB */
/* test in X-direction */ /* test in X-direction */
FINDMINMAX(v0.x(), v1.x(), v2.x(), min, max); std::tie(min, max) = std::minmax<float>({v0.x(), v1.x(), v2.x()});
if (min > boxhalfsize.x() || max < -boxhalfsize.x()) if (min > boxhalfsize.x() || max < -boxhalfsize.x())
return false; return false;
/* test in Y-direction */ /* test in Y-direction */
FINDMINMAX(v0.y(), v1.y(), v2.y(), min, max); std::tie(min, max) = std::minmax<float>({v0.y(), v1.y(), v2.y()});
if (min > boxhalfsize.y() || max < -boxhalfsize.y()) if (min > boxhalfsize.y() || max < -boxhalfsize.y())
return false; return false;
/* test in Z-direction */ /* test in Z-direction */
FINDMINMAX(v0.z(), v1.z(), v2.z(), min, max); std::tie(min, max) = std::minmax<float>({v0.z(), v1.z(), v2.z()});
if (min > boxhalfsize.z() || max < -boxhalfsize.z()) if (min > boxhalfsize.z() || max < -boxhalfsize.z())
return false; return false;