1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-21 08:53:52 +00:00

Merge branch 'camera_stats' into 'master'

Collect all available stats if OPENMW_OSG_STATS_FILE is set and point to a valid file.

See merge request OpenMW/openmw!526
This commit is contained in:
psi29a 2021-01-27 08:04:33 +00:00
commit 699bd257ef
4 changed files with 135 additions and 15 deletions

View file

@ -177,6 +177,8 @@ namespace
~ScopedProfile()
{
if (!mStats.collectStats("engine"))
return;
const osg::Timer_t end = mTimer.tick();
const UserStats& stats = UserStatsValue<sType>::sValue;
@ -863,16 +865,29 @@ void OMW::Engine::go()
prepareEngine (settings);
std::ofstream stats;
if (const auto path = std::getenv("OPENMW_OSG_STATS_FILE"))
{
stats.open(path, std::ios_base::out);
if (stats.is_open())
Log(Debug::Info) << "Stats will be written to: " << path;
else
Log(Debug::Warning) << "Failed to open file for stats: " << path;
}
// Setup profiler
osg::ref_ptr<Resource::Profiler> statshandler = new Resource::Profiler;
osg::ref_ptr<Resource::Profiler> statshandler = new Resource::Profiler(stats.is_open());
initStatsHandler(*statshandler);
mViewer->addEventHandler(statshandler);
osg::ref_ptr<Resource::StatsHandler> resourceshandler = new Resource::StatsHandler;
osg::ref_ptr<Resource::StatsHandler> resourceshandler = new Resource::StatsHandler(stats.is_open());
mViewer->addEventHandler(resourceshandler);
if (stats.is_open())
Resource::CollectStatistics(mViewer);
// Start the game
if (!mSaveGameFile.empty())
{
@ -897,14 +912,6 @@ void OMW::Engine::go()
mEnvironment.getWindowManager()->executeInConsole(mStartupScript);
}
std::ofstream stats;
if (const auto path = std::getenv("OPENMW_OSG_STATS_FILE"))
{
stats.open(path, std::ios_base::out);
if (!stats)
Log(Debug::Warning) << "Failed to open file for stats: " << path;
}
// Start the main rendering loop
osg::Timer frameTimer;
double simulationTime = 0.0;

View file

@ -540,6 +540,8 @@ namespace MWPhysics
void PhysicsTaskScheduler::updateStats(osg::Timer_t frameStart, unsigned int frameNumber, osg::Stats& stats)
{
if (!stats.collectStats("engine"))
return;
if (mFrameNumber == frameNumber - 1)
{
stats.setAttribute(mFrameNumber, "physicsworker_time_begin", mTimer->delta_s(mFrameStart, mTimeBegin));

View file

@ -18,10 +18,72 @@
namespace Resource
{
StatsHandler::StatsHandler():
static bool collectStatRendering = false;
static bool collectStatCameraObjects = false;
static bool collectStatViewerObjects = false;
static bool collectStatResource = false;
static bool collectStatGPU = false;
static bool collectStatEvent = false;
static bool collectStatFrameRate = false;
static bool collectStatUpdate = false;
static bool collectStatEngine = false;
static void setupStatCollection()
{
const char* envList = getenv("OPENMW_OSG_STATS_LIST");
if (envList == nullptr)
return;
std::string_view kwList(envList);
auto kwBegin = kwList.begin();
while (kwBegin != kwList.end())
{
auto kwEnd = std::find(kwBegin, kwList.end(), ';');
const auto kw = kwList.substr(std::distance(kwList.begin(), kwBegin), std::distance(kwBegin, kwEnd));
if (kw.compare("gpu") == 0)
collectStatGPU = true;
else if (kw.compare("event") == 0)
collectStatEvent = true;
else if (kw.compare("frame_rate") == 0)
collectStatFrameRate = true;
else if (kw.compare("update") == 0)
collectStatUpdate = true;
else if (kw.compare("engine") == 0)
collectStatEngine = true;
else if (kw.compare("rendering") == 0)
collectStatRendering = true;
else if (kw.compare("cameraobjects") == 0)
collectStatCameraObjects = true;
else if (kw.compare("viewerobjects") == 0)
collectStatViewerObjects = true;
else if (kw.compare("resource") == 0)
collectStatResource = true;
else if (kw.compare("times") == 0)
{
collectStatGPU = true;
collectStatEvent = true;
collectStatFrameRate = true;
collectStatUpdate = true;
collectStatEngine = true;
collectStatRendering = true;
}
if (kwEnd == kwList.end())
break;
kwBegin = std::next(kwEnd);
}
}
StatsHandler::StatsHandler(bool offlineCollect):
_key(osgGA::GUIEventAdapter::KEY_F4),
_initialized(false),
_statsType(false),
_offlineCollect(offlineCollect),
_statsWidth(1280.0f),
_statsHeight(1024.0f),
_font(""),
@ -38,7 +100,8 @@ StatsHandler::StatsHandler():
_font = osgMyGUI::DataManager::getInstance().getDataPath("DejaVuLGCSansMono.ttf");
}
Profiler::Profiler()
Profiler::Profiler(bool offlineCollect):
_offlineCollect(offlineCollect)
{
if (osgDB::Registry::instance()->getReaderWriterForExtension("ttf"))
_font = osgMyGUI::DataManager::getInstance().getDataPath("DejaVuLGCSansMono.ttf");
@ -48,6 +111,28 @@ Profiler::Profiler()
_characterSize = 18;
setKeyEventTogglesOnScreenStats(osgGA::GUIEventAdapter::KEY_F3);
setupStatCollection();
}
bool Profiler::handle(const osgGA::GUIEventAdapter &ea, osgGA::GUIActionAdapter &aa)
{
osgViewer::ViewerBase* viewer = nullptr;
bool handled = StatsHandler::handle(ea, aa);
auto* view = dynamic_cast<osgViewer::View*>(&aa);
if (view)
viewer = view->getViewerBase();
if (viewer)
{
// Add/remove openmw stats to the osd as necessary
viewer->getViewerStats()->collectStats("engine", _statsType == StatsHandler::StatsType::VIEWER_STATS);
if (_offlineCollect)
CollectStatistics(viewer);
}
return handled;
}
bool StatsHandler::handle(const osgGA::GUIEventAdapter &ea, osgGA::GUIActionAdapter &aa)
@ -67,6 +152,9 @@ bool StatsHandler::handle(const osgGA::GUIEventAdapter &ea, osgGA::GUIActionAdap
toggle(viewer);
if (_offlineCollect)
CollectStatistics(viewer);
aa.requestRedraw();
return true;
}
@ -370,6 +458,22 @@ void StatsHandler::getUsage(osg::ApplicationUsage &usage) const
usage.addKeyboardMouseBinding(_key, "On screen resource usage stats.");
}
void CollectStatistics(osgViewer::ViewerBase* viewer)
{
osgViewer::Viewer::Cameras cameras;
viewer->getCameras(cameras);
for (auto* camera : cameras)
{
if (collectStatGPU) camera->getStats()->collectStats("gpu", true);
if (collectStatRendering) camera->getStats()->collectStats("rendering", true);
if (collectStatCameraObjects) camera->getStats()->collectStats("scene", true);
}
if (collectStatEvent) viewer->getViewerStats()->collectStats("event", true);
if (collectStatFrameRate) viewer->getViewerStats()->collectStats("frame_rate", true);
if (collectStatUpdate) viewer->getViewerStats()->collectStats("update", true);
if (collectStatResource) viewer->getViewerStats()->collectStats("resource", true);
if (collectStatViewerObjects) viewer->getViewerStats()->collectStats("scene", true);
if (collectStatEngine) viewer->getViewerStats()->collectStats("engine", true);
}
}

View file

@ -18,13 +18,17 @@ namespace Resource
class Profiler : public osgViewer::StatsHandler
{
public:
Profiler();
Profiler(bool offlineCollect);
bool handle(const osgGA::GUIEventAdapter& ea, osgGA::GUIActionAdapter& aa) override;
private:
bool _offlineCollect;
};
class StatsHandler : public osgGA::GUIEventHandler
{
public:
StatsHandler();
StatsHandler(bool offlineCollect);
void setKey(int key) { _key = key; }
int getKey() const { return _key; }
@ -47,6 +51,7 @@ namespace Resource
osg::ref_ptr<osg::Camera> _camera;
bool _initialized;
bool _statsType;
bool _offlineCollect;
float _statsWidth;
float _statsHeight;
@ -58,6 +63,8 @@ namespace Resource
};
void CollectStatistics(osgViewer::ViewerBase* viewer);
}
#endif