diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-01-04 16:39:23 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-01-04 16:39:23 +0100 |
commit | acd37f98c045ab8c57430caa4bdec2d60ccacb3c (patch) | |
tree | 77d40eb0ab716056408317a1a97e2768a8468868 /core/math | |
parent | 150f2a75b2f3b39f4e6ff02e00d966b0b1680c0a (diff) | |
parent | bc78c832e98bb8e9b36a4d236d5ad9ce36de66c5 (diff) | |
download | redot-engine-acd37f98c045ab8c57430caa4bdec2d60ccacb3c.tar.gz |
Merge pull request #83353 from Chubercik/expose_delaunay_3d
Expose 3D Delaunay tetrahedralization in `Geometry3D`
Diffstat (limited to 'core/math')
-rw-r--r-- | core/math/geometry_3d.h | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/core/math/geometry_3d.h b/core/math/geometry_3d.h index 99c554fe05..305a64e39c 100644 --- a/core/math/geometry_3d.h +++ b/core/math/geometry_3d.h @@ -31,6 +31,7 @@ #ifndef GEOMETRY_3D_H #define GEOMETRY_3D_H +#include "core/math/delaunay_3d.h" #include "core/math/face3.h" #include "core/object/object.h" #include "core/templates/local_vector.h" @@ -532,6 +533,21 @@ public: return clipped; } + static Vector<int32_t> tetrahedralize_delaunay(const Vector<Vector3> &p_points) { + Vector<Delaunay3D::OutputSimplex> tetr = Delaunay3D::tetrahedralize(p_points); + Vector<int32_t> tetrahedrons; + + tetrahedrons.resize(4 * tetr.size()); + int32_t *ptr = tetrahedrons.ptrw(); + for (int i = 0; i < tetr.size(); i++) { + *ptr++ = tetr[i].points[0]; + *ptr++ = tetr[i].points[1]; + *ptr++ = tetr[i].points[2]; + *ptr++ = tetr[i].points[3]; + } + return tetrahedrons; + } + // Create a "wrap" that encloses the given geometry. static Vector<Face3> wrap_geometry(Vector<Face3> p_array, real_t *p_error = nullptr); |