|
|
@ -204,12 +204,11 @@ namespace
|
|
|
|
struct InsertVisitor
|
|
|
|
struct InsertVisitor
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::CellStore& mCell;
|
|
|
|
MWWorld::CellStore& mCell;
|
|
|
|
bool mRescale;
|
|
|
|
|
|
|
|
Loading::Listener& mLoadingListener;
|
|
|
|
Loading::Listener& mLoadingListener;
|
|
|
|
|
|
|
|
|
|
|
|
std::vector<MWWorld::Ptr> mToInsert;
|
|
|
|
std::vector<MWWorld::Ptr> mToInsert;
|
|
|
|
|
|
|
|
|
|
|
|
InsertVisitor (MWWorld::CellStore& cell, bool rescale, Loading::Listener& loadingListener);
|
|
|
|
InsertVisitor (MWWorld::CellStore& cell, Loading::Listener& loadingListener);
|
|
|
|
|
|
|
|
|
|
|
|
bool operator() (const MWWorld::Ptr& ptr);
|
|
|
|
bool operator() (const MWWorld::Ptr& ptr);
|
|
|
|
|
|
|
|
|
|
|
@ -217,8 +216,8 @@ namespace
|
|
|
|
void insert(AddObject&& addObject);
|
|
|
|
void insert(AddObject&& addObject);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
InsertVisitor::InsertVisitor (MWWorld::CellStore& cell, bool rescale, Loading::Listener& loadingListener)
|
|
|
|
InsertVisitor::InsertVisitor (MWWorld::CellStore& cell, Loading::Listener& loadingListener)
|
|
|
|
: mCell (cell), mRescale (rescale), mLoadingListener (loadingListener)
|
|
|
|
: mCell (cell), mLoadingListener (loadingListener)
|
|
|
|
{}
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
|
bool InsertVisitor::operator() (const MWWorld::Ptr& ptr)
|
|
|
|
bool InsertVisitor::operator() (const MWWorld::Ptr& ptr)
|
|
|
@ -234,14 +233,6 @@ namespace
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for (MWWorld::Ptr& ptr : mToInsert)
|
|
|
|
for (MWWorld::Ptr& ptr : mToInsert)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (mRescale)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (ptr.getCellRef().getScale()<0.5)
|
|
|
|
|
|
|
|
ptr.getCellRef().setScale(0.5);
|
|
|
|
|
|
|
|
else if (ptr.getCellRef().getScale()>2)
|
|
|
|
|
|
|
|
ptr.getCellRef().setScale(2);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!ptr.getRefData().isDeleted() && ptr.getRefData().isEnabled())
|
|
|
|
if (!ptr.getRefData().isDeleted() && ptr.getRefData().isEnabled())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
try
|
|
|
|
try
|
|
|
@ -427,8 +418,7 @@ namespace MWWorld
|
|
|
|
cell->respawn();
|
|
|
|
cell->respawn();
|
|
|
|
|
|
|
|
|
|
|
|
// ... then references. This is important for adjustPosition to work correctly.
|
|
|
|
// ... then references. This is important for adjustPosition to work correctly.
|
|
|
|
/// \todo rescale depending on the state of a new GMST
|
|
|
|
insertCell (*cell, loadingListener);
|
|
|
|
insertCell (*cell, true, loadingListener);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mRendering.addCell(cell);
|
|
|
|
mRendering.addCell(cell);
|
|
|
|
MWBase::Environment::get().getWindowManager()->addCell(cell);
|
|
|
|
MWBase::Environment::get().getWindowManager()->addCell(cell);
|
|
|
@ -769,9 +759,9 @@ namespace MWWorld
|
|
|
|
mCellChanged = false;
|
|
|
|
mCellChanged = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Scene::insertCell (CellStore &cell, bool rescale, Loading::Listener* loadingListener)
|
|
|
|
void Scene::insertCell (CellStore &cell, Loading::Listener* loadingListener)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
InsertVisitor insertVisitor (cell, rescale, *loadingListener);
|
|
|
|
InsertVisitor insertVisitor (cell, *loadingListener);
|
|
|
|
cell.forEach (insertVisitor);
|
|
|
|
cell.forEach (insertVisitor);
|
|
|
|
insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mRendering); });
|
|
|
|
insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mRendering); });
|
|
|
|
insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mNavigator); });
|
|
|
|
insertVisitor.insert([&] (const MWWorld::Ptr& ptr) { addObject(ptr, *mPhysics, mNavigator); });
|
|
|
|