mirror of
https://github.com/Relintai/voxelman.git
synced 2025-01-27 15:19:18 +01:00
Now the base light value is settable in the Cubic Voxel Mesher.
This commit is contained in:
parent
469773a9fd
commit
7db42b88a1
@ -7,6 +7,14 @@ void VoxelMesherCubic::set_ao_strength(float value) {
|
|||||||
_ao_strength = value;
|
_ao_strength = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
float VoxelMesherCubic::get_base_light_value() const {
|
||||||
|
return _base_light_value;
|
||||||
|
}
|
||||||
|
void VoxelMesherCubic::set_base_light_value(float value) {
|
||||||
|
_base_light_value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void VoxelMesherCubic::_add_buffer(Ref<VoxelBuffer> buffer) {
|
void VoxelMesherCubic::_add_buffer(Ref<VoxelBuffer> buffer) {
|
||||||
buffer->generate_ao();
|
buffer->generate_ao();
|
||||||
|
|
||||||
@ -23,7 +31,7 @@ void VoxelMesherCubic::_add_buffer(Ref<VoxelBuffer> buffer) {
|
|||||||
cube_points.instance();
|
cube_points.instance();
|
||||||
|
|
||||||
float tile_uv_size = 1 / 4.0;
|
float tile_uv_size = 1 / 4.0;
|
||||||
Color base_light(0.4, 0.4, 0.4);
|
Color base_light(_base_light_value, _base_light_value, _base_light_value);
|
||||||
|
|
||||||
for (int y = lod_size; y < y_size - lod_size; y += lod_size) {
|
for (int y = lod_size; y < y_size - lod_size; y += lod_size) {
|
||||||
for (int z = lod_size; z < z_size - lod_size; z += lod_size) {
|
for (int z = lod_size; z < z_size - lod_size; z += lod_size) {
|
||||||
@ -88,6 +96,7 @@ void VoxelMesherCubic::_add_buffer(Ref<VoxelBuffer> buffer) {
|
|||||||
|
|
||||||
VoxelMesherCubic::VoxelMesherCubic() {
|
VoxelMesherCubic::VoxelMesherCubic() {
|
||||||
_ao_strength = 0.25;
|
_ao_strength = 0.25;
|
||||||
|
_base_light_value = 0.5;
|
||||||
}
|
}
|
||||||
|
|
||||||
VoxelMesherCubic::~VoxelMesherCubic() {
|
VoxelMesherCubic::~VoxelMesherCubic() {
|
||||||
@ -99,4 +108,8 @@ void VoxelMesherCubic::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("get_ao_strength"), &VoxelMesherCubic::get_ao_strength);
|
ClassDB::bind_method(D_METHOD("get_ao_strength"), &VoxelMesherCubic::get_ao_strength);
|
||||||
ClassDB::bind_method(D_METHOD("set_ao_strength", "value"), &VoxelMesherCubic::set_ao_strength);
|
ClassDB::bind_method(D_METHOD("set_ao_strength", "value"), &VoxelMesherCubic::set_ao_strength);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::REAL, "ao_strength"), "set_ao_strength", "get_ao_strength");
|
ADD_PROPERTY(PropertyInfo(Variant::REAL, "ao_strength"), "set_ao_strength", "get_ao_strength");
|
||||||
|
|
||||||
|
ClassDB::bind_method(D_METHOD("get_base_light_value"), &VoxelMesherCubic::get_base_light_value);
|
||||||
|
ClassDB::bind_method(D_METHOD("set_base_light_value", "value"), &VoxelMesherCubic::set_base_light_value);
|
||||||
|
ADD_PROPERTY(PropertyInfo(Variant::REAL, "base_light_value"), "set_base_light_value", "get_base_light_value");
|
||||||
}
|
}
|
||||||
|
@ -16,6 +16,9 @@ public:
|
|||||||
float get_ao_strength() const;
|
float get_ao_strength() const;
|
||||||
void set_ao_strength(float value);
|
void set_ao_strength(float value);
|
||||||
|
|
||||||
|
float get_base_light_value() const;
|
||||||
|
void set_base_light_value(float value);
|
||||||
|
|
||||||
void _add_buffer(Ref<VoxelBuffer> buffer);
|
void _add_buffer(Ref<VoxelBuffer> buffer);
|
||||||
|
|
||||||
VoxelMesherCubic();
|
VoxelMesherCubic();
|
||||||
@ -26,6 +29,7 @@ protected:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
float _ao_strength;
|
float _ao_strength;
|
||||||
|
float _base_light_value;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -143,12 +143,7 @@ void VoxelChunk::build() {
|
|||||||
ERR_FAIL_COND(!_library.is_valid());
|
ERR_FAIL_COND(!_library.is_valid());
|
||||||
|
|
||||||
if (!_mesher.is_valid()) {
|
if (!_mesher.is_valid()) {
|
||||||
call("_create_mesher");
|
create_mesher();
|
||||||
|
|
||||||
ERR_FAIL_COND(!_mesher.is_valid());
|
|
||||||
|
|
||||||
_mesher->set_lod_size(get_lod_size());
|
|
||||||
_mesher->set_voxel_scale(get_voxel_scale());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_mesher->set_library(_library);
|
_mesher->set_library(_library);
|
||||||
@ -176,6 +171,15 @@ void VoxelChunk::build() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VoxelChunk::create_mesher() {
|
||||||
|
call("_create_mesher");
|
||||||
|
|
||||||
|
ERR_FAIL_COND(!_mesher.is_valid());
|
||||||
|
|
||||||
|
_mesher->set_lod_size(get_lod_size());
|
||||||
|
_mesher->set_voxel_scale(get_voxel_scale());
|
||||||
|
}
|
||||||
|
|
||||||
void VoxelChunk::_create_mesher() {
|
void VoxelChunk::_create_mesher() {
|
||||||
_mesher = Ref<VoxelMesher>(memnew(VoxelMesherCubic()));
|
_mesher = Ref<VoxelMesher>(memnew(VoxelMesherCubic()));
|
||||||
}
|
}
|
||||||
@ -487,6 +491,8 @@ void VoxelChunk::_bind_methods() {
|
|||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("clear"), &VoxelChunk::clear);
|
ClassDB::bind_method(D_METHOD("clear"), &VoxelChunk::clear);
|
||||||
|
|
||||||
|
ClassDB::bind_method(D_METHOD("create_mesher"), &VoxelChunk::create_mesher);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("draw_debug_voxels", "max"), &VoxelChunk::draw_debug_voxels, DEFVAL(Color(1, 1, 1)));
|
ClassDB::bind_method(D_METHOD("draw_debug_voxels", "max"), &VoxelChunk::draw_debug_voxels, DEFVAL(Color(1, 1, 1)));
|
||||||
ClassDB::bind_method(D_METHOD("draw_debug_voxel_lights"), &VoxelChunk::draw_debug_voxel_lights);
|
ClassDB::bind_method(D_METHOD("draw_debug_voxel_lights"), &VoxelChunk::draw_debug_voxel_lights);
|
||||||
}
|
}
|
||||||
|
@ -75,6 +75,7 @@ public:
|
|||||||
|
|
||||||
Ref<VoxelBuffer> get_buffer() const;
|
Ref<VoxelBuffer> get_buffer() const;
|
||||||
|
|
||||||
|
void create_mesher();
|
||||||
void _create_mesher();
|
void _create_mesher();
|
||||||
|
|
||||||
void finalize_mesh();
|
void finalize_mesh();
|
||||||
|
Loading…
Reference in New Issue
Block a user