2014-10-08 15:17:31 +00:00
|
|
|
#include "terrainstorage.hpp"
|
|
|
|
|
2017-09-04 19:13:45 +00:00
|
|
|
#include "../../model/world/land.hpp"
|
|
|
|
#include "../../model/world/landtexture.hpp"
|
|
|
|
|
2014-10-08 15:17:31 +00:00
|
|
|
namespace CSVRender
|
|
|
|
{
|
|
|
|
|
|
|
|
TerrainStorage::TerrainStorage(const CSMWorld::Data &data)
|
2015-06-02 23:18:36 +00:00
|
|
|
: ESMTerrain::Storage(data.getResourceSystem()->getVFS())
|
|
|
|
, mData(data)
|
2014-10-08 15:17:31 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-03-06 18:04:17 +00:00
|
|
|
osg::ref_ptr<const ESMTerrain::LandObject> TerrainStorage::getLand(int cellX, int cellY)
|
2014-10-08 15:17:31 +00:00
|
|
|
{
|
|
|
|
// The cell isn't guaranteed to have Land. This is because the terrain implementation
|
|
|
|
// has to wrap the vertices of the last row and column to the next cell, which may be a nonexisting cell
|
2017-09-04 19:13:45 +00:00
|
|
|
int index = mData.getLand().searchId(CSMWorld::Land::createUniqueRecordId(cellX, cellY));
|
2014-10-08 15:17:31 +00:00
|
|
|
if (index == -1)
|
|
|
|
return NULL;
|
|
|
|
|
2015-08-31 16:13:27 +00:00
|
|
|
const ESM::Land& land = mData.getLand().getRecord(index).get();
|
2017-03-06 23:25:04 +00:00
|
|
|
return new ESMTerrain::LandObject(&land, ESM::Land::DATA_VHGT | ESM::Land::DATA_VNML | ESM::Land::DATA_VCLR | ESM::Land::DATA_VTEX);
|
2014-10-08 15:17:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const ESM::LandTexture* TerrainStorage::getLandTexture(int index, short plugin)
|
|
|
|
{
|
2017-09-04 19:13:45 +00:00
|
|
|
int row = mData.getLandTextures().searchId(CSMWorld::LandTexture::createUniqueRecordId(plugin, index));
|
|
|
|
if (row == -1)
|
|
|
|
return nullptr;
|
2015-08-22 11:10:54 +00:00
|
|
|
|
2017-09-04 19:13:45 +00:00
|
|
|
return &mData.getLandTextures().getRecord(row).get();
|
2014-10-08 15:17:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void TerrainStorage::getBounds(float &minX, float &maxX, float &minY, float &maxY)
|
|
|
|
{
|
|
|
|
// not needed at the moment - this returns the bounds of the whole world, but we only edit individual cells
|
|
|
|
throw std::runtime_error("getBounds not implemented");
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|