|
|
|
@ -683,10 +683,8 @@ namespace MWWorld
|
|
|
|
|
void Scene::changeToInteriorCell (const std::string& cellName, const ESM::Position& position, bool adjustPlayerPos, bool changeEvent)
|
|
|
|
|
{
|
|
|
|
|
CellStore *cell = MWBase::Environment::get().getWorld()->getInterior(cellName);
|
|
|
|
|
bool loadcell = (mCurrentCell == nullptr);
|
|
|
|
|
if(!loadcell)
|
|
|
|
|
loadcell = *mCurrentCell != *cell;
|
|
|
|
|
|
|
|
|
|
bool useFading = (mCurrentCell != nullptr);
|
|
|
|
|
if (useFading)
|
|
|
|
|
MWBase::Environment::get().getWindowManager()->fadeScreenOut(0.5);
|
|
|
|
|
|
|
|
|
|
Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
|
|
|
@ -695,7 +693,7 @@ namespace MWWorld
|
|
|
|
|
loadingListener->setLabel(loadingInteriorText, false, messagesCount > 0);
|
|
|
|
|
Loading::ScopedLoad load(loadingListener);
|
|
|
|
|
|
|
|
|
|
if(!loadcell)
|
|
|
|
|
if(mCurrentCell != nullptr && *mCurrentCell == *cell)
|
|
|
|
|
{
|
|
|
|
|
MWBase::World *world = MWBase::Environment::get().getWorld();
|
|
|
|
|
world->moveObject(world->getPlayerPtr(), position.pos[0], position.pos[1], position.pos[2]);
|
|
|
|
@ -734,6 +732,7 @@ namespace MWWorld
|
|
|
|
|
if (changeEvent)
|
|
|
|
|
mCellChanged = true;
|
|
|
|
|
|
|
|
|
|
if (useFading)
|
|
|
|
|
MWBase::Environment::get().getWindowManager()->fadeScreenIn(0.5);
|
|
|
|
|
|
|
|
|
|
MWBase::Environment::get().getWindowManager()->changeCell(mCurrentCell);
|
|
|
|
|