The blocky mesher is a lot faster now.

This commit is contained in:
Relintai 2020-04-07 14:23:20 +02:00
parent 40535bfb59
commit f7842e1ab2
4 changed files with 73 additions and 46 deletions

View File

@ -58,7 +58,7 @@ void VoxelSurface::set_library(Ref<VoxelmanLibrary> library) {
_library = (*library); _library = (*library);
} }
Vector2 VoxelSurface::transform_uv(const VoxelSurfaceSides p_side, const Vector2 p_uv) const { _FORCE_INLINE_ Vector2 VoxelSurface::transform_uv(const VoxelSurfaceSides p_side, const Vector2 p_uv) const {
Vector2 uv = p_uv; Vector2 uv = p_uv;
Rect2 r = _rects[p_side]; Rect2 r = _rects[p_side];
@ -71,7 +71,7 @@ Vector2 VoxelSurface::transform_uv(const VoxelSurfaceSides p_side, const Vector2
return uv; return uv;
} }
Vector2 VoxelSurface::transform_uv_scaled(const VoxelSurfaceSides p_side, const Vector2 p_uv, int p_current_x, int p_current_y, int p_max) const { _FORCE_INLINE_ Vector2 VoxelSurface::transform_uv_scaled(const VoxelSurfaceSides p_side, const Vector2 p_uv, int p_current_x, int p_current_y, int p_max) const {
Vector2 uv = p_uv; Vector2 uv = p_uv;
Rect2 r = _rects[p_side]; Rect2 r = _rects[p_side];

View File

@ -38,17 +38,44 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
float voxel_scale = get_voxel_scale(); float voxel_scale = get_voxel_scale();
uint8_t *channel_type = chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_TYPE);
uint8_t *channel_color_r = NULL;
uint8_t *channel_color_g = NULL;
uint8_t *channel_color_b = NULL;
uint8_t *channel_ao = NULL;
uint8_t *channel_rao = NULL;
Color base_light(_base_light_value, _base_light_value, _base_light_value); Color base_light(_base_light_value, _base_light_value, _base_light_value);
Color light; Color light;
bool use_lighting = (get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_LIGHTING) != 0; bool use_lighting = (get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_LIGHTING) != 0;
bool use_ao = (get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_AO) != 0; bool use_ao = (get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_AO) != 0;
bool use_rao = (get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_RAO) != 0; bool use_rao = (get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_RAO) != 0;
for (int y = 0; y < y_size; ++y) { if (use_lighting) {
for (int z = 0; z < z_size; ++z) { channel_color_r = chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R);
for (int x = 0; x < x_size; ++x) { channel_color_g = chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G);
channel_color_b = chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B);
uint8_t type = chunk->get_voxel(x, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE); if (use_ao)
channel_ao = chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_AO);
if (use_rao)
channel_rao = chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO);
}
for (int y = chunk->get_margin_start(); y < y_size; ++y) {
for (int z = chunk->get_margin_start(); z < z_size; ++z) {
for (int x = chunk->get_margin_start(); x < x_size; ++x) {
int index = chunk->get_data_index(x, y, z);
int indexxp = chunk->get_data_index(x + 1, y, z);
int indexxn = chunk->get_data_index(x - 1, y, z);
int indexyp = chunk->get_data_index(x, y + 1, z);
int indexyn = chunk->get_data_index(x, y - 1, z);
int indexzp = chunk->get_data_index(x, y, z + 1);
int indexzn = chunk->get_data_index(x, y, z - 1);
uint8_t type = channel_type[index];
if (type == 0) if (type == 0)
continue; continue;
@ -59,28 +86,28 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
continue; continue;
uint8_t neighbours[] = { uint8_t neighbours[] = {
chunk->get_voxel(x + 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE), channel_type[indexxp],
chunk->get_voxel(x - 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE), channel_type[indexxn],
chunk->get_voxel(x, y + 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE), channel_type[indexyp],
chunk->get_voxel(x, y - 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE), channel_type[indexyn],
chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE), channel_type[indexzp],
chunk->get_voxel(x, y, z - 1, VoxelChunkDefault::DEFAULT_CHANNEL_TYPE), channel_type[indexzn],
}; };
//x + 1 //x + 1
if (neighbours[0] == 0) { if (neighbours[0] == 0) {
if (use_lighting) { if (use_lighting) {
light = Color(chunk->get_voxel(x + 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R) / 255.0, light = Color(channel_color_r[indexxp] / 255.0,
chunk->get_voxel(x + 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G) / 255.0, channel_color_g[indexxp] / 255.0,
chunk->get_voxel(x + 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B) / 255.0); channel_color_b[indexxp] / 255.0);
float ao = 0; float ao = 0;
if (use_ao) if (use_ao)
ao = chunk->get_voxel(x + 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_AO) / 255.0; ao = channel_ao[indexxp] / 255.0;
if (use_rao) { if (use_rao) {
float rao = chunk->get_voxel(x + 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO) / 255.0; float rao = channel_rao[indexxp] / 255.0;
ao += rao; ao += rao;
} }
@ -130,17 +157,17 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
//x - 1 //x - 1
if (neighbours[1] == 0) { if (neighbours[1] == 0) {
if (use_lighting) { if (use_lighting) {
light = Color(chunk->get_voxel(x - 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R) / 255.0, light = Color(channel_color_r[indexxn] / 255.0,
chunk->get_voxel(x - 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G) / 255.0, channel_color_g[indexxn] / 255.0,
chunk->get_voxel(x - 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B) / 255.0); channel_color_b[indexxn] / 255.0);
float ao = 0; float ao = 0;
if (use_ao) if (use_ao)
ao = chunk->get_voxel(x - 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_AO) / 255.0; ao = channel_ao[indexxn] / 255.0;
if (use_rao) { if (use_rao) {
float rao = chunk->get_voxel(x - 1, y, z, VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO) / 255.0; float rao = channel_rao[indexxn] / 255.0;
ao += rao; ao += rao;
} }
@ -191,17 +218,17 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
//y + 1 //y + 1
if (neighbours[2] == 0) { if (neighbours[2] == 0) {
if (use_lighting) { if (use_lighting) {
light = Color(chunk->get_voxel(x, y + 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R) / 255.0, light = Color(channel_color_r[indexyp] / 255.0,
chunk->get_voxel(x, y + 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G) / 255.0, channel_color_g[indexyp] / 255.0,
chunk->get_voxel(x, y + 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B) / 255.0); channel_color_b[indexyp] / 255.0);
float ao = 0; float ao = 0;
if (use_ao) if (use_ao)
ao = chunk->get_voxel(x, y + 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_AO) / 255.0; ao = channel_ao[indexyp] / 255.0;
if (use_rao) { if (use_rao) {
float rao = chunk->get_voxel(x, y + 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO) / 255.0; float rao = channel_rao[indexyp] / 255.0;
ao += rao; ao += rao;
} }
@ -251,17 +278,17 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
//y - 1 //y - 1
if (neighbours[3] == 0) { if (neighbours[3] == 0) {
if (use_lighting) { if (use_lighting) {
light = Color(chunk->get_voxel(x, y - 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R) / 255.0, light = Color(channel_color_r[indexyn] / 255.0,
chunk->get_voxel(x, y - 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G) / 255.0, channel_color_g[indexyn] / 255.0,
chunk->get_voxel(x, y - 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B) / 255.0); channel_color_b[indexyn] / 255.0);
float ao = 0; float ao = 0;
if (use_ao) if (use_ao)
ao = chunk->get_voxel(x, y - 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_AO) / 255.0; ao = channel_ao[indexyn] / 255.0;
if (use_rao) { if (use_rao) {
float rao = chunk->get_voxel(x, y - 1, z, VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO) / 255.0; float rao = channel_rao[indexyn] / 255.0;
ao += rao; ao += rao;
} }
@ -312,17 +339,17 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
//z + 1 //z + 1
if (neighbours[4] == 0) { if (neighbours[4] == 0) {
if (use_lighting) { if (use_lighting) {
light = Color(chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R) / 255.0, light = Color(channel_color_r[indexzp] / 255.0,
chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G) / 255.0, channel_color_g[indexzp] / 255.0,
chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B) / 255.0); channel_color_b[indexzp] / 255.0);
float ao = 0; float ao = 0;
if (use_ao) if (use_ao)
ao = chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_AO) / 255.0; ao = channel_ao[indexzp] / 255.0;
if (use_rao) { if (use_rao) {
float rao = chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO) / 255.0; float rao = channel_rao[indexzp] / 255.0;
ao += rao; ao += rao;
} }
@ -372,17 +399,17 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
//z - 1 //z - 1
if (neighbours[5] == 0) { if (neighbours[5] == 0) {
if (use_lighting) { if (use_lighting) {
light = Color(chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_R) / 255.0, light = Color(channel_color_r[indexzn] / 255.0,
chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_G) / 255.0, channel_color_g[indexzn] / 255.0,
chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_LIGHT_COLOR_B) / 255.0); channel_color_b[indexzn] / 255.0);
float ao = 0; float ao = 0;
if (use_ao) if (use_ao)
ao = chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_AO) / 255.0; ao = channel_ao[indexzn] / 255.0;
if (use_rao) { if (use_rao) {
float rao = chunk->get_voxel(x, y, z + 1, VoxelChunkDefault::DEFAULT_CHANNEL_RANDOM_AO) / 255.0; float rao = channel_rao[indexzn] / 255.0;
ao += rao; ao += rao;
} }

View File

@ -467,11 +467,11 @@ void VoxelChunk::set_channel_compressed(int channel_index, const PoolByteArray &
LZ4_decompress_safe(reinterpret_cast<char *>(data_arr), reinterpret_cast<char *>(ch), ds, size); LZ4_decompress_safe(reinterpret_cast<char *>(data_arr), reinterpret_cast<char *>(ch), ds, size);
} }
_FORCE_INLINE_ uint32_t VoxelChunk::get_data_index(uint32_t x, uint32_t y, uint32_t z) const { _FORCE_INLINE_ int VoxelChunk::get_data_index(const int x, const int y, const int z) const {
return y + _data_size_y * (x + _data_size_x * z); return y + _data_size_y * (x + _data_size_x * z);
} }
_FORCE_INLINE_ uint32_t VoxelChunk::get_data_size() const { _FORCE_INLINE_ int VoxelChunk::get_data_size() const {
return _data_size_x * _data_size_y * _data_size_z; return _data_size_x * _data_size_y * _data_size_z;
} }

View File

@ -156,8 +156,8 @@ public:
PoolByteArray get_channel_compressed(int channel_index) const; PoolByteArray get_channel_compressed(int channel_index) const;
void set_channel_compressed(int channel_index, const PoolByteArray &data); void set_channel_compressed(int channel_index, const PoolByteArray &data);
uint32_t get_data_index(uint32_t x, uint32_t y, uint32_t z) const; int get_data_index(int x, int y, int z) const;
uint32_t get_data_size() const; int get_data_size() const;
//Meshing //Meshing
void create_meshers(); void create_meshers();