diff options
Diffstat (limited to 'game')
-rw-r--r-- | game/hud/HudConfig.h | 1 | ||||
-rw-r--r-- | game/hud/SpeedScript.cpp | 21 | ||||
-rw-r--r-- | game/hud/SpeedScript.h | 1 |
3 files changed, 15 insertions, 8 deletions
diff --git a/game/hud/HudConfig.h b/game/hud/HudConfig.h index 1d2ed89..5972f0a 100644 --- a/game/hud/HudConfig.h +++ b/game/hud/HudConfig.h @@ -24,5 +24,4 @@ static constexpr const char* COINS = "0000"; static constexpr int COINS_LENGTH = 4; static constexpr float COINS_CHAR_WIDTH = 10; static constexpr crepe::vec2 COINS_OFFSET = {0,50}; -
\ No newline at end of file diff --git a/game/hud/SpeedScript.cpp b/game/hud/SpeedScript.cpp index c0d927c..69534d9 100644 --- a/game/hud/SpeedScript.cpp +++ b/game/hud/SpeedScript.cpp @@ -1,24 +1,31 @@ #include "SpeedScript.h" +#include "api/Event.h" #include "api/KeyCodes.h" #include "manager/LoopTimerManager.h" using namespace crepe; using namespace std; -void SpeedScript::fixed_update(crepe::duration_t dt){ - LoopTimerManager & lp = this->get_loop_timer(); - if(this->get_key_state(Keycode::HOME)){ - if(toggle) +void SpeedScript::init() { + this->subscribe<KeyPressEvent>([this](const KeyPressEvent & ev) -> bool { + if(ev.key != Keycode::HOME) return false; + LoopTimerManager & lp = this->get_loop_timer(); + this->toggle = !this->toggle; + if(this->toggle) { this->timescale = lp.get_time_scale(); lp.set_time_scale(0); - toggle = false; } else { lp.set_time_scale(this->timescale); - toggle = true; } - } + + return true; + }); +} + +void SpeedScript::fixed_update(crepe::duration_t dt){ + LoopTimerManager & lp = this->get_loop_timer(); if(this->get_key_state(Keycode::PAGE_UP)){ lp.set_time_scale(lp.get_time_scale()+0.1); } diff --git a/game/hud/SpeedScript.h b/game/hud/SpeedScript.h index 1cc4368..8bd7271 100644 --- a/game/hud/SpeedScript.h +++ b/game/hud/SpeedScript.h @@ -5,6 +5,7 @@ class SpeedScript : public crepe::Script { public: + void init() override; void fixed_update(crepe::duration_t dt) override; private: crepe::SaveManager* savemgr; |