From 5198de53b86b83bcaf4a288d9cab6d9980992dbc Mon Sep 17 00:00:00 2001 From: Sebastian Wick Date: Thu, 16 Jun 2011 15:16:35 +0200 Subject: [PATCH 1/3] add the new header to the cmake script --- apps/openmw/CMakeLists.txt | 1 + 1 file changed, 1 insertion(+) diff --git a/apps/openmw/CMakeLists.txt b/apps/openmw/CMakeLists.txt index bb62c0044..492c3869b 100644 --- a/apps/openmw/CMakeLists.txt +++ b/apps/openmw/CMakeLists.txt @@ -50,6 +50,7 @@ set(GAMEGUI_HEADER mwgui/dialogue_history.hpp mwgui/window_base.hpp mwgui/stats_window.hpp + mwgui/messagebox.hpp ) set(GAMEGUI mwgui/window_manager.cpp From 315f4078c625b506bb118a882f22d9872fab19ec Mon Sep 17 00:00:00 2001 From: Sebastian Wick Date: Thu, 16 Jun 2011 17:11:50 +0200 Subject: [PATCH 2/3] make them behave like the MessageBox in the original game --- apps/openmw/mwgui/messagebox.cpp | 48 +++++++++++++++++++++++--------- apps/openmw/mwgui/messagebox.hpp | 2 ++ 2 files changed, 37 insertions(+), 13 deletions(-) diff --git a/apps/openmw/mwgui/messagebox.cpp b/apps/openmw/mwgui/messagebox.cpp index 76b35eab3..d9117a896 100644 --- a/apps/openmw/mwgui/messagebox.cpp +++ b/apps/openmw/mwgui/messagebox.cpp @@ -17,7 +17,28 @@ void MessageBoxManager::onFrame (float frameDuration) it->current += frameDuration; if(it->current >= it->max) { - removeMessageBox(it->messageBox); + it->messageBox->mMarkedToDelete = true; + + if(*mMessageBoxes.begin() == it->messageBox) // if this box is the last one + { + // collect all with mMarkedToDelete and delete them. + // and place the other messageboxes on the right position + int height = 0; + std::vector::iterator it2 = mMessageBoxes.begin(); + while(it2 != mMessageBoxes.end()) + { + if((*it2)->mMarkedToDelete) + { + delete (*it2); + it2 = mMessageBoxes.erase(it2); + } + else { + (*it2)->update(height); + height += (*it2)->getHeight(); + it2++; + } + } + } it = mTimers.erase(it); } else @@ -35,22 +56,24 @@ void MessageBoxManager::createMessageBox (const std::string& message) removeMessageBox(message.length()*mMessageBoxSpeed, box); - mMessageBoxes.insert(mMessageBoxes.begin(), box); - int height = box->getHeight(); + mMessageBoxes.push_back(box); std::vector::iterator it; - int i = 0; - for(it = mMessageBoxes.begin()+1; it != mMessageBoxes.end(); ++it) + if(mMessageBoxes.size() > 3) { + delete *mMessageBoxes.begin(); + mMessageBoxes.erase(mMessageBoxes.begin()); + } + + int height = 0; + for(it = mMessageBoxes.begin(); it != mMessageBoxes.end(); ++it) { - if(i == 2) { - delete (*it); - mMessageBoxes.erase(it); - break; + if((*it) == box) + { + std::cout << "update(" << height << ")" << std::endl; + box->update(height); } else { - (*it)->update(height); height += (*it)->getHeight(); - i++; } } } @@ -112,6 +135,7 @@ MessageBox::MessageBox(MessageBoxManager& parMessageBoxManager, const std::strin mFixedWidth = 300; mBottomPadding = 20; mNextBoxPadding = 20; + mMarkedToDelete = false; getWidget(mMessageWidget, "message"); @@ -134,8 +158,6 @@ MessageBox::MessageBox(MessageBoxManager& parMessageBoxManager, const std::strin mMainWidget->setSize(size); size.width -= 5; // this is to center the text (see messagebox_layout.xml, Widget type="Edit" position="-2 -3 0 0") mMessageWidget->setSize(size); - - update(0); } void MessageBox::update (int height) diff --git a/apps/openmw/mwgui/messagebox.hpp b/apps/openmw/mwgui/messagebox.hpp index 37c4db77a..fe58a31c8 100644 --- a/apps/openmw/mwgui/messagebox.hpp +++ b/apps/openmw/mwgui/messagebox.hpp @@ -48,6 +48,8 @@ namespace MWGui int getHeight (); void update (int height); + bool mMarkedToDelete; + protected: MessageBoxManager& mMessageBoxManager; int mHeight; From d74f834735ab44319fd1e51c53b8c11540ce2d1e Mon Sep 17 00:00:00 2001 From: Sebastian Wick Date: Thu, 16 Jun 2011 18:12:50 +0200 Subject: [PATCH 3/3] make to boxes apear on the correct place even if the oldest is erased --- apps/openmw/mwgui/messagebox.cpp | 12 +++--------- .../openmw_resources/openmw_messagebox_layout.xml | 2 +- 2 files changed, 4 insertions(+), 10 deletions(-) diff --git a/apps/openmw/mwgui/messagebox.cpp b/apps/openmw/mwgui/messagebox.cpp index d9117a896..28aae874f 100644 --- a/apps/openmw/mwgui/messagebox.cpp +++ b/apps/openmw/mwgui/messagebox.cpp @@ -67,14 +67,8 @@ void MessageBoxManager::createMessageBox (const std::string& message) int height = 0; for(it = mMessageBoxes.begin(); it != mMessageBoxes.end(); ++it) { - if((*it) == box) - { - std::cout << "update(" << height << ")" << std::endl; - box->update(height); - } - else { - height += (*it)->getHeight(); - } + (*it)->update(height); + height += (*it)->getHeight(); } } @@ -156,7 +150,7 @@ MessageBox::MessageBox(MessageBoxManager& parMessageBoxManager, const std::strin size.height = mHeight = textSize.height + 20; // this is the padding between the text and the box mMainWidget->setSize(size); - size.width -= 5; // this is to center the text (see messagebox_layout.xml, Widget type="Edit" position="-2 -3 0 0") + size.width -= 15; // this is to center the text (see messagebox_layout.xml, Widget type="Edit" position="-2 -3 0 0") mMessageWidget->setSize(size); } diff --git a/extern/mygui_3.0.1/openmw_resources/openmw_messagebox_layout.xml b/extern/mygui_3.0.1/openmw_resources/openmw_messagebox_layout.xml index aa1e00258..fb4235ff1 100644 --- a/extern/mygui_3.0.1/openmw_resources/openmw_messagebox_layout.xml +++ b/extern/mygui_3.0.1/openmw_resources/openmw_messagebox_layout.xml @@ -5,7 +5,7 @@ - +