00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016 #ifndef STRIDING_MESHINTERFACE_H
00017 #define STRIDING_MESHINTERFACE_H
00018
00019 #include "LinearMath/btVector3.h"
00020 #include "btTriangleCallback.h"
00021 #include "btConcaveShape.h"
00022
00023
00024
00025
00026
00030 class btStridingMeshInterface
00031 {
00032 protected:
00033
00034 btVector3 m_scaling;
00035
00036 public:
00037 btStridingMeshInterface() :m_scaling(btScalar(1.),btScalar(1.),btScalar(1.))
00038 {
00039
00040 }
00041
00042 virtual ~btStridingMeshInterface();
00043
00044
00045
00046 virtual void InternalProcessAllTriangles(btInternalTriangleIndexCallback* callback,const btVector3& aabbMin,const btVector3& aabbMax) const;
00047
00049 void calculateAabbBruteForce(btVector3& aabbMin,btVector3& aabbMax);
00050
00056 virtual void getLockedVertexIndexBase(unsigned char **vertexbase, int& numverts,PHY_ScalarType& type, int& stride,unsigned char **indexbase,int & indexstride,int& numfaces,PHY_ScalarType& indicestype,int subpart=0)=0;
00057
00058 virtual void getLockedReadOnlyVertexIndexBase(const unsigned char **vertexbase, int& numverts,PHY_ScalarType& type, int& stride,const unsigned char **indexbase,int & indexstride,int& numfaces,PHY_ScalarType& indicestype,int subpart=0) const=0;
00059
00062 virtual void unLockVertexBase(int subpart)=0;
00063
00064 virtual void unLockReadOnlyVertexBase(int subpart) const=0;
00065
00066
00069 virtual int getNumSubParts() const=0;
00070
00071 virtual void preallocateVertices(int numverts)=0;
00072 virtual void preallocateIndices(int numindices)=0;
00073
00074 virtual bool hasPremadeAabb() const { return false; }
00075 virtual void setPremadeAabb(const btVector3& aabbMin, const btVector3& aabbMax ) const
00076 {
00077 (void) aabbMin;
00078 (void) aabbMax;
00079 }
00080 virtual void getPremadeAabb(btVector3* aabbMin, btVector3* aabbMax ) const
00081 {
00082 (void) aabbMin;
00083 (void) aabbMax;
00084 }
00085
00086 const btVector3& getScaling() const {
00087 return m_scaling;
00088 }
00089 void setScaling(const btVector3& scaling)
00090 {
00091 m_scaling = scaling;
00092 }
00093
00094 virtual int calculateSerializeBufferSize() const;
00095
00097 virtual const char* serialize(void* dataBuffer, btSerializer* serializer) const;
00098
00099
00100 };
00101
00102 struct btIntIndexData
00103 {
00104 int m_value;
00105 };
00106
00107 struct btShortIntIndexData
00108 {
00109 short int m_value;
00110 };
00111
00113 struct btMeshPartData
00114 {
00115 btVector3FloatData *m_vertices3f;
00116 btVector3DoubleData *m_vertices3d;
00117
00118 btIntIndexData *m_indices32;
00119 btShortIntIndexData *m_indices16;
00120 int m_numTriangles;
00121 int m_numVertices;
00122 };
00123
00124
00126 struct btStridingMeshInterfaceData
00127 {
00128 btMeshPartData *m_meshPartsPtr;
00129 btVector3FloatData m_scaling;
00130 int m_numMeshParts;
00131 char m_padding[4];
00132 };
00133
00134
00135
00136
00137 SIMD_FORCE_INLINE int btStridingMeshInterface::calculateSerializeBufferSize() const
00138 {
00139 return sizeof(btStridingMeshInterfaceData);
00140 }
00141
00142
00143
00144 #endif //STRIDING_MESHINTERFACE_H