openmw-tes3coop/components/esm/loadland.hpp

54 lines
1.2 KiB
C++
Raw Normal View History

2010-02-25 13:03:03 +00:00
#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");
2010-10-03 10:41:35 +00:00
esm.getSubHeaderIs(8);
esm.getT<int>(X);
esm.getT<int>(Y);
2010-02-25 13:03:03 +00:00
esm.getHNT(flags, "DATA");
// Store the file position
context = esm.getContext();
hasData = false;
2010-09-11 13:52:20 +00:00
int cnt = 0;
2010-02-25 13:03:03 +00:00
// 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