|
|
@ -34,7 +34,7 @@ namespace MWRender
|
|
|
|
return land != nullptr;
|
|
|
|
return land != nullptr;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void TerrainStorage::getBounds(float& minX, float& maxX, float& minY, float& maxY)
|
|
|
|
void TerrainStorage::getBounds(float& minX, float& maxX, float& minY, float& maxY, ESM::RefId worldspace)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
minX = 0;
|
|
|
|
minX = 0;
|
|
|
|
minY = 0;
|
|
|
|
minY = 0;
|
|
|
@ -43,19 +43,41 @@ namespace MWRender
|
|
|
|
|
|
|
|
|
|
|
|
const MWWorld::ESMStore& esmStore = *MWBase::Environment::get().getESMStore();
|
|
|
|
const MWWorld::ESMStore& esmStore = *MWBase::Environment::get().getESMStore();
|
|
|
|
|
|
|
|
|
|
|
|
MWWorld::Store<ESM::Land>::iterator it = esmStore.get<ESM::Land>().begin();
|
|
|
|
if (ESM::isEsm4Ext(worldspace))
|
|
|
|
for (; it != esmStore.get<ESM::Land>().end(); ++it)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (it->mX < minX)
|
|
|
|
const auto& lands = esmStore.get<ESM4::Land>().getLands();
|
|
|
|
minX = static_cast<float>(it->mX);
|
|
|
|
for (const auto& it : lands)
|
|
|
|
if (it->mX > maxX)
|
|
|
|
{
|
|
|
|
maxX = static_cast<float>(it->mX);
|
|
|
|
if (it.first.mWorldspace == worldspace)
|
|
|
|
if (it->mY < minY)
|
|
|
|
{
|
|
|
|
minY = static_cast<float>(it->mY);
|
|
|
|
int x = it.first.mX;
|
|
|
|
if (it->mY > maxY)
|
|
|
|
int y = it.first.mY;
|
|
|
|
maxY = static_cast<float>(it->mY);
|
|
|
|
if (x < minX)
|
|
|
|
|
|
|
|
minX = static_cast<float>(x);
|
|
|
|
|
|
|
|
if (x > maxX)
|
|
|
|
|
|
|
|
maxX = static_cast<float>(x);
|
|
|
|
|
|
|
|
if (y < minY)
|
|
|
|
|
|
|
|
minY = static_cast<float>(y);
|
|
|
|
|
|
|
|
if (y > maxY)
|
|
|
|
|
|
|
|
maxY = static_cast<float>(y);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
MWWorld::Store<ESM::Land>::iterator it = esmStore.get<ESM::Land>().begin();
|
|
|
|
|
|
|
|
for (; it != esmStore.get<ESM::Land>().end(); ++it)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (it->mX < minX)
|
|
|
|
|
|
|
|
minX = static_cast<float>(it->mX);
|
|
|
|
|
|
|
|
if (it->mX > maxX)
|
|
|
|
|
|
|
|
maxX = static_cast<float>(it->mX);
|
|
|
|
|
|
|
|
if (it->mY < minY)
|
|
|
|
|
|
|
|
minY = static_cast<float>(it->mY);
|
|
|
|
|
|
|
|
if (it->mY > maxY)
|
|
|
|
|
|
|
|
maxY = static_cast<float>(it->mY);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// since grid coords are at cell origin, we need to add 1 cell
|
|
|
|
// since grid coords are at cell origin, we need to add 1 cell
|
|
|
|
maxX += 1;
|
|
|
|
maxX += 1;
|
|
|
|
maxY += 1;
|
|
|
|
maxY += 1;
|
|
|
|