lugre_meshshape.h

Go to the documentation of this file.
00001 /*
00002 http://www.opensource.org/licenses/mit-license.php  (MIT-License)
00003 
00004 Copyright (c) 2007 Lugre-Team
00005 
00006 Permission is hereby granted, free of charge, to any person obtaining a copy
00007 of this software and associated documentation files (the "Software"), to deal
00008 in the Software without restriction, including without limitation the rights
00009 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
00010 copies of the Software, and to permit persons to whom the Software is
00011 furnished to do so, subject to the following conditions:
00012 
00013 The above copyright notice and this permission notice shall be included in
00014 all copies or substantial portions of the Software.
00015 
00016 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
00017 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
00018 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
00019 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
00020 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
00021 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
00022 THE SOFTWARE.
00023 */
00024 #ifndef LUGRE_MESHSHAPE_H
00025 #define LUGRE_MESHSHAPE_H
00026 
00027 #include <vector>
00028 #include <Ogre.h>
00029 #include <OgreVector3.h>
00030 
00031 namespace Lugre {
00032 
00033 void    UnloadMeshShape     (const char* szMeshName);
00034 
00036 class MeshShape { public :
00037     bool                        mbInitialised; 
00038     Ogre::MeshPtr               mpMesh;
00039     /*
00040     not needed, because of mpMesh->getBoundingSphereRadius()
00041     Ogre::Vector3               mvMid;
00042     Ogre::Real                  mfBoundRad;
00043     */
00044     Ogre::Vector3               mvMin;
00045     Ogre::Vector3               mvMax;
00046     std::vector<Ogre::Vector3>  mlVertices;
00047     std::vector<int>            mlIndices;
00048     
00049     MeshShape   (Ogre::MeshPtr pMesh);
00050     ~MeshShape  ();
00051     
00052     void        Update          (Ogre::Entity *pEntity);
00053     void        RayIntersect    (const Ogre::Vector3& ray_origin,const Ogre::Vector3& ray_dir,std::vector<std::pair<float,int> > &pHitList);
00054     int         RayIntersect    (const Ogre::Vector3& ray_origin,const Ogre::Vector3& ray_dir,float* pfHitDist=0);
00055     
00056     static MeshShape*   GetMeshShape        (Ogre::Entity* pEntity);
00057 };
00058 
00059 bool    IntersectRayTriangle    (const Ogre::Vector3& ray_origin,const Ogre::Vector3& ray_dir,const Ogre::Vector3& a,const Ogre::Vector3& b,const Ogre::Vector3& c,float* pfHitDist=0,float* pfABC=0);
00060 
00061 };
00062 
00063 #endif

Generated on Wed May 23 06:00:13 2012 for cpp by  doxygen 1.5.6