2010-06-03 21:51:59 +02:00
|
|
|
#include "renderer.hpp"
|
2010-06-03 20:44:55 +02:00
|
|
|
|
2010-06-06 13:36:45 +02:00
|
|
|
#include "OgreRoot.h"
|
|
|
|
#include "OgreRenderWindow.h"
|
|
|
|
#include "OgreLogManager.h"
|
|
|
|
#include "OgreLog.h"
|
|
|
|
|
2010-06-03 20:44:55 +02:00
|
|
|
using namespace Ogre;
|
2010-06-03 21:51:59 +02:00
|
|
|
using namespace Render;
|
|
|
|
|
|
|
|
void OgreRenderer::cleanup()
|
|
|
|
{
|
|
|
|
if(mRoot)
|
|
|
|
delete mRoot;
|
|
|
|
mRoot = NULL;
|
|
|
|
}
|
2010-06-03 20:44:55 +02:00
|
|
|
|
2010-06-22 16:02:58 +02:00
|
|
|
void OgreRenderer::screenshot(const std::string &file)
|
|
|
|
{
|
|
|
|
mWindow->writeContentsToFile(file);
|
|
|
|
}
|
|
|
|
|
2010-06-03 20:44:55 +02:00
|
|
|
bool OgreRenderer::configure(bool showConfig,
|
|
|
|
const std::string &pluginCfg,
|
2010-06-03 21:51:59 +02:00
|
|
|
bool _logging)
|
2010-06-03 20:44:55 +02:00
|
|
|
{
|
|
|
|
// Set up logging first
|
|
|
|
new LogManager;
|
|
|
|
Log *log = LogManager::getSingleton().createLog("Ogre.log");
|
|
|
|
logging = _logging;
|
|
|
|
|
|
|
|
if(logging)
|
|
|
|
// Full log detail
|
|
|
|
log->setLogDetail(LL_BOREME);
|
|
|
|
else
|
|
|
|
// Disable logging
|
|
|
|
log->setDebugOutputEnabled(false);
|
|
|
|
|
2010-06-03 21:51:59 +02:00
|
|
|
mRoot = new Root(pluginCfg, "ogre.cfg", "");
|
2010-06-03 20:44:55 +02:00
|
|
|
|
|
|
|
// Show the configuration dialog and initialise the system, if the
|
|
|
|
// showConfig parameter is specified. The settings are stored in
|
|
|
|
// ogre.cfg. If showConfig is false, the settings are assumed to
|
|
|
|
// already exist in ogre.cfg.
|
|
|
|
int result;
|
|
|
|
if(showConfig)
|
|
|
|
result = mRoot->showConfigDialog();
|
|
|
|
else
|
|
|
|
result = mRoot->restoreConfig();
|
|
|
|
|
|
|
|
return !result;
|
|
|
|
}
|
2010-06-03 21:51:59 +02:00
|
|
|
|
|
|
|
void OgreRenderer::createWindow(const std::string &title)
|
|
|
|
{
|
|
|
|
// Initialize OGRE window
|
|
|
|
mWindow = mRoot->initialise(true, title, "");
|
|
|
|
}
|