2010-02-25 13:03:03 +00:00
|
|
|
#ifndef _ESM_PGRD_H
|
|
|
|
#define _ESM_PGRD_H
|
|
|
|
|
|
|
|
#include "esm_reader.hpp"
|
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
namespace ESM
|
|
|
|
{
|
2010-02-25 13:03:03 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Path grid.
|
|
|
|
*/
|
2012-03-09 19:35:20 +00:00
|
|
|
struct Pathgrid
|
2010-02-25 13:03:03 +00:00
|
|
|
{
|
2011-04-08 13:58:21 +00:00
|
|
|
struct DATAstruct
|
|
|
|
{
|
|
|
|
int x, y; // Grid location, matches cell for exterior cells
|
|
|
|
short s1; // ?? Usually but not always a power of 2. Doesn't seem
|
|
|
|
// to have any relation to the size of PGRC.
|
2012-03-10 09:37:35 +00:00
|
|
|
short s2; // Number of path points.
|
2011-04-08 13:58:21 +00:00
|
|
|
}; // 12 bytes
|
2010-02-25 13:03:03 +00:00
|
|
|
|
2012-03-02 15:50:04 +00:00
|
|
|
struct Point // path grid point
|
|
|
|
{
|
2012-03-04 20:04:36 +00:00
|
|
|
int x, y, z; // Location of point
|
2012-03-14 08:45:42 +00:00
|
|
|
unsigned char autogenerated; // autogenerated vs. user coloring flag?
|
|
|
|
unsigned char connectionNum; // number of connections for this point
|
|
|
|
short unknown;
|
2012-03-02 15:50:04 +00:00
|
|
|
}; // 16 bytes
|
|
|
|
|
|
|
|
struct Edge // path grid edge
|
|
|
|
{
|
|
|
|
int v0, v1; // index of points connected with this edge
|
|
|
|
}; // 8 bytes
|
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
std::string cell; // Cell name
|
|
|
|
DATAstruct data;
|
2012-03-02 15:50:04 +00:00
|
|
|
|
2012-03-10 09:37:35 +00:00
|
|
|
typedef std::vector<Point> PointList;
|
|
|
|
PointList points;
|
2012-03-09 19:35:20 +00:00
|
|
|
|
2012-03-10 09:37:35 +00:00
|
|
|
typedef std::vector<Edge> EdgeList;
|
|
|
|
EdgeList edges;
|
2012-03-02 15:50:04 +00:00
|
|
|
|
2011-04-08 13:58:21 +00:00
|
|
|
void load(ESMReader &esm);
|
2010-02-25 13:03:03 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|