mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 11:56:37 +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
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 |