1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-16 08:49:55 +00:00
openmw-tes3mp/apps/openmw/mwrender/bulletdebugdraw.cpp

119 lines
2.4 KiB
C++
Raw Normal View History

2015-05-02 22:39:01 +00:00
#include "bulletdebugdraw.hpp"
#include <iostream>
#include <BulletCollision/CollisionDispatch/btCollisionWorld.h>
2015-05-27 20:32:11 +00:00
2015-05-02 22:39:01 +00:00
#include <osg/Geode>
#include <osg/Geometry>
#include <osg/Group>
#include "vismask.hpp"
namespace
{
osg::Vec3f toOsg(const btVector3& vec)
{
return osg::Vec3f(vec.x(), vec.y(), vec.z());
}
}
namespace MWRender
{
DebugDrawer::DebugDrawer(osg::ref_ptr<osg::Group> parentNode, btCollisionWorld *world)
2015-05-02 22:39:01 +00:00
: mParentNode(parentNode),
mWorld(world),
mDebugOn(true)
{
mGeode = new osg::Geode;
mParentNode->addChild(mGeode);
mGeode->setNodeMask(Mask_Debug);
2015-05-24 02:28:34 +00:00
createGeometry();
2015-05-02 22:39:01 +00:00
2015-05-24 02:28:34 +00:00
mParentNode->addChild(mGeode);
}
void DebugDrawer::createGeometry()
{
if (!mGeometry)
{
mGeometry = new osg::Geometry;
2015-05-02 22:39:01 +00:00
2015-05-24 02:28:34 +00:00
mVertices = new osg::Vec3Array;
2015-05-02 22:39:01 +00:00
2015-05-24 02:28:34 +00:00
mDrawArrays = new osg::DrawArrays(osg::PrimitiveSet::LINES);
2015-05-02 22:39:01 +00:00
2015-05-24 02:28:34 +00:00
mGeometry->setUseDisplayList(false);
mGeometry->setVertexArray(mVertices);
mGeometry->setDataVariance(osg::Object::DYNAMIC);
mGeometry->addPrimitiveSet(mDrawArrays);
mGeode->addDrawable(mGeometry);
}
}
void DebugDrawer::destroyGeometry()
{
if (mGeometry)
{
mGeode->removeDrawable(mGeometry);
mGeometry = NULL;
mVertices = NULL;
mDrawArrays = NULL;
}
2015-05-02 22:39:01 +00:00
}
DebugDrawer::~DebugDrawer()
{
mParentNode->removeChild(mGeode);
}
void DebugDrawer::step()
{
if (mDebugOn)
{
mVertices->clear();
mWorld->debugDrawWorld();
mDrawArrays->setCount(mVertices->size());
mVertices->dirty();
}
}
void DebugDrawer::drawLine(const btVector3 &from, const btVector3 &to, const btVector3 &color)
{
mVertices->push_back(toOsg(from));
mVertices->push_back(toOsg(to));
}
void DebugDrawer::drawContactPoint(const btVector3 &PointOnB, const btVector3 &normalOnB, btScalar distance, int lifeTime, const btVector3 &color)
{
mVertices->push_back(toOsg(PointOnB));
mVertices->push_back(toOsg(PointOnB) + (toOsg(normalOnB) * distance * 20));
}
void DebugDrawer::reportErrorWarning(const char *warningString)
{
std::cerr << warningString << std::endl;
}
void DebugDrawer::setDebugMode(int isOn)
{
mDebugOn = (isOn == 0) ? false : true;
if (!mDebugOn)
2015-05-24 02:28:34 +00:00
destroyGeometry();
else
createGeometry();
2015-05-02 22:39:01 +00:00
}
int DebugDrawer::getDebugMode() const
{
return mDebugOn;
}
}