Merge pull request #50090 from Calinou/remove-leftover-optimized-directional-shadow-depth-range
Remove leftovers from the DirectionalLight3D Optimized shadow depth range
This commit is contained in:
commit
c77e0da1d7
12 changed files with 7 additions and 105 deletions
|
@ -15,9 +15,6 @@
|
||||||
<member name="directional_shadow_blend_splits" type="bool" setter="set_blend_splits" getter="is_blend_splits_enabled" default="false">
|
<member name="directional_shadow_blend_splits" type="bool" setter="set_blend_splits" getter="is_blend_splits_enabled" default="false">
|
||||||
If [code]true[/code], shadow detail is sacrificed in exchange for smoother transitions between splits.
|
If [code]true[/code], shadow detail is sacrificed in exchange for smoother transitions between splits.
|
||||||
</member>
|
</member>
|
||||||
<member name="directional_shadow_depth_range" type="int" setter="set_shadow_depth_range" getter="get_shadow_depth_range" enum="DirectionalLight3D.ShadowDepthRange" default="0">
|
|
||||||
Optimizes shadow rendering for detail versus movement. See [enum ShadowDepthRange].
|
|
||||||
</member>
|
|
||||||
<member name="directional_shadow_fade_start" type="float" setter="set_param" getter="get_param" default="0.8">
|
<member name="directional_shadow_fade_start" type="float" setter="set_param" getter="get_param" default="0.8">
|
||||||
Proportion of [member directional_shadow_max_distance] at which point the shadow starts to fade. At [member directional_shadow_max_distance] the shadow will disappear.
|
Proportion of [member directional_shadow_max_distance] at which point the shadow starts to fade. At [member directional_shadow_max_distance] the shadow will disappear.
|
||||||
</member>
|
</member>
|
||||||
|
@ -55,11 +52,5 @@
|
||||||
<constant name="SHADOW_PARALLEL_4_SPLITS" value="2" enum="ShadowMode">
|
<constant name="SHADOW_PARALLEL_4_SPLITS" value="2" enum="ShadowMode">
|
||||||
Splits the view frustum in 4 areas, each with its own shadow map. This is the slowest directional shadow mode.
|
Splits the view frustum in 4 areas, each with its own shadow map. This is the slowest directional shadow mode.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="SHADOW_DEPTH_RANGE_STABLE" value="0" enum="ShadowDepthRange">
|
|
||||||
Keeps the shadow stable when the camera moves, at the cost of lower effective shadow resolution.
|
|
||||||
</constant>
|
|
||||||
<constant name="SHADOW_DEPTH_RANGE_OPTIMIZED" value="1" enum="ShadowDepthRange">
|
|
||||||
Tries to achieve maximum shadow resolution. May result in saw effect on shadow edges. This mode typically works best in games where the camera will often move at high speeds, such as most racing games.
|
|
||||||
</constant>
|
|
||||||
</constants>
|
</constants>
|
||||||
</class>
|
</class>
|
||||||
|
|
|
@ -2121,17 +2121,6 @@
|
||||||
If [code]true[/code], this directional light will blend between shadow map splits resulting in a smoother transition between them. Equivalent to [member DirectionalLight3D.directional_shadow_blend_splits].
|
If [code]true[/code], this directional light will blend between shadow map splits resulting in a smoother transition between them. Equivalent to [member DirectionalLight3D.directional_shadow_blend_splits].
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="light_directional_set_shadow_depth_range_mode">
|
|
||||||
<return type="void">
|
|
||||||
</return>
|
|
||||||
<argument index="0" name="light" type="RID">
|
|
||||||
</argument>
|
|
||||||
<argument index="1" name="range_mode" type="int" enum="RenderingServer.LightDirectionalShadowDepthRangeMode">
|
|
||||||
</argument>
|
|
||||||
<description>
|
|
||||||
Sets the shadow depth range mode for this directional light. Equivalent to [member DirectionalLight3D.directional_shadow_depth_range]. See [enum LightDirectionalShadowDepthRangeMode] for options.
|
|
||||||
</description>
|
|
||||||
</method>
|
|
||||||
<method name="light_directional_set_shadow_mode">
|
<method name="light_directional_set_shadow_mode">
|
||||||
<return type="void">
|
<return type="void">
|
||||||
</return>
|
</return>
|
||||||
|
@ -4963,12 +4952,6 @@
|
||||||
<constant name="LIGHT_DIRECTIONAL_SHADOW_PARALLEL_4_SPLITS" value="2" enum="LightDirectionalShadowMode">
|
<constant name="LIGHT_DIRECTIONAL_SHADOW_PARALLEL_4_SPLITS" value="2" enum="LightDirectionalShadowMode">
|
||||||
Use 4 splits for shadow projection when using directional light.
|
Use 4 splits for shadow projection when using directional light.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE" value="0" enum="LightDirectionalShadowDepthRangeMode">
|
|
||||||
Keeps shadows stable as camera moves but has lower effective resolution.
|
|
||||||
</constant>
|
|
||||||
<constant name="LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_OPTIMIZED" value="1" enum="LightDirectionalShadowDepthRangeMode">
|
|
||||||
Optimize use of shadow maps, increasing the effective resolution. But may result in shadows moving or flickering slightly.
|
|
||||||
</constant>
|
|
||||||
<constant name="SHADOW_QUALITY_HARD" value="0" enum="ShadowQuality">
|
<constant name="SHADOW_QUALITY_HARD" value="0" enum="ShadowQuality">
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="SHADOW_QUALITY_SOFT_LOW" value="1" enum="ShadowQuality">
|
<constant name="SHADOW_QUALITY_SOFT_LOW" value="1" enum="ShadowQuality">
|
||||||
|
|
|
@ -375,15 +375,6 @@ DirectionalLight3D::ShadowMode DirectionalLight3D::get_shadow_mode() const {
|
||||||
return shadow_mode;
|
return shadow_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DirectionalLight3D::set_shadow_depth_range(ShadowDepthRange p_range) {
|
|
||||||
shadow_depth_range = p_range;
|
|
||||||
RS::get_singleton()->light_directional_set_shadow_depth_range_mode(light, RS::LightDirectionalShadowDepthRangeMode(p_range));
|
|
||||||
}
|
|
||||||
|
|
||||||
DirectionalLight3D::ShadowDepthRange DirectionalLight3D::get_shadow_depth_range() const {
|
|
||||||
return shadow_depth_range;
|
|
||||||
}
|
|
||||||
|
|
||||||
void DirectionalLight3D::set_blend_splits(bool p_enable) {
|
void DirectionalLight3D::set_blend_splits(bool p_enable) {
|
||||||
blend_splits = p_enable;
|
blend_splits = p_enable;
|
||||||
RS::get_singleton()->light_directional_set_blend_splits(light, p_enable);
|
RS::get_singleton()->light_directional_set_blend_splits(light, p_enable);
|
||||||
|
@ -406,9 +397,6 @@ void DirectionalLight3D::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("set_shadow_mode", "mode"), &DirectionalLight3D::set_shadow_mode);
|
ClassDB::bind_method(D_METHOD("set_shadow_mode", "mode"), &DirectionalLight3D::set_shadow_mode);
|
||||||
ClassDB::bind_method(D_METHOD("get_shadow_mode"), &DirectionalLight3D::get_shadow_mode);
|
ClassDB::bind_method(D_METHOD("get_shadow_mode"), &DirectionalLight3D::get_shadow_mode);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("set_shadow_depth_range", "mode"), &DirectionalLight3D::set_shadow_depth_range);
|
|
||||||
ClassDB::bind_method(D_METHOD("get_shadow_depth_range"), &DirectionalLight3D::get_shadow_depth_range);
|
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("set_blend_splits", "enabled"), &DirectionalLight3D::set_blend_splits);
|
ClassDB::bind_method(D_METHOD("set_blend_splits", "enabled"), &DirectionalLight3D::set_blend_splits);
|
||||||
ClassDB::bind_method(D_METHOD("is_blend_splits_enabled"), &DirectionalLight3D::is_blend_splits_enabled);
|
ClassDB::bind_method(D_METHOD("is_blend_splits_enabled"), &DirectionalLight3D::is_blend_splits_enabled);
|
||||||
|
|
||||||
|
@ -422,7 +410,6 @@ void DirectionalLight3D::_bind_methods() {
|
||||||
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_split_3", PROPERTY_HINT_RANGE, "0,1,0.001"), "set_param", "get_param", PARAM_SHADOW_SPLIT_3_OFFSET);
|
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_split_3", PROPERTY_HINT_RANGE, "0,1,0.001"), "set_param", "get_param", PARAM_SHADOW_SPLIT_3_OFFSET);
|
||||||
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_fade_start", PROPERTY_HINT_RANGE, "0,1,0.01"), "set_param", "get_param", PARAM_SHADOW_FADE_START);
|
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_fade_start", PROPERTY_HINT_RANGE, "0,1,0.01"), "set_param", "get_param", PARAM_SHADOW_FADE_START);
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "directional_shadow_blend_splits"), "set_blend_splits", "is_blend_splits_enabled");
|
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "directional_shadow_blend_splits"), "set_blend_splits", "is_blend_splits_enabled");
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::INT, "directional_shadow_depth_range", PROPERTY_HINT_ENUM, "Stable,Optimized"), "set_shadow_depth_range", "get_shadow_depth_range");
|
|
||||||
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_max_distance", PROPERTY_HINT_RANGE, "0,8192,0.1,or_greater,exp"), "set_param", "get_param", PARAM_SHADOW_MAX_DISTANCE);
|
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_max_distance", PROPERTY_HINT_RANGE, "0,8192,0.1,or_greater,exp"), "set_param", "get_param", PARAM_SHADOW_MAX_DISTANCE);
|
||||||
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_pancake_size", PROPERTY_HINT_RANGE, "0,1024,0.1,or_greater,exp"), "set_param", "get_param", PARAM_SHADOW_PANCAKE_SIZE);
|
ADD_PROPERTYI(PropertyInfo(Variant::FLOAT, "directional_shadow_pancake_size", PROPERTY_HINT_RANGE, "0,1024,0.1,or_greater,exp"), "set_param", "get_param", PARAM_SHADOW_PANCAKE_SIZE);
|
||||||
|
|
||||||
|
@ -431,9 +418,6 @@ void DirectionalLight3D::_bind_methods() {
|
||||||
BIND_ENUM_CONSTANT(SHADOW_ORTHOGONAL);
|
BIND_ENUM_CONSTANT(SHADOW_ORTHOGONAL);
|
||||||
BIND_ENUM_CONSTANT(SHADOW_PARALLEL_2_SPLITS);
|
BIND_ENUM_CONSTANT(SHADOW_PARALLEL_2_SPLITS);
|
||||||
BIND_ENUM_CONSTANT(SHADOW_PARALLEL_4_SPLITS);
|
BIND_ENUM_CONSTANT(SHADOW_PARALLEL_4_SPLITS);
|
||||||
|
|
||||||
BIND_ENUM_CONSTANT(SHADOW_DEPTH_RANGE_STABLE);
|
|
||||||
BIND_ENUM_CONSTANT(SHADOW_DEPTH_RANGE_OPTIMIZED);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DirectionalLight3D::DirectionalLight3D() :
|
DirectionalLight3D::DirectionalLight3D() :
|
||||||
|
@ -444,7 +428,6 @@ DirectionalLight3D::DirectionalLight3D() :
|
||||||
// Leave normal bias untouched as it doesn't benefit DirectionalLight3D as much as OmniLight3D.
|
// Leave normal bias untouched as it doesn't benefit DirectionalLight3D as much as OmniLight3D.
|
||||||
set_param(PARAM_SHADOW_BIAS, 0.05);
|
set_param(PARAM_SHADOW_BIAS, 0.05);
|
||||||
set_shadow_mode(SHADOW_PARALLEL_4_SPLITS);
|
set_shadow_mode(SHADOW_PARALLEL_4_SPLITS);
|
||||||
set_shadow_depth_range(SHADOW_DEPTH_RANGE_STABLE);
|
|
||||||
blend_splits = false;
|
blend_splits = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -149,15 +149,9 @@ public:
|
||||||
SHADOW_PARALLEL_4_SPLITS,
|
SHADOW_PARALLEL_4_SPLITS,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum ShadowDepthRange {
|
|
||||||
SHADOW_DEPTH_RANGE_STABLE = RS::LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE,
|
|
||||||
SHADOW_DEPTH_RANGE_OPTIMIZED = RS::LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_OPTIMIZED,
|
|
||||||
};
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool blend_splits;
|
bool blend_splits;
|
||||||
ShadowMode shadow_mode;
|
ShadowMode shadow_mode;
|
||||||
ShadowDepthRange shadow_depth_range;
|
|
||||||
bool sky_only = false;
|
bool sky_only = false;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -167,9 +161,6 @@ public:
|
||||||
void set_shadow_mode(ShadowMode p_mode);
|
void set_shadow_mode(ShadowMode p_mode);
|
||||||
ShadowMode get_shadow_mode() const;
|
ShadowMode get_shadow_mode() const;
|
||||||
|
|
||||||
void set_shadow_depth_range(ShadowDepthRange p_range);
|
|
||||||
ShadowDepthRange get_shadow_depth_range() const;
|
|
||||||
|
|
||||||
void set_blend_splits(bool p_enable);
|
void set_blend_splits(bool p_enable);
|
||||||
bool is_blend_splits_enabled() const;
|
bool is_blend_splits_enabled() const;
|
||||||
|
|
||||||
|
@ -180,7 +171,6 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
VARIANT_ENUM_CAST(DirectionalLight3D::ShadowMode)
|
VARIANT_ENUM_CAST(DirectionalLight3D::ShadowMode)
|
||||||
VARIANT_ENUM_CAST(DirectionalLight3D::ShadowDepthRange)
|
|
||||||
|
|
||||||
class OmniLight3D : public Light3D {
|
class OmniLight3D : public Light3D {
|
||||||
GDCLASS(OmniLight3D, Light3D);
|
GDCLASS(OmniLight3D, Light3D);
|
||||||
|
|
|
@ -405,10 +405,8 @@ public:
|
||||||
void light_directional_set_shadow_mode(RID p_light, RS::LightDirectionalShadowMode p_mode) override {}
|
void light_directional_set_shadow_mode(RID p_light, RS::LightDirectionalShadowMode p_mode) override {}
|
||||||
void light_directional_set_blend_splits(RID p_light, bool p_enable) override {}
|
void light_directional_set_blend_splits(RID p_light, bool p_enable) override {}
|
||||||
bool light_directional_get_blend_splits(RID p_light) const override { return false; }
|
bool light_directional_get_blend_splits(RID p_light) const override { return false; }
|
||||||
void light_directional_set_shadow_depth_range_mode(RID p_light, RS::LightDirectionalShadowDepthRangeMode p_range_mode) override {}
|
|
||||||
void light_directional_set_sky_only(RID p_light, bool p_sky_only) override {}
|
void light_directional_set_sky_only(RID p_light, bool p_sky_only) override {}
|
||||||
bool light_directional_is_sky_only(RID p_light) const override { return false; }
|
bool light_directional_is_sky_only(RID p_light) const override { return false; }
|
||||||
RS::LightDirectionalShadowDepthRangeMode light_directional_get_shadow_depth_range_mode(RID p_light) const override { return RS::LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE; }
|
|
||||||
|
|
||||||
RS::LightDirectionalShadowMode light_directional_get_shadow_mode(RID p_light) override { return RS::LIGHT_DIRECTIONAL_SHADOW_ORTHOGONAL; }
|
RS::LightDirectionalShadowMode light_directional_get_shadow_mode(RID p_light) override { return RS::LIGHT_DIRECTIONAL_SHADOW_ORTHOGONAL; }
|
||||||
RS::LightOmniShadowMode light_omni_get_shadow_mode(RID p_light) override { return RS::LIGHT_OMNI_SHADOW_DUAL_PARABOLOID; }
|
RS::LightOmniShadowMode light_omni_get_shadow_mode(RID p_light) override { return RS::LIGHT_OMNI_SHADOW_DUAL_PARABOLOID; }
|
||||||
|
|
|
@ -6031,20 +6031,6 @@ RS::LightDirectionalShadowMode RendererStorageRD::light_directional_get_shadow_m
|
||||||
return light->directional_shadow_mode;
|
return light->directional_shadow_mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
void RendererStorageRD::light_directional_set_shadow_depth_range_mode(RID p_light, RS::LightDirectionalShadowDepthRangeMode p_range_mode) {
|
|
||||||
Light *light = light_owner.getornull(p_light);
|
|
||||||
ERR_FAIL_COND(!light);
|
|
||||||
|
|
||||||
light->directional_range_mode = p_range_mode;
|
|
||||||
}
|
|
||||||
|
|
||||||
RS::LightDirectionalShadowDepthRangeMode RendererStorageRD::light_directional_get_shadow_depth_range_mode(RID p_light) const {
|
|
||||||
const Light *light = light_owner.getornull(p_light);
|
|
||||||
ERR_FAIL_COND_V(!light, RS::LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE);
|
|
||||||
|
|
||||||
return light->directional_range_mode;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint32_t RendererStorageRD::light_get_max_sdfgi_cascade(RID p_light) {
|
uint32_t RendererStorageRD::light_get_max_sdfgi_cascade(RID p_light) {
|
||||||
const Light *light = light_owner.getornull(p_light);
|
const Light *light = light_owner.getornull(p_light);
|
||||||
ERR_FAIL_COND_V(!light, 0);
|
ERR_FAIL_COND_V(!light, 0);
|
||||||
|
|
|
@ -1002,7 +1002,6 @@ private:
|
||||||
uint32_t cull_mask = 0xFFFFFFFF;
|
uint32_t cull_mask = 0xFFFFFFFF;
|
||||||
RS::LightOmniShadowMode omni_shadow_mode = RS::LIGHT_OMNI_SHADOW_DUAL_PARABOLOID;
|
RS::LightOmniShadowMode omni_shadow_mode = RS::LIGHT_OMNI_SHADOW_DUAL_PARABOLOID;
|
||||||
RS::LightDirectionalShadowMode directional_shadow_mode = RS::LIGHT_DIRECTIONAL_SHADOW_ORTHOGONAL;
|
RS::LightDirectionalShadowMode directional_shadow_mode = RS::LIGHT_DIRECTIONAL_SHADOW_ORTHOGONAL;
|
||||||
RS::LightDirectionalShadowDepthRangeMode directional_range_mode = RS::LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE;
|
|
||||||
bool directional_blend_splits = false;
|
bool directional_blend_splits = false;
|
||||||
bool directional_sky_only = false;
|
bool directional_sky_only = false;
|
||||||
uint64_t version = 0;
|
uint64_t version = 0;
|
||||||
|
@ -1813,8 +1812,6 @@ public:
|
||||||
bool light_directional_get_blend_splits(RID p_light) const;
|
bool light_directional_get_blend_splits(RID p_light) const;
|
||||||
void light_directional_set_sky_only(RID p_light, bool p_sky_only);
|
void light_directional_set_sky_only(RID p_light, bool p_sky_only);
|
||||||
bool light_directional_is_sky_only(RID p_light) const;
|
bool light_directional_is_sky_only(RID p_light) const;
|
||||||
void light_directional_set_shadow_depth_range_mode(RID p_light, RS::LightDirectionalShadowDepthRangeMode p_range_mode);
|
|
||||||
RS::LightDirectionalShadowDepthRangeMode light_directional_get_shadow_depth_range_mode(RID p_light) const;
|
|
||||||
|
|
||||||
RS::LightDirectionalShadowMode light_directional_get_shadow_mode(RID p_light);
|
RS::LightDirectionalShadowMode light_directional_get_shadow_mode(RID p_light);
|
||||||
RS::LightOmniShadowMode light_omni_get_shadow_mode(RID p_light);
|
RS::LightOmniShadowMode light_omni_get_shadow_mode(RID p_light);
|
||||||
|
|
|
@ -1877,8 +1877,6 @@ void RendererSceneCull::_light_instance_setup_directional_shadow(int p_shadow_in
|
||||||
max_distance = MAX(max_distance, p_cam_projection.get_z_near() + 0.001);
|
max_distance = MAX(max_distance, p_cam_projection.get_z_near() + 0.001);
|
||||||
real_t min_distance = MIN(p_cam_projection.get_z_near(), max_distance);
|
real_t min_distance = MIN(p_cam_projection.get_z_near(), max_distance);
|
||||||
|
|
||||||
RS::LightDirectionalShadowDepthRangeMode depth_range_mode = RSG::storage->light_directional_get_shadow_depth_range_mode(p_instance->base);
|
|
||||||
|
|
||||||
real_t pancake_size = RSG::storage->light_get_param(p_instance->base, RS::LIGHT_PARAM_SHADOW_PANCAKE_SIZE);
|
real_t pancake_size = RSG::storage->light_get_param(p_instance->base, RS::LIGHT_PARAM_SHADOW_PANCAKE_SIZE);
|
||||||
|
|
||||||
real_t range = max_distance - min_distance;
|
real_t range = max_distance - min_distance;
|
||||||
|
@ -2038,22 +2036,13 @@ void RendererSceneCull::_light_instance_setup_directional_shadow(int p_shadow_in
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
x_max_cam = x_vec.dot(center) + radius + soft_shadow_expand;
|
// This trick here is what stabilizes the shadow (make potential jaggies to not move)
|
||||||
x_min_cam = x_vec.dot(center) - radius - soft_shadow_expand;
|
// at the cost of some wasted resolution. Still, the quality increase is very well worth it.
|
||||||
y_max_cam = y_vec.dot(center) + radius + soft_shadow_expand;
|
const real_t unit = radius * 2.0 / texture_size;
|
||||||
y_min_cam = y_vec.dot(center) - radius - soft_shadow_expand;
|
x_max_cam = Math::snapped(x_vec.dot(center) + radius + soft_shadow_expand, unit);
|
||||||
|
x_min_cam = Math::snapped(x_vec.dot(center) - radius - soft_shadow_expand, unit);
|
||||||
if (depth_range_mode == RS::LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE) {
|
y_max_cam = Math::snapped(y_vec.dot(center) + radius + soft_shadow_expand, unit);
|
||||||
//this trick here is what stabilizes the shadow (make potential jaggies to not move)
|
y_min_cam = Math::snapped(y_vec.dot(center) - radius - soft_shadow_expand, unit);
|
||||||
//at the cost of some wasted resolution. Still the quality increase is very well worth it
|
|
||||||
|
|
||||||
real_t unit = radius * 2.0 / texture_size;
|
|
||||||
|
|
||||||
x_max_cam = Math::snapped(x_max_cam, unit);
|
|
||||||
x_min_cam = Math::snapped(x_min_cam, unit);
|
|
||||||
y_max_cam = Math::snapped(y_max_cam, unit);
|
|
||||||
y_min_cam = Math::snapped(y_min_cam, unit);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//now that we know all ranges, we can proceed to make the light frustum planes, for culling octree
|
//now that we know all ranges, we can proceed to make the light frustum planes, for culling octree
|
||||||
|
|
|
@ -331,8 +331,6 @@ public:
|
||||||
virtual bool light_directional_get_blend_splits(RID p_light) const = 0;
|
virtual bool light_directional_get_blend_splits(RID p_light) const = 0;
|
||||||
virtual void light_directional_set_sky_only(RID p_light, bool p_sky_only) = 0;
|
virtual void light_directional_set_sky_only(RID p_light, bool p_sky_only) = 0;
|
||||||
virtual bool light_directional_is_sky_only(RID p_light) const = 0;
|
virtual bool light_directional_is_sky_only(RID p_light) const = 0;
|
||||||
virtual void light_directional_set_shadow_depth_range_mode(RID p_light, RS::LightDirectionalShadowDepthRangeMode p_range_mode) = 0;
|
|
||||||
virtual RS::LightDirectionalShadowDepthRangeMode light_directional_get_shadow_depth_range_mode(RID p_light) const = 0;
|
|
||||||
|
|
||||||
virtual RS::LightDirectionalShadowMode light_directional_get_shadow_mode(RID p_light) = 0;
|
virtual RS::LightDirectionalShadowMode light_directional_get_shadow_mode(RID p_light) = 0;
|
||||||
virtual RS::LightOmniShadowMode light_omni_get_shadow_mode(RID p_light) = 0;
|
virtual RS::LightOmniShadowMode light_omni_get_shadow_mode(RID p_light) = 0;
|
||||||
|
|
|
@ -362,7 +362,6 @@ public:
|
||||||
FUNC2(light_directional_set_shadow_mode, RID, LightDirectionalShadowMode)
|
FUNC2(light_directional_set_shadow_mode, RID, LightDirectionalShadowMode)
|
||||||
FUNC2(light_directional_set_blend_splits, RID, bool)
|
FUNC2(light_directional_set_blend_splits, RID, bool)
|
||||||
FUNC2(light_directional_set_sky_only, RID, bool)
|
FUNC2(light_directional_set_sky_only, RID, bool)
|
||||||
FUNC2(light_directional_set_shadow_depth_range_mode, RID, LightDirectionalShadowDepthRangeMode)
|
|
||||||
|
|
||||||
/* PROBE API */
|
/* PROBE API */
|
||||||
|
|
||||||
|
|
|
@ -1853,7 +1853,6 @@ void RenderingServer::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("light_directional_set_shadow_mode", "light", "mode"), &RenderingServer::light_directional_set_shadow_mode);
|
ClassDB::bind_method(D_METHOD("light_directional_set_shadow_mode", "light", "mode"), &RenderingServer::light_directional_set_shadow_mode);
|
||||||
ClassDB::bind_method(D_METHOD("light_directional_set_blend_splits", "light", "enable"), &RenderingServer::light_directional_set_blend_splits);
|
ClassDB::bind_method(D_METHOD("light_directional_set_blend_splits", "light", "enable"), &RenderingServer::light_directional_set_blend_splits);
|
||||||
ClassDB::bind_method(D_METHOD("light_directional_set_sky_only", "light", "enable"), &RenderingServer::light_directional_set_sky_only);
|
ClassDB::bind_method(D_METHOD("light_directional_set_sky_only", "light", "enable"), &RenderingServer::light_directional_set_sky_only);
|
||||||
ClassDB::bind_method(D_METHOD("light_directional_set_shadow_depth_range_mode", "light", "range_mode"), &RenderingServer::light_directional_set_shadow_depth_range_mode);
|
|
||||||
|
|
||||||
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL);
|
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL);
|
||||||
BIND_ENUM_CONSTANT(LIGHT_OMNI);
|
BIND_ENUM_CONSTANT(LIGHT_OMNI);
|
||||||
|
@ -1891,9 +1890,6 @@ void RenderingServer::_bind_methods() {
|
||||||
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL_SHADOW_PARALLEL_2_SPLITS);
|
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL_SHADOW_PARALLEL_2_SPLITS);
|
||||||
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL_SHADOW_PARALLEL_4_SPLITS);
|
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL_SHADOW_PARALLEL_4_SPLITS);
|
||||||
|
|
||||||
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE);
|
|
||||||
BIND_ENUM_CONSTANT(LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_OPTIMIZED);
|
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("shadows_quality_set", "quality"), &RenderingServer::shadows_quality_set);
|
ClassDB::bind_method(D_METHOD("shadows_quality_set", "quality"), &RenderingServer::shadows_quality_set);
|
||||||
ClassDB::bind_method(D_METHOD("directional_shadow_quality_set", "quality"), &RenderingServer::directional_shadow_quality_set);
|
ClassDB::bind_method(D_METHOD("directional_shadow_quality_set", "quality"), &RenderingServer::directional_shadow_quality_set);
|
||||||
ClassDB::bind_method(D_METHOD("directional_shadow_atlas_set_size", "size", "is_16bits"), &RenderingServer::directional_shadow_atlas_set_size);
|
ClassDB::bind_method(D_METHOD("directional_shadow_atlas_set_size", "size", "is_16bits"), &RenderingServer::directional_shadow_atlas_set_size);
|
||||||
|
|
|
@ -469,13 +469,6 @@ public:
|
||||||
virtual void light_directional_set_blend_splits(RID p_light, bool p_enable) = 0;
|
virtual void light_directional_set_blend_splits(RID p_light, bool p_enable) = 0;
|
||||||
virtual void light_directional_set_sky_only(RID p_light, bool p_sky_only) = 0;
|
virtual void light_directional_set_sky_only(RID p_light, bool p_sky_only) = 0;
|
||||||
|
|
||||||
enum LightDirectionalShadowDepthRangeMode {
|
|
||||||
LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_STABLE,
|
|
||||||
LIGHT_DIRECTIONAL_SHADOW_DEPTH_RANGE_OPTIMIZED,
|
|
||||||
};
|
|
||||||
|
|
||||||
virtual void light_directional_set_shadow_depth_range_mode(RID p_light, LightDirectionalShadowDepthRangeMode p_range_mode) = 0;
|
|
||||||
|
|
||||||
virtual void directional_shadow_atlas_set_size(int p_size, bool p_16_bits = false) = 0;
|
virtual void directional_shadow_atlas_set_size(int p_size, bool p_16_bits = false) = 0;
|
||||||
|
|
||||||
enum ShadowQuality {
|
enum ShadowQuality {
|
||||||
|
@ -1505,7 +1498,6 @@ VARIANT_ENUM_CAST(RenderingServer::LightParam);
|
||||||
VARIANT_ENUM_CAST(RenderingServer::LightBakeMode);
|
VARIANT_ENUM_CAST(RenderingServer::LightBakeMode);
|
||||||
VARIANT_ENUM_CAST(RenderingServer::LightOmniShadowMode);
|
VARIANT_ENUM_CAST(RenderingServer::LightOmniShadowMode);
|
||||||
VARIANT_ENUM_CAST(RenderingServer::LightDirectionalShadowMode);
|
VARIANT_ENUM_CAST(RenderingServer::LightDirectionalShadowMode);
|
||||||
VARIANT_ENUM_CAST(RenderingServer::LightDirectionalShadowDepthRangeMode);
|
|
||||||
VARIANT_ENUM_CAST(RenderingServer::ReflectionProbeUpdateMode);
|
VARIANT_ENUM_CAST(RenderingServer::ReflectionProbeUpdateMode);
|
||||||
VARIANT_ENUM_CAST(RenderingServer::ReflectionProbeAmbientMode);
|
VARIANT_ENUM_CAST(RenderingServer::ReflectionProbeAmbientMode);
|
||||||
VARIANT_ENUM_CAST(RenderingServer::VoxelGIQuality);
|
VARIANT_ENUM_CAST(RenderingServer::VoxelGIQuality);
|
||||||
|
|
Loading…
Reference in a new issue