diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2024-02-12 23:25:00 +0000 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2024-02-12 23:25:00 +0000 |
commit | 68a23b27925142fed3b1e53b2f17ad2c90878e21 (patch) | |
tree | b73ee9841244a82bcfffed5eb1f3e77dad494bcd /game/geoData.cpp | |
parent | Create flat GeoData as 10m squares instead of one big square (diff) | |
download | ilt-68a23b27925142fed3b1e53b2f17ad2c90878e21.tar.bz2 ilt-68a23b27925142fed3b1e53b2f17ad2c90878e21.tar.xz ilt-68a23b27925142fed3b1e53b2f17ad2c90878e21.zip |
Add helpers for testing for triangle overlap/containedness
Diffstat (limited to 'game/geoData.cpp')
-rw-r--r-- | game/geoData.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/game/geoData.cpp b/game/geoData.cpp index 49cf892..ae43f3f 100644 --- a/game/geoData.cpp +++ b/game/geoData.cpp @@ -359,3 +359,19 @@ GeoData::update_vertex_normals_only() this->set_normal(vh, glm::normalize(n)); } } + +bool +GeoData::triangleOverlapsTriangle(const Triangle<2> & a, const Triangle<2> & b) +{ + return triangleContainsPoint(a.x, b) || triangleContainsPoint(a.y, b) || triangleContainsPoint(a.z, b) + || triangleContainsPoint(b.x, a) || triangleContainsPoint(b.y, a) || triangleContainsPoint(b.z, a) + || linesCross(a.x, a.y, b.x, b.y) || linesCross(a.x, a.y, b.y, b.z) || linesCross(a.x, a.y, b.z, b.x) + || linesCross(a.y, a.z, b.x, b.y) || linesCross(a.y, a.z, b.y, b.z) || linesCross(a.y, a.z, b.z, b.x) + || linesCross(a.z, a.x, b.x, b.y) || linesCross(a.z, a.x, b.y, b.z) || linesCross(a.z, a.x, b.z, b.x); +} + +bool +GeoData::triangleContainsTriangle(const Triangle<2> & a, const Triangle<2> & b) +{ + return triangleContainsPoint(a.x, b) && triangleContainsPoint(a.y, b) && triangleContainsPoint(a.z, b); +} |