mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-23 06:53:54 +00:00
53 lines
1.2 KiB
C++
53 lines
1.2 KiB
C++
|
#ifndef _ESM_LAND_H
|
||
|
#define _ESM_LAND_H
|
||
|
|
||
|
#include "esm_reader.hpp"
|
||
|
|
||
|
namespace ESM {
|
||
|
|
||
|
/*
|
||
|
* Landscape data.
|
||
|
*/
|
||
|
|
||
|
struct Land
|
||
|
{
|
||
|
int flags; // Only first four bits seem to be used, don't know what
|
||
|
// they mean.
|
||
|
int X, Y; // Map coordinates.
|
||
|
|
||
|
// File context. This allows the ESM reader to be 'reset' to this
|
||
|
// location later when we are ready to load the full data set.
|
||
|
ESM_Context context;
|
||
|
|
||
|
bool hasData;
|
||
|
|
||
|
void load(ESMReader &esm)
|
||
|
{
|
||
|
// Get the grid location
|
||
|
esm.getSubNameIs("INTV");
|
||
|
esm.getT(X);
|
||
|
esm.getT(Y);
|
||
|
|
||
|
esm.getHNT(flags, "DATA");
|
||
|
|
||
|
// Store the file position
|
||
|
context = esm.getContext();
|
||
|
|
||
|
hasData = false;
|
||
|
int cnt;
|
||
|
|
||
|
// Skip these here. Load the actual data when the cell is loaded.
|
||
|
if(esm.isNextSub("VNML")) {esm.skipHSubSize(12675);cnt++;}
|
||
|
if(esm.isNextSub("VHGT")) {esm.skipHSubSize(4232);cnt++;}
|
||
|
if(esm.isNextSub("WNAM")) esm.skipHSubSize(81);
|
||
|
if(esm.isNextSub("VCLR")) esm.skipHSubSize(12675);
|
||
|
if(esm.isNextSub("VTEX")) {esm.skipHSubSize(512);cnt++;}
|
||
|
|
||
|
// We need all three of VNML, VHGT and VTEX in order to use the
|
||
|
// landscape.
|
||
|
hasData = (cnt == 3);
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
#endif
|