openmw-tes3coop/libs/openengine/gui/manager.cpp

51 lines
1.3 KiB
C++
Raw Normal View History

2010-07-09 19:21:04 +00:00
#include <MyGUI.h>
#include <MyGUI_OgrePlatform.h>
#include <cassert>
2010-07-09 19:21:04 +00:00
#include "manager.hpp"
using namespace OEngine::GUI;
2010-07-09 19:21:04 +00:00
void MyGUIManager::setup(Ogre::RenderWindow *wnd, Ogre::SceneManager *mgr, bool logging, const std::string& logDir)
2010-07-09 19:21:04 +00:00
{
2012-09-11 14:37:54 +00:00
assert(wnd);
assert(mgr);
2010-07-09 19:21:04 +00:00
2012-09-11 14:37:54 +00:00
mSceneMgr = mgr;
2010-07-09 19:21:04 +00:00
2012-09-11 14:37:54 +00:00
using namespace MyGUI;
2010-07-09 19:21:04 +00:00
2012-09-11 14:37:54 +00:00
// Enable/disable MyGUI logging to stdout. (Logging to MyGUI.log is
// still enabled.) In order to do this we have to initialize the log
// manager before the main gui system itself, otherwise the main
// object will get the chance to spit out a few messages before we
// can able to disable it.
2012-09-11 14:37:54 +00:00
std::string theLogFile = std::string(MYGUI_PLATFORM_LOG_FILENAME);
if(!logDir.empty())
theLogFile.insert(0, logDir);
2010-07-09 19:21:04 +00:00
2012-09-11 14:37:54 +00:00
// Set up OGRE platform. We might make this more generic later.
mPlatform = new OgrePlatform();
LogManager::getInstance().setSTDOutputEnabled(logging);
mPlatform->initialise(wnd, mgr, "General", theLogFile);
2012-03-20 19:24:36 +00:00
2012-09-11 14:37:54 +00:00
// Create GUI
mGui = new Gui();
mGui->initialise("core.xml");
2010-07-09 19:21:04 +00:00
}
void MyGUIManager::shutdown()
{
2012-08-12 19:21:23 +00:00
mGui->shutdown ();
2012-09-11 14:37:54 +00:00
delete mGui;
if(mPlatform)
2010-07-09 19:21:04 +00:00
{
2012-09-11 14:37:54 +00:00
mPlatform->shutdown();
delete mPlatform;
2010-07-09 19:21:04 +00:00
}
2012-09-11 14:37:54 +00:00
mGui = NULL;
mPlatform = NULL;
2010-07-09 19:21:04 +00:00
}