2019-04-28 20:48:59 +01:00
|
|
|
#ifndef VOXEL_MESHER_H
|
|
|
|
#define VOXEL_MESHER_H
|
|
|
|
|
2021-02-21 23:58:00 +00:00
|
|
|
#include "../constants/cube_tables.h"
|
2019-12-31 16:48:46 +00:00
|
|
|
#include "../util/fixed_array.h"
|
2019-04-28 20:48:59 +01:00
|
|
|
#include <scene/resources/mesh.h>
|
|
|
|
|
2020-09-14 19:33:02 +01:00
|
|
|
class VoxelBuffer;
|
|
|
|
|
2020-12-18 21:01:50 +00:00
|
|
|
class VoxelMesher : public Resource {
|
|
|
|
GDCLASS(VoxelMesher, Resource)
|
2019-04-28 20:48:59 +01:00
|
|
|
public:
|
2020-01-04 23:24:33 +00:00
|
|
|
struct Input {
|
|
|
|
const VoxelBuffer &voxels;
|
2020-01-06 20:08:51 +00:00
|
|
|
int lod; // = 0; // Not initialized because it confused GCC
|
2020-01-04 23:24:33 +00:00
|
|
|
};
|
|
|
|
|
2019-04-28 20:48:59 +01:00
|
|
|
struct Output {
|
2019-09-10 20:04:08 +01:00
|
|
|
// Each surface correspond to a different material
|
2019-04-28 20:48:59 +01:00
|
|
|
Vector<Array> surfaces;
|
2019-12-31 16:48:46 +00:00
|
|
|
FixedArray<Vector<Array>, Cube::SIDE_COUNT> transition_surfaces;
|
2019-12-26 20:29:55 +00:00
|
|
|
Mesh::PrimitiveType primitive_type = Mesh::PRIMITIVE_TRIANGLES;
|
|
|
|
unsigned int compression_flags = Mesh::ARRAY_COMPRESS_DEFAULT;
|
2019-04-28 20:48:59 +01:00
|
|
|
};
|
|
|
|
|
2020-12-18 21:01:50 +00:00
|
|
|
// This can be called from multiple threads at once. Make sure member vars are protected or thread-local.
|
2020-01-04 23:24:33 +00:00
|
|
|
virtual void build(Output &output, const Input &voxels);
|
2019-04-28 20:48:59 +01:00
|
|
|
|
2020-12-18 21:01:50 +00:00
|
|
|
// Builds a mesh from the given voxels. This function is simplified to be used by the script API.
|
|
|
|
Ref<Mesh> build_mesh(Ref<VoxelBuffer> voxels, Array materials);
|
|
|
|
|
|
|
|
// Gets how many neighbor voxels need to be accessed around the meshed area, toward negative axes.
|
2019-12-31 16:48:46 +00:00
|
|
|
// If this is not respected, the mesher might produce seams at the edges, or an error
|
2020-08-25 23:00:38 +01:00
|
|
|
unsigned int get_minimum_padding() const;
|
2020-12-18 21:01:50 +00:00
|
|
|
|
|
|
|
// Gets how many neighbor voxels need to be accessed around the meshed area, toward positive axes.
|
|
|
|
// If this is not respected, the mesher might produce seams at the edges, or an error
|
2020-08-25 23:00:38 +01:00
|
|
|
unsigned int get_maximum_padding() const;
|
2019-12-31 16:48:46 +00:00
|
|
|
|
2020-12-18 21:01:50 +00:00
|
|
|
virtual Ref<Resource> duplicate(bool p_subresources = false) const { return Ref<Resource>(); }
|
2019-05-19 18:27:49 +01:00
|
|
|
|
2021-07-11 16:27:17 +01:00
|
|
|
// Gets which channels this mesher is able to use in its current configuration.
|
|
|
|
// This is returned as a bitmask where channel index corresponds to bit position.
|
2020-12-18 21:01:50 +00:00
|
|
|
virtual int get_used_channels_mask() const { return 0; }
|
2019-04-28 20:48:59 +01:00
|
|
|
|
2021-07-11 16:27:17 +01:00
|
|
|
// Returns true if this mesher supports generating voxel data at multiple levels of detail.
|
2021-05-15 23:41:19 +01:00
|
|
|
virtual bool supports_lod() const { return true; }
|
|
|
|
|
2019-04-28 20:48:59 +01:00
|
|
|
protected:
|
|
|
|
static void _bind_methods();
|
2019-12-31 16:48:46 +00:00
|
|
|
|
|
|
|
void set_padding(int minimum, int maximum);
|
|
|
|
|
|
|
|
private:
|
2021-01-17 23:47:16 +00:00
|
|
|
// Set in constructor and never changed after.
|
2020-08-25 23:00:38 +01:00
|
|
|
unsigned int _minimum_padding = 0;
|
|
|
|
unsigned int _maximum_padding = 0;
|
2019-04-28 20:48:59 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // VOXEL_MESHER_H
|