mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 09:56:39 +00:00
284 lines
8.6 KiB
C++
284 lines
8.6 KiB
C++
/*
|
|
* =====================================================================================
|
|
*
|
|
* Filename: BtOgreExtras.h
|
|
*
|
|
* Description: Contains the Ogre Mesh to Bullet Shape converters.
|
|
*
|
|
* Version: 1.0
|
|
* Created: 27/12/2008 01:45:56 PM
|
|
*
|
|
* Author: Nikhilesh (nikki)
|
|
*
|
|
* =====================================================================================
|
|
*/
|
|
|
|
#ifndef BtOgreShapes_H_
|
|
#define BtOgreShapes_H_
|
|
|
|
#include "btBulletDynamicsCommon.h"
|
|
#include "OgreSimpleRenderable.h"
|
|
#include "OgreCamera.h"
|
|
#include "OgreHardwareBufferManager.h"
|
|
#include "OgreMaterialManager.h"
|
|
#include "OgreTechnique.h"
|
|
#include "OgrePass.h"
|
|
|
|
#include "OgreLogManager.h"
|
|
|
|
namespace BtOgre
|
|
{
|
|
|
|
typedef std::vector<Ogre::Vector3> Vector3Array;
|
|
|
|
//Converts from and to Bullet and Ogre stuff. Pretty self-explanatory.
|
|
class Convert
|
|
{
|
|
public:
|
|
Convert() {};
|
|
~Convert() {};
|
|
|
|
static btQuaternion toBullet(const Ogre::Quaternion &q)
|
|
{
|
|
return btQuaternion(q.x, q.y, q.z, q.w);
|
|
}
|
|
static btVector3 toBullet(const Ogre::Vector3 &v)
|
|
{
|
|
return btVector3(v.x, v.y, v.z);
|
|
}
|
|
|
|
static Ogre::Quaternion toOgre(const btQuaternion &q)
|
|
{
|
|
return Ogre::Quaternion(q.w(), q.x(), q.y(), q.z());
|
|
}
|
|
static Ogre::Vector3 toOgre(const btVector3 &v)
|
|
{
|
|
return Ogre::Vector3(v.x(), v.y(), v.z());
|
|
}
|
|
};
|
|
|
|
//From here on its debug-drawing stuff. ------------------------------------------------------------------
|
|
|
|
class DynamicRenderable : public Ogre::SimpleRenderable
|
|
{
|
|
public:
|
|
/// Constructor
|
|
DynamicRenderable();
|
|
/// Virtual destructor
|
|
virtual ~DynamicRenderable();
|
|
|
|
/** Initializes the dynamic renderable.
|
|
@remarks
|
|
This function should only be called once. It initializes the
|
|
render operation, and calls the abstract function
|
|
createVertexDeclaration().
|
|
@param operationType The type of render operation to perform.
|
|
@param useIndices Specifies whether to use indices to determine the
|
|
vertices to use as input. */
|
|
void initialize(Ogre::RenderOperation::OperationType operationType,
|
|
bool useIndices);
|
|
|
|
/// Implementation of Ogre::SimpleRenderable
|
|
virtual Ogre::Real getBoundingRadius(void) const;
|
|
/// Implementation of Ogre::SimpleRenderable
|
|
virtual Ogre::Real getSquaredViewDepth(const Ogre::Camera* cam) const;
|
|
|
|
protected:
|
|
/// Maximum capacity of the currently allocated vertex buffer.
|
|
size_t mVertexBufferCapacity;
|
|
/// Maximum capacity of the currently allocated index buffer.
|
|
size_t mIndexBufferCapacity;
|
|
|
|
/** Creates the vertex declaration.
|
|
@remarks
|
|
Override and set mRenderOp.vertexData->vertexDeclaration here.
|
|
mRenderOp.vertexData will be created for you before this method
|
|
is called. */
|
|
virtual void createVertexDeclaration() = 0;
|
|
|
|
/** Prepares the hardware buffers for the requested vertex and index counts.
|
|
@remarks
|
|
This function must be called before locking the buffers in
|
|
fillHardwareBuffers(). It guarantees that the hardware buffers
|
|
are large enough to hold at least the requested number of
|
|
vertices and indices (if using indices). The buffers are
|
|
possibly reallocated to achieve this.
|
|
@par
|
|
The vertex and index count in the render operation are set to
|
|
the values of vertexCount and indexCount respectively.
|
|
@param vertexCount The number of vertices the buffer must hold.
|
|
|
|
@param indexCount The number of indices the buffer must hold. This
|
|
parameter is ignored if not using indices. */
|
|
void prepareHardwareBuffers(size_t vertexCount, size_t indexCount);
|
|
|
|
/** Fills the hardware vertex and index buffers with data.
|
|
@remarks
|
|
This function must call prepareHardwareBuffers() before locking
|
|
the buffers to ensure the they are large enough for the data to
|
|
be written. Afterwards the vertex and index buffers (if using
|
|
indices) can be locked, and data can be written to them. */
|
|
virtual void fillHardwareBuffers() = 0;
|
|
};
|
|
|
|
class DynamicLines : public DynamicRenderable
|
|
{
|
|
typedef Ogre::Vector3 Vector3;
|
|
typedef Ogre::Quaternion Quaternion;
|
|
typedef Ogre::Camera Camera;
|
|
typedef Ogre::Real Real;
|
|
typedef Ogre::RenderOperation::OperationType OperationType;
|
|
|
|
public:
|
|
/// Constructor - see setOperationType() for description of argument.
|
|
DynamicLines(OperationType opType=Ogre::RenderOperation::OT_LINE_STRIP);
|
|
virtual ~DynamicLines();
|
|
|
|
/// Add a point to the point list
|
|
void addPoint(const Ogre::Vector3 &p);
|
|
/// Add a point to the point list
|
|
void addPoint(Real x, Real y, Real z);
|
|
|
|
/// Change the location of an existing point in the point list
|
|
void setPoint(unsigned short index, const Vector3 &value);
|
|
|
|
/// Return the location of an existing point in the point list
|
|
const Vector3& getPoint(unsigned short index) const;
|
|
|
|
/// Return the total number of points in the point list
|
|
unsigned short getNumPoints(void) const;
|
|
|
|
/// Remove all points from the point list
|
|
void clear();
|
|
|
|
/// Call this to update the hardware buffer after making changes.
|
|
void update();
|
|
|
|
/** Set the type of operation to draw with.
|
|
* @param opType Can be one of
|
|
* - RenderOperation::OT_LINE_STRIP
|
|
* - RenderOperation::OT_LINE_LIST
|
|
* - RenderOperation::OT_POINT_LIST
|
|
* - RenderOperation::OT_TRIANGLE_LIST
|
|
* - RenderOperation::OT_TRIANGLE_STRIP
|
|
* - RenderOperation::OT_TRIANGLE_FAN
|
|
* The default is OT_LINE_STRIP.
|
|
*/
|
|
void setOperationType(OperationType opType);
|
|
OperationType getOperationType() const;
|
|
|
|
protected:
|
|
/// Implementation DynamicRenderable, creates a simple vertex-only decl
|
|
virtual void createVertexDeclaration();
|
|
/// Implementation DynamicRenderable, pushes point list out to hardware memory
|
|
virtual void fillHardwareBuffers();
|
|
|
|
private:
|
|
std::vector<Vector3> mPoints;
|
|
bool mDirty;
|
|
};
|
|
|
|
class DebugDrawer : public btIDebugDraw
|
|
{
|
|
protected:
|
|
Ogre::SceneNode *mNode;
|
|
btDynamicsWorld *mWorld;
|
|
DynamicLines *mLineDrawer;
|
|
bool mDebugOn;
|
|
|
|
public:
|
|
|
|
DebugDrawer(Ogre::SceneNode *node, btDynamicsWorld *world)
|
|
: mNode(node),
|
|
mWorld(world),
|
|
mDebugOn(true)
|
|
{
|
|
mLineDrawer = new DynamicLines(Ogre::RenderOperation::OT_LINE_LIST);
|
|
mNode->attachObject(mLineDrawer);
|
|
|
|
if (!Ogre::ResourceGroupManager::getSingleton().resourceGroupExists("BtOgre"))
|
|
Ogre::ResourceGroupManager::getSingleton().createResourceGroup("BtOgre");
|
|
if (!Ogre::MaterialManager::getSingleton().resourceExists("BtOgre/DebugLines"))
|
|
{
|
|
Ogre::MaterialPtr mat = Ogre::MaterialManager::getSingleton().create("BtOgre/DebugLines", "BtOgre");
|
|
mat->setReceiveShadows(false);
|
|
mat->setSelfIllumination(1,1,1);
|
|
}
|
|
|
|
mLineDrawer->setMaterial("BtOgre/DebugLines");
|
|
|
|
//mLineDrawer->setVisibilityFlags (1024);
|
|
}
|
|
|
|
~DebugDrawer()
|
|
{
|
|
if (Ogre::MaterialManager::getSingleton().resourceExists("BtOgre/DebugLines"))
|
|
Ogre::MaterialManager::getSingleton().remove("BtOgre/DebugLines");
|
|
if (Ogre::ResourceGroupManager::getSingleton().resourceGroupExists("BtOgre"))
|
|
Ogre::ResourceGroupManager::getSingleton().destroyResourceGroup("BtOgre");
|
|
delete mLineDrawer;
|
|
}
|
|
|
|
void step()
|
|
{
|
|
if (mDebugOn)
|
|
{
|
|
mWorld->debugDrawWorld();
|
|
mLineDrawer->update();
|
|
mNode->needUpdate();
|
|
mLineDrawer->clear();
|
|
}
|
|
else
|
|
{
|
|
mLineDrawer->clear();
|
|
mLineDrawer->update();
|
|
mNode->needUpdate();
|
|
}
|
|
}
|
|
|
|
void drawLine(const btVector3& from,const btVector3& to,const btVector3& color)
|
|
{
|
|
mLineDrawer->addPoint(Convert::toOgre(from));
|
|
mLineDrawer->addPoint(Convert::toOgre(to));
|
|
}
|
|
|
|
void drawContactPoint(const btVector3& PointOnB,const btVector3& normalOnB,btScalar distance,int lifeTime,const btVector3& color)
|
|
{
|
|
mLineDrawer->addPoint(Convert::toOgre(PointOnB));
|
|
mLineDrawer->addPoint(Convert::toOgre(PointOnB) + (Convert::toOgre(normalOnB) * distance * 20));
|
|
}
|
|
|
|
void reportErrorWarning(const char* warningString)
|
|
{
|
|
Ogre::LogManager::getSingleton().logMessage(warningString);
|
|
}
|
|
|
|
void draw3dText(const btVector3& location,const char* textString)
|
|
{
|
|
}
|
|
|
|
//0 for off, anything else for on.
|
|
void setDebugMode(int isOn)
|
|
{
|
|
mDebugOn = (isOn == 0) ? false : true;
|
|
|
|
if (!mDebugOn)
|
|
mLineDrawer->clear();
|
|
}
|
|
|
|
//0 for off, anything else for on.
|
|
int getDebugMode() const
|
|
{
|
|
return mDebugOn;
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|