mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 07:26:37 +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.getSubHeaderIs(8);
|
|
esm.getT<int>(X);
|
|
esm.getT<int>(Y);
|
|
|
|
esm.getHNT(flags, "DATA");
|
|
|
|
// Store the file position
|
|
context = esm.getContext();
|
|
|
|
hasData = false;
|
|
int cnt = 0;
|
|
|
|
// 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
|