aboutsummaryrefslogtreecommitdiff
path: root/src/crepe/api/LoopTimer.cpp
blob: aaba8b3e8239b21e071ea02e27dfd3cb91b96b28 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#include "../facade/SDLContext.h"
#include "../util/log.h"

#include "LoopTimer.h"

using namespace crepe;

LoopTimer::LoopTimer() {
	dbg_trace();
}

LoopTimer & LoopTimer::get_instance() {
    static LoopTimer instance;
    return instance;
}

void LoopTimer::start() {
    last_frame_time = SDLContext::get_instance().get_ticks();
    elapsed_time = 0;
    elapsed_fixed_time = 0;
    delta_time = 0;
}

void LoopTimer::update() {
    uint64_t current_frame_time = SDLContext::get_instance().get_ticks();
    delta_time = (current_frame_time - last_frame_time) / 1000.0;

    if (delta_time > maximum_delta_time) {
        delta_time = maximum_delta_time;
    }
    delta_time = game_scale;
    elapsed_time += delta_time;
    last_frame_time = current_frame_time;
}

double LoopTimer::get_delta_time() const { return delta_time; }
int LoopTimer::get_current_time() const { return elapsed_time; }

void LoopTimer::advance_fixed_update() { elapsed_fixed_time += fixed_delta_time; }

double LoopTimer::get_fixed_delta_time() const { return fixed_delta_time; }

void LoopTimer::set_fps(int fps) {
    this->fps = fps;
    frame_target_time = 1.0 / fps;
}

int LoopTimer::get_fps() const { return fps; }
void LoopTimer::set_game_scale(double value) { game_scale = value; };
double LoopTimer::get_game_scale() const { return game_scale; }
void LoopTimer::enforce_frame_rate() {
    uint64_t current_frame_time = SDLContext::get_instance().get_ticks();
    double frame_duration = (current_frame_time - last_frame_time) / 1000.0;

    if (frame_duration < frame_target_time) {
        uint32_t delay_time
            = (uint32_t) ((frame_target_time - frame_duration) / 1000.0);
        SDLContext::get_instance().delay(delay_time);
    }
}

double LoopTimer::get_lag() const { return elapsed_time - elapsed_fixed_time; }