2010-07-09 19:21:04 +00:00
|
|
|
#include <MyGUI.h>
|
|
|
|
#include <MyGUI_OgrePlatform.h>
|
|
|
|
#include <assert.h>
|
|
|
|
|
|
|
|
#include "manager.hpp"
|
|
|
|
|
2010-07-10 11:41:43 +00:00
|
|
|
using namespace OEngine::GUI;
|
2010-07-09 19:21:04 +00:00
|
|
|
|
2011-01-04 00:03:05 +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
|
|
|
{
|
|
|
|
assert(wnd);
|
|
|
|
assert(mgr);
|
|
|
|
|
|
|
|
using namespace MyGUI;
|
|
|
|
|
|
|
|
// 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-03-20 19:24:36 +00:00
|
|
|
/// \todo - can't avoid this with MyGUI 3.2?
|
2010-07-09 19:21:04 +00:00
|
|
|
|
2011-01-04 00:03:05 +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
|
|
|
// Set up OGRE platform. We might make this more generic later.
|
|
|
|
mPlatform = new OgrePlatform();
|
2011-01-04 00:03:05 +00:00
|
|
|
mPlatform->initialise(wnd, mgr, "General", theLogFile);
|
2010-07-09 19:21:04 +00:00
|
|
|
|
2012-03-20 19:24:36 +00:00
|
|
|
LogManager::getInstance().setSTDOutputEnabled(logging);
|
|
|
|
|
2010-07-09 19:21:04 +00:00
|
|
|
// Create GUI
|
|
|
|
mGui = new Gui();
|
2011-01-04 00:03:05 +00:00
|
|
|
mGui->initialise("core.xml", theLogFile);
|
2010-07-09 19:21:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void MyGUIManager::shutdown()
|
|
|
|
{
|
|
|
|
if(mGui) delete mGui;
|
|
|
|
if(mPlatform)
|
|
|
|
{
|
|
|
|
mPlatform->shutdown();
|
|
|
|
delete mPlatform;
|
|
|
|
}
|
|
|
|
mGui = NULL;
|
|
|
|
mPlatform = NULL;
|
|
|
|
}
|