summaryrefslogtreecommitdiff
path: root/servers/rendering
diff options
context:
space:
mode:
authorBastiaan Olij <mux213@gmail.com>2022-10-05 21:51:22 +1100
committerBastiaan Olij <mux213@gmail.com>2022-10-05 22:12:57 +1100
commitaba356e882d498ada7f4443afd6ddcf7ace2c9bf (patch)
treeb30a1ef5f6216031024f4617dc2df638b93289b6 /servers/rendering
parent9cd62741bb0e2f410b2fb861f66e2cf10fe0334d (diff)
Make sure atlas rect for directional lights is calculated using floats
Diffstat (limited to 'servers/rendering')
-rw-r--r--servers/rendering/renderer_rd/forward_clustered/render_forward_clustered.cpp10
-rw-r--r--servers/rendering/renderer_rd/forward_mobile/render_forward_mobile.cpp10
2 files changed, 10 insertions, 10 deletions
diff --git a/servers/rendering/renderer_rd/forward_clustered/render_forward_clustered.cpp b/servers/rendering/renderer_rd/forward_clustered/render_forward_clustered.cpp
index cf08949d99..69d444aeeb 100644
--- a/servers/rendering/renderer_rd/forward_clustered/render_forward_clustered.cpp
+++ b/servers/rendering/renderer_rd/forward_clustered/render_forward_clustered.cpp
@@ -2174,11 +2174,11 @@ void RenderForwardClustered::_render_shadow_pass(RID p_light, RID p_shadow_atlas
}
}
- int directional_shadow_size = light_storage->directional_shadow_get_size();
- atlas_rect.position /= directional_shadow_size;
- atlas_rect.size /= directional_shadow_size;
-
- light_storage->light_instance_set_directional_shadow_atlas_rect(p_light, p_pass, atlas_rect);
+ float directional_shadow_size = light_storage->directional_shadow_get_size();
+ Rect2 atlas_rect_norm = atlas_rect;
+ atlas_rect_norm.position /= directional_shadow_size;
+ atlas_rect_norm.size /= directional_shadow_size;
+ light_storage->light_instance_set_directional_shadow_atlas_rect(p_light, p_pass, atlas_rect_norm);
zfar = RSG::light_storage->light_get_param(base, RS::LIGHT_PARAM_RANGE);
diff --git a/servers/rendering/renderer_rd/forward_mobile/render_forward_mobile.cpp b/servers/rendering/renderer_rd/forward_mobile/render_forward_mobile.cpp
index c3ce1b05f1..2b2090f8ed 100644
--- a/servers/rendering/renderer_rd/forward_mobile/render_forward_mobile.cpp
+++ b/servers/rendering/renderer_rd/forward_mobile/render_forward_mobile.cpp
@@ -1128,11 +1128,11 @@ void RenderForwardMobile::_render_shadow_pass(RID p_light, RID p_shadow_atlas, i
}
}
- int directional_shadow_size = light_storage->directional_shadow_get_size();
- atlas_rect.position /= directional_shadow_size;
- atlas_rect.size /= directional_shadow_size;
-
- light_storage->light_instance_set_directional_shadow_atlas_rect(p_light, p_pass, atlas_rect);
+ float directional_shadow_size = light_storage->directional_shadow_get_size();
+ Rect2 atlas_rect_norm = atlas_rect;
+ atlas_rect_norm.position /= directional_shadow_size;
+ atlas_rect_norm.size /= directional_shadow_size;
+ light_storage->light_instance_set_directional_shadow_atlas_rect(p_light, p_pass, atlas_rect_norm);
zfar = RSG::light_storage->light_get_param(base, RS::LIGHT_PARAM_RANGE);