#ifndef VOXEL_MESHER_DMC_H #define VOXEL_MESHER_DMC_H #include "../voxel_buffer.h" #include "hermite_value.h" #include "mesh_builder.h" #include "object_pool.h" #include "scene/resources/mesh.h" namespace dmc { struct OctreeNode; typedef ObjectPool OctreeNodePool; // Octree used only for dual grid construction struct OctreeNode { Vector3i origin; int size; // Nodes are cubic HermiteValue center_value; OctreeNode *children[8]; OctreeNode() { init(); } inline void init() { for (int i = 0; i < 8; ++i) { children[i] = nullptr; } } void recycle(OctreeNodePool &pool) { for (int i = 0; i < 8; ++i) { if (children[i]) { pool.recycle(children[i]); } } } inline bool has_children() const { return children[0] != nullptr; } }; struct DualCell { Vector3 corners[8]; HermiteValue values[8]; bool has_values; DualCell() : has_values(false) {} inline void set_corner(int i, Vector3 vertex, HermiteValue value) { CRASH_COND(i < 0 || i >= 8); corners[i] = vertex; values[i] = value; } }; struct DualGrid { std::vector cells; }; } // namespace dmc class VoxelMesherDMC : public Reference { GDCLASS(VoxelMesherDMC, Reference) public: enum Mode { MODE_NORMAL, MODE_WIREFRAME, MODE_DEBUG_OCTREE, MODE_DEBUG_DUAL_GRID }; Ref build_mesh(const VoxelBuffer &voxels, real_t geometric_error, Mode mode); Dictionary get_stats() const; protected: static void _bind_methods(); Ref _build_mesh_b(Ref voxels, real_t geometric_error, Mode mode); private: dmc::MeshBuilder _mesh_builder; dmc::DualGrid _dual_grid; dmc::OctreeNodePool _octree_node_pool; struct Stats { real_t octree_build_time; real_t dualgrid_derivation_time; real_t meshing_time; real_t commit_time; }; Stats _stats; }; VARIANT_ENUM_CAST(VoxelMesherDMC::Mode) #endif // VOXEL_MESHER_DMC_H