summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbitsawer <sawerduster@gmail.com>2023-08-28 13:19:07 +0300
committerbitsawer <sawerduster@gmail.com>2023-08-28 13:25:34 +0300
commitc73e1f0d22a3cd12f756492e1cc0a03d74e171fa (patch)
tree6f9562406aa1a0c49a91a82a9ac576233b910959
parent713bfaf5eac1eb8a770e5ee825db29de99f3d0f7 (diff)
downloadredot-engine-c73e1f0d22a3cd12f756492e1cc0a03d74e171fa.tar.gz
Fix VoxelGI CameraAttributes exposure normalization handling
-rw-r--r--scene/3d/voxel_gi.cpp24
-rw-r--r--scene/3d/voxel_gi.h2
2 files changed, 19 insertions, 7 deletions
diff --git a/scene/3d/voxel_gi.cpp b/scene/3d/voxel_gi.cpp
index faeacec63a..43906b2586 100644
--- a/scene/3d/voxel_gi.cpp
+++ b/scene/3d/voxel_gi.cpp
@@ -270,6 +270,7 @@ VoxelGIData::~VoxelGIData() {
void VoxelGI::set_probe_data(const Ref<VoxelGIData> &p_data) {
if (p_data.is_valid()) {
RS::get_singleton()->instance_set_base(get_instance(), p_data->get_rid());
+ RS::get_singleton()->voxel_gi_set_baked_exposure_normalization(p_data->get_rid(), _get_camera_exposure_normalization());
} else {
RS::get_singleton()->instance_set_base(get_instance(), RID());
}
@@ -303,6 +304,10 @@ Vector3 VoxelGI::get_size() const {
void VoxelGI::set_camera_attributes(const Ref<CameraAttributes> &p_camera_attributes) {
camera_attributes = p_camera_attributes;
+
+ if (probe_data.is_valid()) {
+ RS::get_singleton()->voxel_gi_set_baked_exposure_normalization(probe_data->get_rid(), _get_camera_exposure_normalization());
+ }
}
Ref<CameraAttributes> VoxelGI::get_camera_attributes() const {
@@ -398,13 +403,7 @@ void VoxelGI::bake(Node *p_from_node, bool p_create_visual_debug) {
p_from_node = p_from_node ? p_from_node : get_parent();
ERR_FAIL_NULL(p_from_node);
- float exposure_normalization = 1.0;
- if (camera_attributes.is_valid()) {
- exposure_normalization = camera_attributes->get_exposure_multiplier();
- if (GLOBAL_GET("rendering/lights_and_shadows/use_physical_light_units")) {
- exposure_normalization = camera_attributes->calculate_exposure_normalization();
- }
- }
+ float exposure_normalization = _get_camera_exposure_normalization();
Voxelizer baker;
@@ -485,6 +484,17 @@ void VoxelGI::_debug_bake() {
bake(nullptr, true);
}
+float VoxelGI::_get_camera_exposure_normalization() {
+ float exposure_normalization = 1.0;
+ if (camera_attributes.is_valid()) {
+ exposure_normalization = camera_attributes->get_exposure_multiplier();
+ if (GLOBAL_GET("rendering/lights_and_shadows/use_physical_light_units")) {
+ exposure_normalization = camera_attributes->calculate_exposure_normalization();
+ }
+ }
+ return exposure_normalization;
+}
+
AABB VoxelGI::get_aabb() const {
return AABB(-size / 2, size);
}
diff --git a/scene/3d/voxel_gi.h b/scene/3d/voxel_gi.h
index d276186dd1..7d7787f721 100644
--- a/scene/3d/voxel_gi.h
+++ b/scene/3d/voxel_gi.h
@@ -131,6 +131,8 @@ private:
void _find_meshes(Node *p_at_node, List<PlotMesh> &plot_meshes);
void _debug_bake();
+ float _get_camera_exposure_normalization();
+
protected:
static void _bind_methods();
#ifndef DISABLE_DEPRECATED