Ver Fonte

Merge pull request #52954 from nekomatata/fix-kinematic-collision-reference

Rémi Verschelde há 4 anos atrás
pai
commit
2815594ba0
2 ficheiros alterados com 8 adições e 4 exclusões
  1. 4 2
      scene/2d/physics_body_2d.cpp
  2. 4 2
      scene/3d/physics_body_3d.cpp

+ 4 - 2
scene/2d/physics_body_2d.cpp

@@ -58,7 +58,8 @@ Ref<KinematicCollision2D> PhysicsBody2D::_move(const Vector2 &p_motion, bool p_t
 	PhysicsServer2D::MotionResult result;
 	PhysicsServer2D::MotionResult result;
 
 
 	if (move_and_collide(p_motion, result, p_margin, p_test_only)) {
 	if (move_and_collide(p_motion, result, p_margin, p_test_only)) {
-		if (motion_cache.is_null()) {
+		// Create a new instance when the cached reference is invalid or still in use in script.
+		if (motion_cache.is_null() || motion_cache->reference_get_count() > 1) {
 			motion_cache.instantiate();
 			motion_cache.instantiate();
 			motion_cache->owner = this;
 			motion_cache->owner = this;
 		}
 		}
@@ -1369,7 +1370,8 @@ Ref<KinematicCollision2D> CharacterBody2D::_get_slide_collision(int p_bounce) {
 		slide_colliders.resize(p_bounce + 1);
 		slide_colliders.resize(p_bounce + 1);
 	}
 	}
 
 
-	if (slide_colliders[p_bounce].is_null()) {
+	// Create a new instance when the cached reference is invalid or still in use in script.
+	if (slide_colliders[p_bounce].is_null() || slide_colliders[p_bounce]->reference_get_count() > 1) {
 		slide_colliders.write[p_bounce].instantiate();
 		slide_colliders.write[p_bounce].instantiate();
 		slide_colliders.write[p_bounce]->owner = this;
 		slide_colliders.write[p_bounce]->owner = this;
 	}
 	}

+ 4 - 2
scene/3d/physics_body_3d.cpp

@@ -98,7 +98,8 @@ void PhysicsBody3D::remove_collision_exception_with(Node *p_node) {
 Ref<KinematicCollision3D> PhysicsBody3D::_move(const Vector3 &p_motion, bool p_test_only, real_t p_margin, int p_max_collisions) {
 Ref<KinematicCollision3D> PhysicsBody3D::_move(const Vector3 &p_motion, bool p_test_only, real_t p_margin, int p_max_collisions) {
 	PhysicsServer3D::MotionResult result;
 	PhysicsServer3D::MotionResult result;
 	if (move_and_collide(p_motion, result, p_margin, p_test_only, p_max_collisions)) {
 	if (move_and_collide(p_motion, result, p_margin, p_test_only, p_max_collisions)) {
-		if (motion_cache.is_null()) {
+		// Create a new instance when the cached reference is invalid or still in use in script.
+		if (motion_cache.is_null() || motion_cache->reference_get_count() > 1) {
 			motion_cache.instantiate();
 			motion_cache.instantiate();
 			motion_cache->owner = this;
 			motion_cache->owner = this;
 		}
 		}
@@ -1590,7 +1591,8 @@ Ref<KinematicCollision3D> CharacterBody3D::_get_slide_collision(int p_bounce) {
 		slide_colliders.resize(p_bounce + 1);
 		slide_colliders.resize(p_bounce + 1);
 	}
 	}
 
 
-	if (slide_colliders[p_bounce].is_null()) {
+	// Create a new instance when the cached reference is invalid or still in use in script.
+	if (slide_colliders[p_bounce].is_null() || slide_colliders[p_bounce]->reference_get_count() > 1) {
 		slide_colliders.write[p_bounce].instantiate();
 		slide_colliders.write[p_bounce].instantiate();
 		slide_colliders.write[p_bounce]->owner = this;
 		slide_colliders.write[p_bounce]->owner = this;
 	}
 	}