2019-04-20 17:32:10 +01:00
|
|
|
#ifndef VOXEL_MESHER_DMC_H
|
|
|
|
#define VOXEL_MESHER_DMC_H
|
|
|
|
|
|
|
|
#include "../voxel_buffer.h"
|
2019-04-22 23:36:42 +01:00
|
|
|
#include "hermite_value.h"
|
2019-04-21 01:14:28 +01:00
|
|
|
#include "mesh_builder.h"
|
2019-04-23 00:47:52 +01:00
|
|
|
#include "object_pool.h"
|
2019-04-20 17:32:10 +01:00
|
|
|
#include "scene/resources/mesh.h"
|
|
|
|
|
2019-04-22 23:36:42 +01:00
|
|
|
namespace dmc {
|
|
|
|
|
2019-04-23 00:47:52 +01:00
|
|
|
struct OctreeNode;
|
|
|
|
typedef ObjectPool<OctreeNode> 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;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-04-22 23:36:42 +01:00
|
|
|
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<DualCell> cells;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace dmc
|
|
|
|
|
2019-04-20 17:32:10 +01:00
|
|
|
class VoxelMesherDMC : public Reference {
|
|
|
|
GDCLASS(VoxelMesherDMC, Reference)
|
|
|
|
public:
|
2019-04-20 21:21:45 +01:00
|
|
|
enum Mode {
|
|
|
|
MODE_NORMAL,
|
|
|
|
MODE_WIREFRAME,
|
|
|
|
MODE_DEBUG_OCTREE,
|
|
|
|
MODE_DEBUG_DUAL_GRID
|
|
|
|
};
|
|
|
|
|
2019-04-21 19:31:35 +01:00
|
|
|
Ref<ArrayMesh> build_mesh(const VoxelBuffer &voxels, real_t geometric_error, Mode mode);
|
2019-04-22 23:03:57 +01:00
|
|
|
Dictionary get_stats() const;
|
2019-04-20 17:32:10 +01:00
|
|
|
|
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
2019-04-21 19:31:35 +01:00
|
|
|
Ref<ArrayMesh> _build_mesh_b(Ref<VoxelBuffer> voxels, real_t geometric_error, Mode mode);
|
2019-04-21 01:14:28 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
dmc::MeshBuilder _mesh_builder;
|
2019-04-22 23:36:42 +01:00
|
|
|
dmc::DualGrid _dual_grid;
|
2019-04-23 00:47:52 +01:00
|
|
|
dmc::OctreeNodePool _octree_node_pool;
|
2019-04-22 23:03:57 +01:00
|
|
|
|
|
|
|
struct Stats {
|
|
|
|
real_t octree_build_time;
|
|
|
|
real_t dualgrid_derivation_time;
|
|
|
|
real_t meshing_time;
|
|
|
|
real_t commit_time;
|
|
|
|
};
|
|
|
|
|
|
|
|
Stats _stats;
|
2019-04-20 17:32:10 +01:00
|
|
|
};
|
|
|
|
|
2019-04-20 21:21:45 +01:00
|
|
|
VARIANT_ENUM_CAST(VoxelMesherDMC::Mode)
|
|
|
|
|
2019-04-20 17:32:10 +01:00
|
|
|
#endif // VOXEL_MESHER_DMC_H
|