2013-08-16 11:01:52 +00:00
|
|
|
#include "terrainstorage.hpp"
|
|
|
|
|
2014-02-13 09:13:53 +00:00
|
|
|
#include <boost/algorithm/string.hpp>
|
|
|
|
|
2013-08-16 11:01:52 +00:00
|
|
|
#include "../mwbase/world.hpp"
|
|
|
|
#include "../mwbase/environment.hpp"
|
|
|
|
#include "../mwworld/esmstore.hpp"
|
|
|
|
|
|
|
|
namespace MWRender
|
|
|
|
{
|
|
|
|
|
2015-06-02 23:18:36 +00:00
|
|
|
TerrainStorage::TerrainStorage(const VFS::Manager* vfs, bool preload)
|
|
|
|
: ESMTerrain::Storage(vfs)
|
2015-01-29 02:30:07 +00:00
|
|
|
{
|
|
|
|
if (preload)
|
|
|
|
{
|
|
|
|
const MWWorld::ESMStore &esmStore =
|
|
|
|
MWBase::Environment::get().getWorld()->getStore();
|
|
|
|
|
|
|
|
MWWorld::Store<ESM::Land>::iterator it = esmStore.get<ESM::Land>().begin();
|
|
|
|
for (; it != esmStore.get<ESM::Land>().end(); ++it)
|
|
|
|
{
|
2015-12-17 22:33:31 +00:00
|
|
|
const ESM::Land* land = &*it;
|
2015-01-29 02:30:07 +00:00
|
|
|
land->loadData(ESM::Land::DATA_VCLR|ESM::Land::DATA_VHGT|ESM::Land::DATA_VNML|ESM::Land::DATA_VTEX);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-16 12:07:32 +00:00
|
|
|
void TerrainStorage::getBounds(float& minX, float& maxX, float& minY, float& maxY)
|
2013-08-16 11:01:52 +00:00
|
|
|
{
|
2014-02-16 12:07:32 +00:00
|
|
|
minX = 0, minY = 0, maxX = 0, maxY = 0;
|
2013-08-16 11:01:52 +00:00
|
|
|
|
|
|
|
const MWWorld::ESMStore &esmStore =
|
|
|
|
MWBase::Environment::get().getWorld()->getStore();
|
|
|
|
|
|
|
|
MWWorld::Store<ESM::Cell>::iterator it = esmStore.get<ESM::Cell>().extBegin();
|
|
|
|
for (; it != esmStore.get<ESM::Cell>().extEnd(); ++it)
|
|
|
|
{
|
|
|
|
if (it->getGridX() < minX)
|
2015-03-08 00:07:29 +00:00
|
|
|
minX = static_cast<float>(it->getGridX());
|
2013-08-16 11:01:52 +00:00
|
|
|
if (it->getGridX() > maxX)
|
2015-03-08 00:07:29 +00:00
|
|
|
maxX = static_cast<float>(it->getGridX());
|
2013-08-16 11:01:52 +00:00
|
|
|
if (it->getGridY() < minY)
|
2015-03-08 00:07:29 +00:00
|
|
|
minY = static_cast<float>(it->getGridY());
|
2013-08-16 11:01:52 +00:00
|
|
|
if (it->getGridY() > maxY)
|
2015-03-08 00:07:29 +00:00
|
|
|
maxY = static_cast<float>(it->getGridY());
|
2013-08-16 11:01:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// since grid coords are at cell origin, we need to add 1 cell
|
|
|
|
maxX += 1;
|
|
|
|
maxY += 1;
|
|
|
|
}
|
|
|
|
|
2015-08-31 12:17:11 +00:00
|
|
|
const ESM::Land* TerrainStorage::getLand(int cellX, int cellY)
|
2013-08-16 11:01:52 +00:00
|
|
|
{
|
|
|
|
const MWWorld::ESMStore &esmStore =
|
|
|
|
MWBase::Environment::get().getWorld()->getStore();
|
|
|
|
ESM::Land* land = esmStore.get<ESM::Land>().search(cellX, cellY);
|
2015-01-29 02:30:07 +00:00
|
|
|
if (!land)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
const int flags = ESM::Land::DATA_VCLR|ESM::Land::DATA_VHGT|ESM::Land::DATA_VNML|ESM::Land::DATA_VTEX;
|
|
|
|
if (!land->isDataLoaded(flags))
|
|
|
|
land->loadData(flags);
|
2016-02-09 19:14:16 +00:00
|
|
|
|
|
|
|
// TODO: unload land data when it's no longer needed
|
|
|
|
|
2013-08-16 11:01:52 +00:00
|
|
|
return land;
|
|
|
|
}
|
|
|
|
|
|
|
|
const ESM::LandTexture* TerrainStorage::getLandTexture(int index, short plugin)
|
|
|
|
{
|
|
|
|
const MWWorld::ESMStore &esmStore =
|
|
|
|
MWBase::Environment::get().getWorld()->getStore();
|
2015-11-27 20:45:37 +00:00
|
|
|
return esmStore.get<ESM::LandTexture>().search(index, plugin);
|
2013-08-16 11:01:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|