|
@@ -1812,6 +1812,7 @@ void RenderForwardClustered::_render_scene(RenderDataRD *p_render_data, const Co
|
|
RS::EnvironmentBG bg_mode = environment_get_background(p_render_data->environment);
|
|
RS::EnvironmentBG bg_mode = environment_get_background(p_render_data->environment);
|
|
float bg_energy_multiplier = environment_get_bg_energy_multiplier(p_render_data->environment);
|
|
float bg_energy_multiplier = environment_get_bg_energy_multiplier(p_render_data->environment);
|
|
bg_energy_multiplier *= environment_get_bg_intensity(p_render_data->environment);
|
|
bg_energy_multiplier *= environment_get_bg_intensity(p_render_data->environment);
|
|
|
|
+ RS::EnvironmentReflectionSource reflection_source = environment_get_reflection_source(p_render_data->environment);
|
|
|
|
|
|
if (p_render_data->camera_attributes.is_valid()) {
|
|
if (p_render_data->camera_attributes.is_valid()) {
|
|
bg_energy_multiplier *= RSG::camera_attributes->camera_attributes_get_exposure_normalization_factor(p_render_data->camera_attributes);
|
|
bg_energy_multiplier *= RSG::camera_attributes->camera_attributes_get_exposure_normalization_factor(p_render_data->camera_attributes);
|
|
@@ -1823,7 +1824,7 @@ void RenderForwardClustered::_render_scene(RenderDataRD *p_render_data, const Co
|
|
clear_color.r *= bg_energy_multiplier;
|
|
clear_color.r *= bg_energy_multiplier;
|
|
clear_color.g *= bg_energy_multiplier;
|
|
clear_color.g *= bg_energy_multiplier;
|
|
clear_color.b *= bg_energy_multiplier;
|
|
clear_color.b *= bg_energy_multiplier;
|
|
- if ((rb->has_custom_data(RB_SCOPE_FOG)) || environment_get_fog_enabled(p_render_data->environment)) {
|
|
|
|
|
|
+ if (!p_render_data->transparent_bg && rb->has_custom_data(RB_SCOPE_FOG) && environment_get_fog_enabled(p_render_data->environment)) {
|
|
draw_sky_fog_only = true;
|
|
draw_sky_fog_only = true;
|
|
RendererRD::MaterialStorage::get_singleton()->material_set_param(sky.sky_scene_state.fog_material, "clear_color", Variant(clear_color.srgb_to_linear()));
|
|
RendererRD::MaterialStorage::get_singleton()->material_set_param(sky.sky_scene_state.fog_material, "clear_color", Variant(clear_color.srgb_to_linear()));
|
|
}
|
|
}
|
|
@@ -1833,13 +1834,13 @@ void RenderForwardClustered::_render_scene(RenderDataRD *p_render_data, const Co
|
|
clear_color.r *= bg_energy_multiplier;
|
|
clear_color.r *= bg_energy_multiplier;
|
|
clear_color.g *= bg_energy_multiplier;
|
|
clear_color.g *= bg_energy_multiplier;
|
|
clear_color.b *= bg_energy_multiplier;
|
|
clear_color.b *= bg_energy_multiplier;
|
|
- if ((rb->has_custom_data(RB_SCOPE_FOG)) || environment_get_fog_enabled(p_render_data->environment)) {
|
|
|
|
|
|
+ if (!p_render_data->transparent_bg && rb->has_custom_data(RB_SCOPE_FOG) && environment_get_fog_enabled(p_render_data->environment)) {
|
|
draw_sky_fog_only = true;
|
|
draw_sky_fog_only = true;
|
|
RendererRD::MaterialStorage::get_singleton()->material_set_param(sky.sky_scene_state.fog_material, "clear_color", Variant(clear_color.srgb_to_linear()));
|
|
RendererRD::MaterialStorage::get_singleton()->material_set_param(sky.sky_scene_state.fog_material, "clear_color", Variant(clear_color.srgb_to_linear()));
|
|
}
|
|
}
|
|
} break;
|
|
} break;
|
|
case RS::ENV_BG_SKY: {
|
|
case RS::ENV_BG_SKY: {
|
|
- draw_sky = true;
|
|
|
|
|
|
+ draw_sky = !p_render_data->transparent_bg;
|
|
} break;
|
|
} break;
|
|
case RS::ENV_BG_CANVAS: {
|
|
case RS::ENV_BG_CANVAS: {
|
|
if (!is_reflection_probe) {
|
|
if (!is_reflection_probe) {
|
|
@@ -1859,7 +1860,7 @@ void RenderForwardClustered::_render_scene(RenderDataRD *p_render_data, const Co
|
|
}
|
|
}
|
|
|
|
|
|
// setup sky if used for ambient, reflections, or background
|
|
// setup sky if used for ambient, reflections, or background
|
|
- if (draw_sky || draw_sky_fog_only || environment_get_reflection_source(p_render_data->environment) == RS::ENV_REFLECTION_SOURCE_SKY || environment_get_ambient_source(p_render_data->environment) == RS::ENV_AMBIENT_SOURCE_SKY) {
|
|
|
|
|
|
+ if (draw_sky || draw_sky_fog_only || (reflection_source == RS::ENV_REFLECTION_SOURCE_BG && bg_mode == RS::ENV_BG_SKY) || reflection_source == RS::ENV_REFLECTION_SOURCE_SKY || environment_get_ambient_source(p_render_data->environment) == RS::ENV_AMBIENT_SOURCE_SKY) {
|
|
RENDER_TIMESTAMP("Setup Sky");
|
|
RENDER_TIMESTAMP("Setup Sky");
|
|
RD::get_singleton()->draw_command_begin_label("Setup Sky");
|
|
RD::get_singleton()->draw_command_begin_label("Setup Sky");
|
|
|
|
|