From 1d16153881262d226a8bba7274609ccc0a549856 Mon Sep 17 00:00:00 2001 From: Ricardo Buring Date: Thu, 24 Mar 2022 14:44:49 +0100 Subject: [PATCH] collide_shape: return contact points in world space --- modules/bullet/godot_result_callbacks.cpp | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/modules/bullet/godot_result_callbacks.cpp b/modules/bullet/godot_result_callbacks.cpp index 3c594735cfc..58607332939 100644 --- a/modules/bullet/godot_result_callbacks.cpp +++ b/modules/bullet/godot_result_callbacks.cpp @@ -299,12 +299,13 @@ btScalar GodotContactPairContactResultCallback::addSingleResult(btManifoldPoint return 1; // not used by bullet } + // In each contact pair, the contact on the shape which was passed to collide_shape (where this callback is used) is put first. if (m_self_object == colObj0Wrap->getCollisionObject()) { - B_TO_G(cp.m_localPointA, m_results[m_count * 2 + 0]); // Local contact - B_TO_G(cp.m_localPointB, m_results[m_count * 2 + 1]); + B_TO_G(cp.getPositionWorldOnA(), m_results[m_count * 2 + 0]); + B_TO_G(cp.getPositionWorldOnB(), m_results[m_count * 2 + 1]); } else { - B_TO_G(cp.m_localPointB, m_results[m_count * 2 + 0]); // Local contact - B_TO_G(cp.m_localPointA, m_results[m_count * 2 + 1]); + B_TO_G(cp.getPositionWorldOnB(), m_results[m_count * 2 + 0]); + B_TO_G(cp.getPositionWorldOnA(), m_results[m_count * 2 + 1]); } ++m_count;