1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-24 07:56:42 +00:00

The debug drawer rely on Bullet to determines the vertices of collision

shapes. It doesn't work in the case of spheres (used by projectiles):
resulting shape is malformed. It can also leads to this error which
makes the debug drawer non-working till game restart:
CullVisitor::apply(Geode&) detected NaN,
    depth=nan, center=(nan nan nan),
    matrix={
       -0.265814 -0.0639702 0.9619 0
       0.964024 -0.0176387 0.265228 0
       -4.29769e-09 0.997796 0.0663574 0
       18178.6 -3550.91 42154.4 1
}

Avoid this issue by using osg::Sphere

While here, remove an unused function. We don't use Bullet's solver so
we never have any contact points (in Bullet parlance).
This commit is contained in:
fredzio 2020-12-22 14:51:16 +01:00
parent cdf0bc1d8d
commit 5215ffd964
2 changed files with 20 additions and 6 deletions

View file

@ -7,6 +7,9 @@
#include <components/debug/debuglog.hpp> #include <components/debug/debuglog.hpp>
#include <components/misc/convert.hpp> #include <components/misc/convert.hpp>
#include <osg/PolygonMode>
#include <osg/ShapeDrawable>
#include <osg/StateSet>
#include "bulletdebugdraw.hpp" #include "bulletdebugdraw.hpp"
#include "vismask.hpp" #include "vismask.hpp"
@ -41,6 +44,14 @@ void DebugDrawer::createGeometry()
mGeometry->addPrimitiveSet(mDrawArrays); mGeometry->addPrimitiveSet(mDrawArrays);
mParentNode->addChild(mGeometry); mParentNode->addChild(mGeometry);
auto* stateSet = new osg::StateSet;
stateSet->setAttributeAndModes(new osg::PolygonMode(osg::PolygonMode::FRONT_AND_BACK, osg::PolygonMode::LINE), osg::StateAttribute::ON);
mShapesRoot = new osg::Group;
mShapesRoot->setStateSet(stateSet);
mShapesRoot->setDataVariance(osg::Object::DYNAMIC);
mShapesRoot->setNodeMask(Mask_Debug);
mParentNode->addChild(mShapesRoot);
} }
} }
@ -49,6 +60,7 @@ void DebugDrawer::destroyGeometry()
if (mGeometry) if (mGeometry)
{ {
mParentNode->removeChild(mGeometry); mParentNode->removeChild(mGeometry);
mParentNode->removeChild(mShapesRoot);
mGeometry = nullptr; mGeometry = nullptr;
mVertices = nullptr; mVertices = nullptr;
mDrawArrays = nullptr; mDrawArrays = nullptr;
@ -66,6 +78,7 @@ void DebugDrawer::step()
{ {
mVertices->clear(); mVertices->clear();
mColors->clear(); mColors->clear();
mShapesRoot->removeChildren(0, mShapesRoot->getNumChildren());
mWorld->debugDrawWorld(); mWorld->debugDrawWorld();
showCollisions(); showCollisions();
mDrawArrays->setCount(mVertices->size()); mDrawArrays->setCount(mVertices->size());
@ -106,12 +119,11 @@ void DebugDrawer::showCollisions()
mCollisionViews.end()); mCollisionViews.end());
} }
void DebugDrawer::drawContactPoint(const btVector3 &PointOnB, const btVector3 &normalOnB, btScalar distance, int lifeTime, const btVector3 &color) void DebugDrawer::drawSphere(btScalar radius, const btTransform& transform, const btVector3& color)
{ {
mVertices->push_back(Misc::Convert::toOsg(PointOnB)); auto* geom = new osg::ShapeDrawable(new osg::Sphere(Misc::Convert::toOsg(transform.getOrigin()), radius));
mVertices->push_back(Misc::Convert::toOsg(PointOnB) + (Misc::Convert::toOsg(normalOnB) * distance * 20)); geom->setColor(osg::Vec4(1, 1, 1, 1));
mColors->push_back({1,1,1,1}); mShapesRoot->addChild(geom);
mColors->push_back({1,1,1,1});
} }
void DebugDrawer::reportErrorWarning(const char *warningString) void DebugDrawer::reportErrorWarning(const char *warningString)

View file

@ -32,6 +32,7 @@ private:
CollisionView(btVector3 orig, btVector3 normal) : mOrig(orig), mEnd(orig + normal * 20), mCreated(std::chrono::steady_clock::now()) {}; CollisionView(btVector3 orig, btVector3 normal) : mOrig(orig), mEnd(orig + normal * 20), mCreated(std::chrono::steady_clock::now()) {};
}; };
std::vector<CollisionView> mCollisionViews; std::vector<CollisionView> mCollisionViews;
osg::ref_ptr<osg::Group> mShapesRoot;
protected: protected:
osg::ref_ptr<osg::Group> mParentNode; osg::ref_ptr<osg::Group> mParentNode;
@ -59,7 +60,8 @@ public:
void showCollisions(); void showCollisions();
void drawContactPoint(const btVector3& PointOnB,const btVector3& normalOnB,btScalar distance,int lifeTime,const btVector3& color) override; void drawContactPoint(const btVector3& PointOnB,const btVector3& normalOnB,btScalar distance,int lifeTime,const btVector3& color) override {};
void drawSphere(btScalar radius, const btTransform& transform, const btVector3& color) override;
void reportErrorWarning(const char* warningString) override; void reportErrorWarning(const char* warningString) override;