mirror of
https://github.com/Relintai/voxelman.git
synced 2025-01-12 15:01:09 +01:00
Implement texture scale for the blocky mesher. Also added an option to add vertex colors even whe n lighting is off.
This commit is contained in:
parent
64b9476eca
commit
eea8309352
@ -24,12 +24,20 @@ SOFTWARE.
|
|||||||
|
|
||||||
#include "../../world/default/voxel_chunk_default.h"
|
#include "../../world/default/voxel_chunk_default.h"
|
||||||
|
|
||||||
|
bool VoxelMesherBlocky::get_always_add_colors() const {
|
||||||
|
return _always_add_colors;
|
||||||
|
}
|
||||||
|
void VoxelMesherBlocky::set_always_add_colors(const bool value) {
|
||||||
|
_always_add_colors = value;
|
||||||
|
}
|
||||||
|
|
||||||
void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
||||||
Ref<VoxelChunkDefault> chunk = p_chunk;
|
Ref<VoxelChunkDefault> chunk = p_chunk;
|
||||||
|
|
||||||
ERR_FAIL_COND(!chunk.is_valid());
|
ERR_FAIL_COND(!chunk.is_valid());
|
||||||
|
|
||||||
if ((get_build_flags() & VoxelChunkDefault::BUILD_FLAG_GENERATE_AO) != 0)
|
if ((get_build_flags() & VoxelChunkDefault::BUILD_FLAG_GENERATE_AO) != 0)
|
||||||
|
if (!chunk->get_channel(VoxelChunkDefault::DEFAULT_CHANNEL_AO))
|
||||||
chunk->generate_ao();
|
chunk->generate_ao();
|
||||||
|
|
||||||
int x_size = chunk->get_size_x();
|
int x_size = chunk->get_size_x();
|
||||||
@ -50,7 +58,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
uint8_t *channel_rao = 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(1, 1, 1);
|
||||||
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;
|
||||||
@ -154,10 +162,10 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
add_indices(vc + 0);
|
add_indices(vc + 0);
|
||||||
|
|
||||||
Vector2 uvs[] = {
|
Vector2 uvs[] = {
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1))
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale())
|
||||||
};
|
};
|
||||||
|
|
||||||
Vector3 verts[] = {
|
Vector3 verts[] = {
|
||||||
@ -170,7 +178,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
add_normal(Vector3(1, 0, 0));
|
add_normal(Vector3(1, 0, 0));
|
||||||
|
|
||||||
if (use_lighting)
|
if (use_lighting || _always_add_colors)
|
||||||
add_color(light);
|
add_color(light);
|
||||||
|
|
||||||
add_uv(uvs[i]);
|
add_uv(uvs[i]);
|
||||||
@ -215,10 +223,10 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
add_indices(vc + 3);
|
add_indices(vc + 3);
|
||||||
|
|
||||||
Vector2 uvs[] = {
|
Vector2 uvs[] = {
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1))
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale())
|
||||||
};
|
};
|
||||||
|
|
||||||
Vector3 verts[] = {
|
Vector3 verts[] = {
|
||||||
@ -231,7 +239,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
add_normal(Vector3(-1, 0, 0));
|
add_normal(Vector3(-1, 0, 0));
|
||||||
|
|
||||||
if (use_lighting)
|
if (use_lighting || _always_add_colors)
|
||||||
add_color(light);
|
add_color(light);
|
||||||
|
|
||||||
add_uv(uvs[i]);
|
add_uv(uvs[i]);
|
||||||
@ -275,10 +283,10 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
add_indices(vc + 0);
|
add_indices(vc + 0);
|
||||||
|
|
||||||
Vector2 uvs[] = {
|
Vector2 uvs[] = {
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_TOP, Vector2(0, 1)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_TOP, Vector2(0, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_TOP, Vector2(1, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_TOP, Vector2(1, 1))
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale())
|
||||||
};
|
};
|
||||||
|
|
||||||
Vector3 verts[] = {
|
Vector3 verts[] = {
|
||||||
@ -291,7 +299,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
add_normal(Vector3(0, 1, 0));
|
add_normal(Vector3(0, 1, 0));
|
||||||
|
|
||||||
if (use_lighting)
|
if (use_lighting || _always_add_colors)
|
||||||
add_color(light);
|
add_color(light);
|
||||||
|
|
||||||
add_uv(uvs[i]);
|
add_uv(uvs[i]);
|
||||||
@ -336,10 +344,10 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
add_indices(vc + 3);
|
add_indices(vc + 3);
|
||||||
|
|
||||||
Vector2 uvs[] = {
|
Vector2 uvs[] = {
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_BOTTOM, Vector2(0, 1)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_BOTTOM, Vector2(0, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_BOTTOM, Vector2(1, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_BOTTOM, Vector2(1, 1))
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale())
|
||||||
};
|
};
|
||||||
|
|
||||||
Vector3 verts[] = {
|
Vector3 verts[] = {
|
||||||
@ -352,7 +360,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
add_normal(Vector3(0, -1, 0));
|
add_normal(Vector3(0, -1, 0));
|
||||||
|
|
||||||
if (use_lighting)
|
if (use_lighting || _always_add_colors)
|
||||||
add_color(light);
|
add_color(light);
|
||||||
|
|
||||||
add_uv(uvs[i]);
|
add_uv(uvs[i]);
|
||||||
@ -396,10 +404,10 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
add_indices(vc + 0);
|
add_indices(vc + 0);
|
||||||
|
|
||||||
Vector2 uvs[] = {
|
Vector2 uvs[] = {
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1))
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale())
|
||||||
};
|
};
|
||||||
|
|
||||||
Vector3 verts[] = {
|
Vector3 verts[] = {
|
||||||
@ -412,7 +420,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
add_normal(Vector3(0, 0, 1));
|
add_normal(Vector3(0, 0, 1));
|
||||||
|
|
||||||
if (use_lighting)
|
if (use_lighting || _always_add_colors)
|
||||||
add_color(light);
|
add_color(light);
|
||||||
|
|
||||||
add_uv(uvs[i]);
|
add_uv(uvs[i]);
|
||||||
@ -457,10 +465,10 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
add_indices(vc + 3);
|
add_indices(vc + 3);
|
||||||
|
|
||||||
Vector2 uvs[] = {
|
Vector2 uvs[] = {
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(0, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0)),
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 0), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale()),
|
||||||
surface->transform_uv(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1))
|
surface->transform_uv_scaled(VoxelSurface::VOXEL_SIDE_SIDE, Vector2(1, 1), x % get_texture_scale(), z % get_texture_scale(), get_texture_scale())
|
||||||
};
|
};
|
||||||
|
|
||||||
Vector3 verts[] = {
|
Vector3 verts[] = {
|
||||||
@ -473,7 +481,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
add_normal(Vector3(0, 0, -1));
|
add_normal(Vector3(0, 0, -1));
|
||||||
|
|
||||||
if (use_lighting)
|
if (use_lighting || _always_add_colors)
|
||||||
add_color(light);
|
add_color(light);
|
||||||
|
|
||||||
add_uv(uvs[i]);
|
add_uv(uvs[i]);
|
||||||
@ -486,6 +494,7 @@ void VoxelMesherBlocky::_add_chunk(Ref<VoxelChunk> p_chunk) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
VoxelMesherBlocky::VoxelMesherBlocky() {
|
VoxelMesherBlocky::VoxelMesherBlocky() {
|
||||||
|
_always_add_colors = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
VoxelMesherBlocky::~VoxelMesherBlocky() {
|
VoxelMesherBlocky::~VoxelMesherBlocky() {
|
||||||
@ -493,4 +502,8 @@ VoxelMesherBlocky::~VoxelMesherBlocky() {
|
|||||||
|
|
||||||
void VoxelMesherBlocky::_bind_methods() {
|
void VoxelMesherBlocky::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("_add_chunk", "buffer"), &VoxelMesherBlocky::_add_chunk);
|
ClassDB::bind_method(D_METHOD("_add_chunk", "buffer"), &VoxelMesherBlocky::_add_chunk);
|
||||||
|
|
||||||
|
ClassDB::bind_method(D_METHOD("get_always_add_colors"), &VoxelMesherBlocky::get_always_add_colors);
|
||||||
|
ClassDB::bind_method(D_METHOD("set_always_add_colors", "value"), &VoxelMesherBlocky::set_always_add_colors);
|
||||||
|
ADD_PROPERTY(PropertyInfo(Variant::INT, "always_add_colors"), "set_always_add_colors", "get_always_add_colors");
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,9 @@ class VoxelMesherBlocky : public VoxelMesherDefault {
|
|||||||
GDCLASS(VoxelMesherBlocky, VoxelMesherDefault);
|
GDCLASS(VoxelMesherBlocky, VoxelMesherDefault);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
bool get_always_add_colors() const;
|
||||||
|
void set_always_add_colors(const bool value);
|
||||||
|
|
||||||
void _add_chunk(Ref<VoxelChunk> p_chunk);
|
void _add_chunk(Ref<VoxelChunk> p_chunk);
|
||||||
|
|
||||||
VoxelMesherBlocky();
|
VoxelMesherBlocky();
|
||||||
@ -40,6 +43,9 @@ public:
|
|||||||
|
|
||||||
protected:
|
protected:
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
|
|
||||||
|
private:
|
||||||
|
bool _always_add_colors;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -45,8 +45,8 @@ _FORCE_INLINE_ void VoxelMesherDefault::set_build_flags(const int flags) {
|
|||||||
void VoxelMesherDefault::_bake_colors(Ref<VoxelChunk> chunk) {
|
void VoxelMesherDefault::_bake_colors(Ref<VoxelChunk> chunk) {
|
||||||
ERR_FAIL_COND(!chunk.is_valid());
|
ERR_FAIL_COND(!chunk.is_valid());
|
||||||
|
|
||||||
if ((get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_LIGHTING) == 0)
|
//if ((get_build_flags() & VoxelChunkDefault::BUILD_FLAG_USE_LIGHTING) == 0)
|
||||||
return;
|
// return;
|
||||||
|
|
||||||
if (_vertices.size() == 0)
|
if (_vertices.size() == 0)
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user