charcoal/OpenGLEngine/FPS.h

47 lines
1.4 KiB
C
Raw Permalink Normal View History

2018-09-04 19:25:54 +00:00
#pragma once
2018-09-06 05:14:00 +00:00
#include <ctime>
2018-09-04 19:25:54 +00:00
2018-09-12 21:03:46 +00:00
namespace charcoal
2018-09-04 19:25:54 +00:00
{
2018-09-12 21:03:46 +00:00
//A class to handle the FPS of the game
//Calculations are done per the number of frames specified
//Frames must be a value from 2 - 255
//Recommended numbers for frames is 2 (Instant), 5 (Slightly Smoothed), 60 (Smoothed)
//Max number for frames = 255
//Lower frames = jumpy, instant updates
//Higher frames = smoother, flowing updates
class FPS final
{
public:
FPS(unsigned short frames = 2);
~FPS();
//Returns the clock of the last mark() call
const clock_t& get_clock() const;
//Returns FPS (frames per second) of the game (based on the last marked frame)
//CLOCKS_PER_SECOND / (m_clock - m_prevClock)
float get_spf() const;
//Returns FPS (frames per second) of the game (based on the last marked frame)
//CLOCKS_PER_SECOND / (m_clock - m_prevClock)
float get_fps() const;
//Fills the clocks with the current clock() value (to prevent unreasonable clock counts at the first few frames)
void prepare();
//Marks the end of the frame (resets the clock)
//Should be called right before the update() and render() functions
//Also calculates the seconds per frame (able to be considered the dTime)
//(m_clock - m_prevClock) / CLOCKS_PER_SEC
float mark();
private:
//m_iter marks the place of the next mark
unsigned short m_iter;
unsigned short m_frames;
clock_t* m_clocks = nullptr;
};
}