diff --git a/scene/2d/collision_polygon_2d.cpp b/scene/2d/collision_polygon_2d.cpp index c2890b117a7..1c508ec77b2 100644 --- a/scene/2d/collision_polygon_2d.cpp +++ b/scene/2d/collision_polygon_2d.cpp @@ -205,6 +205,7 @@ void CollisionPolygon2D::set_polygon(const Vector &p_polygon) { if (parent) { _build_polygon(); + _update_in_shape_owner(); } update(); update_configuration_warning(); @@ -221,6 +222,7 @@ void CollisionPolygon2D::set_build_mode(BuildMode p_mode) { build_mode = p_mode; if (parent) { _build_polygon(); + _update_in_shape_owner(); } } diff --git a/scene/2d/collision_shape_2d.cpp b/scene/2d/collision_shape_2d.cpp index 589dfa1492b..dfe69943582 100644 --- a/scene/2d/collision_shape_2d.cpp +++ b/scene/2d/collision_shape_2d.cpp @@ -147,7 +147,9 @@ void CollisionShape2D::_notification(int p_what) { } void CollisionShape2D::set_shape(const Ref &p_shape) { - + if (p_shape == shape) { + return; + } if (shape.is_valid()) shape->disconnect("changed", this, "_shape_changed"); shape = p_shape; @@ -157,6 +159,7 @@ void CollisionShape2D::set_shape(const Ref &p_shape) { if (shape.is_valid()) { parent->shape_owner_add_shape(owner_id, shape); } + _update_in_shape_owner(); } if (shape.is_valid()) diff --git a/scene/3d/collision_shape.cpp b/scene/3d/collision_shape.cpp index 9e3e45326f9..9d8351f1a93 100644 --- a/scene/3d/collision_shape.cpp +++ b/scene/3d/collision_shape.cpp @@ -83,7 +83,6 @@ void CollisionShape::_notification(int p_what) { if (shape.is_valid()) { parent->shape_owner_add_shape(owner_id, shape); } - _update_in_shape_owner(); } } break; case NOTIFICATION_ENTER_TREE: { @@ -170,7 +169,9 @@ void CollisionShape::_bind_methods() { } void CollisionShape::set_shape(const Ref &p_shape) { - + if (p_shape == shape) { + return; + } if (!shape.is_null()) { shape->unregister_owner(this); shape->disconnect("changed", this, "_shape_changed");