2021-10-29 16:47:17 +04:00
|
|
|
#include "groundcoverstore.hpp"
|
|
|
|
|
|
|
|
#include <components/esmloader/load.hpp>
|
|
|
|
#include <components/misc/stringops.hpp>
|
2022-06-01 22:53:18 +02:00
|
|
|
#include <components/esm3/readerscache.hpp>
|
2021-10-29 16:47:17 +04:00
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
|
|
|
void GroundcoverStore::init(const Store<ESM::Static>& statics, const Files::Collections& fileCollections, const std::vector<std::string>& groundcoverFiles, ToUTF8::Utf8Encoder* encoder)
|
|
|
|
{
|
2022-05-13 12:35:58 +02:00
|
|
|
::EsmLoader::Query query;
|
2021-10-29 16:47:17 +04:00
|
|
|
query.mLoadStatics = true;
|
|
|
|
query.mLoadCells = true;
|
|
|
|
|
2022-06-01 22:53:18 +02:00
|
|
|
ESM::ReadersCache readers;
|
2022-05-13 12:35:58 +02:00
|
|
|
const ::EsmLoader::EsmData content = ::EsmLoader::loadEsmData(query, groundcoverFiles, fileCollections, readers, encoder);
|
2021-10-29 16:47:17 +04:00
|
|
|
|
|
|
|
for (const ESM::Static& stat : statics)
|
|
|
|
{
|
|
|
|
std::string id = Misc::StringUtils::lowerCase(stat.mId);
|
|
|
|
mMeshCache[id] = "meshes\\" + Misc::StringUtils::lowerCase(stat.mModel);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const ESM::Static& stat : content.mStatics)
|
|
|
|
{
|
|
|
|
std::string id = Misc::StringUtils::lowerCase(stat.mId);
|
|
|
|
mMeshCache[id] = "meshes\\" + Misc::StringUtils::lowerCase(stat.mModel);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const ESM::Cell& cell : content.mCells)
|
|
|
|
{
|
|
|
|
if (!cell.isExterior()) continue;
|
|
|
|
auto cellIndex = std::make_pair(cell.getCellId().mIndex.mX, cell.getCellId().mIndex.mY);
|
|
|
|
mCellContexts[cellIndex] = std::move(cell.mContextList);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string GroundcoverStore::getGroundcoverModel(const std::string& id) const
|
|
|
|
{
|
|
|
|
std::string idLower = Misc::StringUtils::lowerCase(id);
|
|
|
|
auto search = mMeshCache.find(idLower);
|
|
|
|
if (search == mMeshCache.end()) return std::string();
|
|
|
|
|
|
|
|
return search->second;
|
|
|
|
}
|
|
|
|
|
|
|
|
void GroundcoverStore::initCell(ESM::Cell& cell, int cellX, int cellY) const
|
|
|
|
{
|
|
|
|
cell.blank();
|
|
|
|
|
|
|
|
auto searchCell = mCellContexts.find(std::make_pair(cellX, cellY));
|
|
|
|
if (searchCell != mCellContexts.end())
|
|
|
|
cell.mContextList = searchCell->second;
|
|
|
|
}
|
|
|
|
}
|