Merge pull request #69657 from rburing/degenerate_capsule_has_no_edge

Fix collision detection for degenerate capsules
This commit is contained in:
Rémi Verschelde 2022-12-06 15:16:44 +01:00
commit c83695c0b5
No known key found for this signature in database
GPG Key ID: C3336907360768E1
2 changed files with 8 additions and 12 deletions

View File

@ -369,8 +369,9 @@ void GodotCapsuleShape2D::get_supports(const Vector2 &p_normal, Vector2 *r_suppo
Vector2 n = p_normal;
real_t d = n.y;
real_t h = height * 0.5 - radius; // half-height of the rectangle part
if (Math::abs(d) < (1.0 - _SEGMENT_IS_VALID_SUPPORT_THRESHOLD)) {
if (h > 0 && Math::abs(d) < (1.0 - _SEGMENT_IS_VALID_SUPPORT_THRESHOLD)) {
// make it flat
n.y = 0.0;
n.normalize();
@ -378,13 +379,10 @@ void GodotCapsuleShape2D::get_supports(const Vector2 &p_normal, Vector2 *r_suppo
r_amount = 2;
r_supports[0] = n;
r_supports[0].y += height * 0.5 - radius;
r_supports[0].y += h;
r_supports[1] = n;
r_supports[1].y -= height * 0.5 - radius;
r_supports[1].y -= h;
} else {
real_t h = height * 0.5 - radius;
n *= radius;
n.y += (d > 0) ? h : -h;
r_amount = 1;

View File

@ -521,8 +521,9 @@ void GodotCapsuleShape3D::get_supports(const Vector3 &p_normal, int p_max, Vecto
Vector3 n = p_normal;
real_t d = n.y;
real_t h = height * 0.5 - radius; // half-height of the cylinder part
if (Math::abs(d) < edge_support_threshold) {
if (h > 0 && Math::abs(d) < edge_support_threshold) {
// make it flat
n.y = 0.0;
n.normalize();
@ -531,13 +532,10 @@ void GodotCapsuleShape3D::get_supports(const Vector3 &p_normal, int p_max, Vecto
r_amount = 2;
r_type = FEATURE_EDGE;
r_supports[0] = n;
r_supports[0].y += height * 0.5 - radius;
r_supports[0].y += h;
r_supports[1] = n;
r_supports[1].y -= height * 0.5 - radius;
r_supports[1].y -= h;
} else {
real_t h = height * 0.5 - radius;
n *= radius;
n.y += (d > 0) ? h : -h;
r_amount = 1;