mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 05:26:36 +00:00
Merge pull request #1993 from akortunov/loadingbar
Center progress bar when there are active messageboxes
This commit is contained in:
commit
3cd59d4a89
11 changed files with 37 additions and 8 deletions
|
@ -151,6 +151,7 @@
|
||||||
Bug #4684: Spell Absorption is additive
|
Bug #4684: Spell Absorption is additive
|
||||||
Bug #4685: Missing sound causes an exception inside Say command
|
Bug #4685: Missing sound causes an exception inside Say command
|
||||||
Bug #4689: Default creature soundgen entries are not used
|
Bug #4689: Default creature soundgen entries are not used
|
||||||
|
Bug #4691: Loading bar for cell should be moved up when text is still active at bottom of screen
|
||||||
Feature #912: Editor: Add missing icons to UniversalId tables
|
Feature #912: Editor: Add missing icons to UniversalId tables
|
||||||
Feature #1221: Editor: Creature/NPC rendering
|
Feature #1221: Editor: Creature/NPC rendering
|
||||||
Feature #1617: Editor: Enchantment effect record verifier
|
Feature #1617: Editor: Enchantment effect record verifier
|
||||||
|
|
|
@ -285,6 +285,8 @@ namespace MWBase
|
||||||
|
|
||||||
virtual void setEnemy (const MWWorld::Ptr& enemy) = 0;
|
virtual void setEnemy (const MWWorld::Ptr& enemy) = 0;
|
||||||
|
|
||||||
|
virtual int getMessagesCount() const = 0;
|
||||||
|
|
||||||
virtual const Translation::Storage& getTranslationDataStorage() const = 0;
|
virtual const Translation::Storage& getTranslationDataStorage() const = 0;
|
||||||
|
|
||||||
/// Warning: do not use MyGUI::InputManager::setKeyFocusWidget directly. Instead use this.
|
/// Warning: do not use MyGUI::InputManager::setKeyFocusWidget directly. Instead use this.
|
||||||
|
|
|
@ -96,7 +96,7 @@ namespace MWGui
|
||||||
Log(Debug::Warning) << "Warning: no splash screens found!";
|
Log(Debug::Warning) << "Warning: no splash screens found!";
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoadingScreen::setLabel(const std::string &label, bool important)
|
void LoadingScreen::setLabel(const std::string &label, bool important, bool center)
|
||||||
{
|
{
|
||||||
mImportantLabel = important;
|
mImportantLabel = important;
|
||||||
|
|
||||||
|
@ -105,7 +105,11 @@ namespace MWGui
|
||||||
MyGUI::IntSize size(mLoadingText->getTextSize().width+padding, mLoadingBox->getHeight());
|
MyGUI::IntSize size(mLoadingText->getTextSize().width+padding, mLoadingBox->getHeight());
|
||||||
size.width = std::max(300, size.width);
|
size.width = std::max(300, size.width);
|
||||||
mLoadingBox->setSize(size);
|
mLoadingBox->setSize(size);
|
||||||
mLoadingBox->setPosition(mMainWidget->getWidth()/2 - mLoadingBox->getWidth()/2, mLoadingBox->getTop());
|
|
||||||
|
if (center)
|
||||||
|
mLoadingBox->setPosition(mMainWidget->getWidth()/2 - mLoadingBox->getWidth()/2, mMainWidget->getHeight()/2 - mLoadingBox->getHeight()/2);
|
||||||
|
else
|
||||||
|
mLoadingBox->setPosition(mMainWidget->getWidth()/2 - mLoadingBox->getWidth()/2, mMainWidget->getHeight() - mLoadingBox->getHeight() - 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
void LoadingScreen::setVisible(bool visible)
|
void LoadingScreen::setVisible(bool visible)
|
||||||
|
|
|
@ -34,7 +34,7 @@ namespace MWGui
|
||||||
virtual ~LoadingScreen();
|
virtual ~LoadingScreen();
|
||||||
|
|
||||||
/// Overridden from Loading::Listener, see the Loading::Listener documentation for usage details
|
/// Overridden from Loading::Listener, see the Loading::Listener documentation for usage details
|
||||||
virtual void setLabel (const std::string& label, bool important);
|
virtual void setLabel (const std::string& label, bool important, bool center);
|
||||||
virtual void loadingOn(bool visible=true);
|
virtual void loadingOn(bool visible=true);
|
||||||
virtual void loadingOff();
|
virtual void loadingOff();
|
||||||
virtual void setProgressRange (size_t range);
|
virtual void setProgressRange (size_t range);
|
||||||
|
|
|
@ -35,6 +35,11 @@ namespace MWGui
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int MessageBoxManager::getMessagesCount()
|
||||||
|
{
|
||||||
|
return mMessageBoxes.size();
|
||||||
|
}
|
||||||
|
|
||||||
void MessageBoxManager::clear()
|
void MessageBoxManager::clear()
|
||||||
{
|
{
|
||||||
if (mInterMessageBoxe)
|
if (mInterMessageBoxe)
|
||||||
|
|
|
@ -28,6 +28,8 @@ namespace MWGui
|
||||||
bool createInteractiveMessageBox (const std::string& message, const std::vector<std::string>& buttons);
|
bool createInteractiveMessageBox (const std::string& message, const std::vector<std::string>& buttons);
|
||||||
bool isInteractiveMessageBox ();
|
bool isInteractiveMessageBox ();
|
||||||
|
|
||||||
|
int getMessagesCount();
|
||||||
|
|
||||||
const InteractiveMessageBox* getInteractiveMessageBox() const { return mInterMessageBoxe; }
|
const InteractiveMessageBox* getInteractiveMessageBox() const { return mInterMessageBoxe; }
|
||||||
|
|
||||||
/// Remove all message boxes
|
/// Remove all message boxes
|
||||||
|
|
|
@ -1670,6 +1670,15 @@ namespace MWGui
|
||||||
mHud->setEnemy(enemy);
|
mHud->setEnemy(enemy);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int WindowManager::getMessagesCount() const
|
||||||
|
{
|
||||||
|
int count = 0;
|
||||||
|
if (mMessageBoxManager)
|
||||||
|
count = mMessageBoxManager->getMessagesCount();
|
||||||
|
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
Loading::Listener* WindowManager::getLoadingScreen()
|
Loading::Listener* WindowManager::getLoadingScreen()
|
||||||
{
|
{
|
||||||
return mLoadingScreen;
|
return mLoadingScreen;
|
||||||
|
|
|
@ -316,6 +316,8 @@ namespace MWGui
|
||||||
|
|
||||||
virtual void setEnemy (const MWWorld::Ptr& enemy);
|
virtual void setEnemy (const MWWorld::Ptr& enemy);
|
||||||
|
|
||||||
|
virtual int getMessagesCount() const;
|
||||||
|
|
||||||
virtual const Translation::Storage& getTranslationDataStorage() const;
|
virtual const Translation::Storage& getTranslationDataStorage() const;
|
||||||
|
|
||||||
void onSoulgemDialogButtonPressed (int button);
|
void onSoulgemDialogButtonPressed (int button);
|
||||||
|
|
|
@ -265,9 +265,10 @@ void MWState::StateManager::saveGame (const std::string& description, const Slot
|
||||||
writer.save (stream);
|
writer.save (stream);
|
||||||
|
|
||||||
Loading::Listener& listener = *MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
Loading::Listener& listener = *MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
||||||
|
int messagesCount = MWBase::Environment::get().getWindowManager()->getMessagesCount();
|
||||||
// Using only Cells for progress information, since they typically have the largest records by far
|
// Using only Cells for progress information, since they typically have the largest records by far
|
||||||
listener.setProgressRange(MWBase::Environment::get().getWorld()->countSavedGameCells());
|
listener.setProgressRange(MWBase::Environment::get().getWorld()->countSavedGameCells());
|
||||||
listener.setLabel("#{sNotifyMessage4}", true);
|
listener.setLabel("#{sNotifyMessage4}", true, messagesCount > 0);
|
||||||
|
|
||||||
Loading::ScopedLoad load(&listener);
|
Loading::ScopedLoad load(&listener);
|
||||||
|
|
||||||
|
@ -389,9 +390,10 @@ void MWState::StateManager::loadGame (const Character *character, const std::str
|
||||||
std::map<int, int> contentFileMap = buildContentFileIndexMap (reader);
|
std::map<int, int> contentFileMap = buildContentFileIndexMap (reader);
|
||||||
|
|
||||||
Loading::Listener& listener = *MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
Loading::Listener& listener = *MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
||||||
|
int messagesCount = MWBase::Environment::get().getWindowManager()->getMessagesCount();
|
||||||
|
|
||||||
listener.setProgressRange(100);
|
listener.setProgressRange(100);
|
||||||
listener.setLabel("#{sLoadingMessage14}");
|
listener.setLabel("#{sLoadingMessage14}", false, messagesCount > 0);
|
||||||
|
|
||||||
Loading::ScopedLoad load(&listener);
|
Loading::ScopedLoad load(&listener);
|
||||||
|
|
||||||
|
|
|
@ -360,8 +360,9 @@ namespace MWWorld
|
||||||
Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
||||||
Loading::ScopedLoad load(loadingListener);
|
Loading::ScopedLoad load(loadingListener);
|
||||||
|
|
||||||
|
int messagesCount = MWBase::Environment::get().getWindowManager()->getMessagesCount();
|
||||||
std::string loadingExteriorText = "#{sLoadingMessage3}";
|
std::string loadingExteriorText = "#{sLoadingMessage3}";
|
||||||
loadingListener->setLabel(loadingExteriorText);
|
loadingListener->setLabel(loadingExteriorText, false, messagesCount > 0);
|
||||||
|
|
||||||
CellStoreCollection::iterator active = mActiveCells.begin();
|
CellStoreCollection::iterator active = mActiveCells.begin();
|
||||||
while (active!=mActiveCells.end())
|
while (active!=mActiveCells.end())
|
||||||
|
@ -526,8 +527,9 @@ namespace MWWorld
|
||||||
MWBase::Environment::get().getWindowManager()->fadeScreenOut(0.5);
|
MWBase::Environment::get().getWindowManager()->fadeScreenOut(0.5);
|
||||||
|
|
||||||
Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
Loading::Listener* loadingListener = MWBase::Environment::get().getWindowManager()->getLoadingScreen();
|
||||||
|
int messagesCount = MWBase::Environment::get().getWindowManager()->getMessagesCount();
|
||||||
std::string loadingInteriorText = "#{sLoadingMessage2}";
|
std::string loadingInteriorText = "#{sLoadingMessage2}";
|
||||||
loadingListener->setLabel(loadingInteriorText);
|
loadingListener->setLabel(loadingInteriorText, false, messagesCount > 0);
|
||||||
Loading::ScopedLoad load(loadingListener);
|
Loading::ScopedLoad load(loadingListener);
|
||||||
|
|
||||||
if(!loadcell)
|
if(!loadcell)
|
||||||
|
|
|
@ -14,7 +14,7 @@ namespace Loading
|
||||||
/// @note "non-important" labels may not show on screen if the loading process went so fast
|
/// @note "non-important" labels may not show on screen if the loading process went so fast
|
||||||
/// that the implementation decided not to show a loading screen at all. "important" labels
|
/// that the implementation decided not to show a loading screen at all. "important" labels
|
||||||
/// will show in a separate message-box if the loading screen was not shown.
|
/// will show in a separate message-box if the loading screen was not shown.
|
||||||
virtual void setLabel (const std::string& label, bool important=false) {}
|
virtual void setLabel (const std::string& label, bool important=false, bool center=false) {}
|
||||||
|
|
||||||
/// Start a loading sequence. Must call loadingOff() when done.
|
/// Start a loading sequence. Must call loadingOff() when done.
|
||||||
/// @note To get the loading screen to actually update, you must call setProgress / increaseProgress periodically.
|
/// @note To get the loading screen to actually update, you must call setProgress / increaseProgress periodically.
|
||||||
|
|
Loading…
Reference in a new issue