浏览代码

Fix PhysicsBody ignoring set_friction/bounce with default value

The intent was to avoid creating a physics override to set a default value
that doesn't make a difference, but as #22406 shows it can be necessary to
set the default value *back* after an override was created to set a non-default
value.

Fixes #22406.
Rémi Verschelde 6 年之前
父节点
当前提交
63b487e49c
共有 1 个文件被更改,包括 4 次插入4 次删除
  1. 4 4
      scene/3d/physics_body.cpp

+ 4 - 4
scene/3d/physics_body.cpp

@@ -188,7 +188,7 @@ PhysicsBody::PhysicsBody(PhysicsServer::BodyMode p_mode) :
 #ifndef DISABLE_DEPRECATED
 #ifndef DISABLE_DEPRECATED
 void StaticBody::set_friction(real_t p_friction) {
 void StaticBody::set_friction(real_t p_friction) {
 
 
-	if (p_friction == 1.0) { // default value, don't create an override for that
+	if (p_friction == 1.0 && physics_material_override.is_null()) { // default value, don't create an override for that
 		return;
 		return;
 	}
 	}
 
 
@@ -218,7 +218,7 @@ real_t StaticBody::get_friction() const {
 
 
 void StaticBody::set_bounce(real_t p_bounce) {
 void StaticBody::set_bounce(real_t p_bounce) {
 
 
-	if (p_bounce == 0.0) { // default value, don't create an override for that
+	if (p_bounce == 0.0 && physics_material_override.is_null()) { // default value, don't create an override for that
 		return;
 		return;
 	}
 	}
 
 
@@ -632,7 +632,7 @@ real_t RigidBody::get_weight() const {
 #ifndef DISABLE_DEPRECATED
 #ifndef DISABLE_DEPRECATED
 void RigidBody::set_friction(real_t p_friction) {
 void RigidBody::set_friction(real_t p_friction) {
 
 
-	if (p_friction == 1.0) { // default value, don't create an override for that
+	if (p_friction == 1.0 && physics_material_override.is_null()) { // default value, don't create an override for that
 		return;
 		return;
 	}
 	}
 
 
@@ -661,7 +661,7 @@ real_t RigidBody::get_friction() const {
 
 
 void RigidBody::set_bounce(real_t p_bounce) {
 void RigidBody::set_bounce(real_t p_bounce) {
 
 
-	if (p_bounce == 0.0) { // default value, don't create an override for that
+	if (p_bounce == 0.0 && physics_material_override.is_null()) { // default value, don't create an override for that
 		return;
 		return;
 	}
 	}