Blender V2.61 - r43446

BKE_navmesh_conversion.h

Go to the documentation of this file.
00001 /*
00002  * ***** BEGIN GPL LICENSE BLOCK *****
00003  *
00004  * This program is free software; you can redistribute it and/or
00005  * modify it under the terms of the GNU General Public License
00006  * as published by the Free Software Foundation; either version 2
00007  * of the License, or (at your option) any later version.
00008  *
00009  * This program is distributed in the hope that it will be useful,
00010  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00011  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00012  * GNU General Public License for more details.
00013  *
00014  * You should have received a copy of the GNU General Public License
00015  * along with this program; if not, write to the Free Software Foundation,
00016  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
00017  *
00018  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
00019  * All rights reserved.
00020  *
00021  * The Original Code is: all of this file.
00022  *
00023  * Contributor(s): none yet.
00024  *
00025  * ***** END GPL LICENSE BLOCK *****
00026  */
00027 
00028 #ifndef BKE_NAVMESH_CONVERSION_H
00029 #define BKE_NAVMESH_CONVERSION_H
00030 
00031 struct DerivedMesh;
00032 
00033 /* navmesh_conversion.c */
00034 int buildNavMeshDataByDerivedMesh(struct DerivedMesh *dm, int *vertsPerPoly,
00035                                    int *nverts, float **verts,
00036                                    int *ndtris, unsigned short **dtris,
00037                                    int *npolys, unsigned short **dmeshes,
00038                                    unsigned short **polys, int **dtrisToPolysMap,
00039                                    int **dtrisToTrisMap, int **trisToFacesMap);
00040 
00041 int buildRawVertIndicesData(struct DerivedMesh* dm, int *nverts, float **verts,
00042                 int *ntris, unsigned short **tris, int **trisToFacesMap,
00043                 int **recastData);
00044 
00045 int buildNavMeshData(const int nverts, const float* verts,
00046                       const int ntris, const unsigned short *tris,
00047                       const int* recastData, const int* trisToFacesMap,
00048                       int *ndtris, unsigned short **dtris,
00049                       int *npolys, unsigned short **dmeshes, unsigned short **polys,
00050                       int *vertsPerPoly, int **dtrisToPolysMap, int **dtrisToTrisMap);
00051 
00052 int buildPolygonsByDetailedMeshes(const int vertsPerPoly, const int npolys,
00053                 unsigned short* polys, const unsigned short* dmeshes,
00054                 const float* verts, const unsigned short* dtris,
00055                 const int* dtrisToPolysMap);
00056 
00057 int polyNumVerts(const unsigned short* p, const int vertsPerPoly);
00058 int polyIsConvex(const unsigned short* p, const int vertsPerPoly, const float* verts);
00059 int polyFindVertex(const unsigned short* p, const int vertsPerPoly, unsigned short vertexIdx);
00060 float distPointToSegmentSq(const float* point, const float* a, const float* b);
00061 
00062 
00063 #endif //NAVMESH_CONVERSION_H