| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 | /* * FramerateManager.h, part of VCMI engine * * Authors: listed in file AUTHORS in main folder * * License: GNU General Public License v2.0 or later * Full text of license available in license.txt file, in main folder * */#include "StdInc.h"#include "FramerateManager.h"#include "../../lib/CConfigHandler.h"#include <SDL_video.h>FramerateManager::FramerateManager(int targetFrameRate)	: targetFrameTime(Duration(boost::chrono::seconds(1)) / targetFrameRate)	, lastFrameIndex(0)	, lastFrameTimes({})	, lastTimePoint(Clock::now())	, vsyncEnabled(settings["video"]["vsync"].Bool()){	boost::range::fill(lastFrameTimes, targetFrameTime);}void FramerateManager::framerateDelay(){	Duration timeSpentBusy = Clock::now() - lastTimePoint;	if(!vsyncEnabled)	{		// if FPS is higher than it should be, then wait some time		if(timeSpentBusy < targetFrameTime)		{			boost::this_thread::sleep_for(targetFrameTime - timeSpentBusy);		}	}	// compute actual timeElapsed taking into account actual sleep interval	// limit it to 100 ms to avoid breaking animation in case of huge lag (e.g. triggered breakpoint)	TimePoint currentTicks = Clock::now();	Duration timeElapsed = currentTicks - lastTimePoint;	if(timeElapsed > boost::chrono::milliseconds(100))		timeElapsed = boost::chrono::milliseconds(100);	lastTimePoint = currentTicks;	lastFrameIndex = (lastFrameIndex + 1) % lastFrameTimes.size();	lastFrameTimes[lastFrameIndex] = timeElapsed;}ui32 FramerateManager::getElapsedMilliseconds() const{	return lastFrameTimes[lastFrameIndex] / boost::chrono::milliseconds(1);}ui32 FramerateManager::getFramerate() const{	Duration accumulatedTime = std::accumulate(lastFrameTimes.begin(), lastFrameTimes.end(), Duration());	auto actualFrameTime = accumulatedTime / lastFrameTimes.size();	if(actualFrameTime == actualFrameTime.zero())		return 0;	return std::round(boost::chrono::duration<double>(1) / actualFrameTime);};
 |