2023-05-13 00:15:48 +03:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
2023-05-13 01:12:11 +03:00
|
|
|
/// Framerate manager controls current game frame rate by constantly trying to reach targeted frame rate
|
2023-05-13 00:15:48 +03:00
|
|
|
class FramerateManager
|
|
|
|
{
|
2023-05-13 01:12:11 +03:00
|
|
|
using Clock = boost::chrono::high_resolution_clock;
|
|
|
|
using TimePoint = Clock::time_point;
|
|
|
|
using Duration = Clock::duration;
|
|
|
|
|
|
|
|
/// cyclic buffer of durations of last frames
|
|
|
|
std::array<Duration, 60> lastFrameTimes;
|
|
|
|
|
|
|
|
Duration targetFrameTime;
|
|
|
|
TimePoint lastTimePoint;
|
|
|
|
|
2024-06-24 03:23:26 +02:00
|
|
|
/// index of last measured from in lastFrameTimes array
|
2023-05-13 01:12:11 +03:00
|
|
|
ui32 lastFrameIndex;
|
2023-05-13 00:15:48 +03:00
|
|
|
|
2023-09-27 16:09:52 +02:00
|
|
|
bool vsyncEnabled;
|
|
|
|
|
2023-05-13 00:15:48 +03:00
|
|
|
public:
|
2023-05-13 01:12:11 +03:00
|
|
|
FramerateManager(int targetFramerate);
|
|
|
|
|
|
|
|
/// must be called every frame
|
|
|
|
/// updates framerate calculations and executes sleep to maintain target frame rate
|
|
|
|
void framerateDelay();
|
|
|
|
|
|
|
|
/// returns duration of last frame in seconds
|
|
|
|
ui32 getElapsedMilliseconds() const;
|
|
|
|
|
|
|
|
/// returns current estimation of frame rate
|
|
|
|
ui32 getFramerate() const;
|
2023-05-13 00:15:48 +03:00
|
|
|
};
|