-
-
Notifications
You must be signed in to change notification settings - Fork 21.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ensure KinematicBodies only interact with other Bodies with matching mask. #42641
Conversation
Rebased following merge of #43952. |
Now we have an approved proposal: So this change is welcome for 4.0, the PR just needs a rebase. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I haven't tested the changes in Bullet, but they look ok.
Works fine in Godot Physics.
Thanks! |
@@ -549,7 +549,7 @@ int Space3DSW::_cull_aabb_for_body(Body3DSW *p_body, const AABB &p_aabb) { | |||
keep = false; | |||
} else if (intersection_query_results[i]->get_type() == CollisionObject3DSW::TYPE_SOFT_BODY) { | |||
keep = false; | |||
} else if ((static_cast<Body3DSW *>(intersection_query_results[i])->test_collision_mask(p_body)) == 0) { | |||
} else if (!p_body->layer_in_mask(static_cast<Body3DSW *>(intersection_query_results[i]))) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually after doing more tests I realized this layer check is inverted, a kinematic body should collide with objects it scans in its own mask, not objects which have its own layer in their mask. I'll make a fix in another PR.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the correct way around. A KinematicBody
should only interact with other Bodies
that have a matching mask.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The way you implemented things, walls would define what they stop instead of moving bodies what they collide with. That would be a nightmare for users to setup.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You're right. Its mask is the layers it sees. So it is the other way around.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It probably makes more sense then to revert the logic (and the name) of layer_in_mask
to mask_has_layer
.
Currently, when a
KinematicBody
collides with anotherCollisionObject
thecollision_layer
->collision_mask
combination is checked both ways. This results in unintended and unwanted collisions. For example, you may want a bullet to be stopped by a shield, but not a shield to be stopped by a bullet.This PR ensures that
KinematicBodies
only collide withCollisionObjects
that have one of theKinematicBody
'scollision_layer
bits in the otherCollisionObject
'scollision_mask
. It fixes both 2D and 3D (Godot and Bullet) physics.This PR is the
KinematicBody
sister to #42268, which fixescollision_layer
->collision_mask
checks forArea
s.Fixes #15243.