#ifndef OPENMW_ESM_PGRD_H #define OPENMW_ESM_PGRD_H #include #include #include "components/esm/defs.hpp" #include "components/esm/refid.hpp" namespace ESM { class ESMReader; class ESMWriter; /* * Path grid. */ struct Pathgrid { constexpr static RecNameInts sRecordId = REC_PGRD; /// Return a string descriptor for this record type. Currently used for debugging / error logs only. static std::string_view getRecordType() { return "Pathgrid"; } struct DATAstruct { int32_t mX, mY; // Grid location, matches cell for exterior cells int16_t mGranularity; // Granularity with which the graph was autogenerated uint16_t mPoints; // Number of path points. }; // 12 bytes struct Point // path grid point { int32_t mX, mY, mZ; // Location of point unsigned char mAutogenerated; // autogenerated vs. user coloring flag? unsigned char mConnectionNum; // number of connections for this point Point& operator=(const float[3]); Point(const float[3]); Point(); Point(int x, int y, int z) : mX(x) , mY(y) , mZ(z) , mAutogenerated(0) , mConnectionNum(0) { } }; // 16 bytes struct Edge // path grid edge { size_t mV0, mV1; // index of points connected with this edge }; ESM::RefId mCell; // Cell name DATAstruct mData; typedef std::vector PointList; PointList mPoints; typedef std::vector EdgeList; EdgeList mEdges; void load(ESMReader& esm, bool& isDeleted); void save(ESMWriter& esm, bool isDeleted = false) const; void blank(); }; } #endif