From e7ff8a9d0cff724520c4fb7a13b77e93797759cf Mon Sep 17 00:00:00 2001 From: JAROWMR Date: Tue, 7 Jan 2025 15:03:53 +0100 Subject: saving coins avaiable in menu --- game/CMakeLists.txt | 1 + game/coins/CoinScript.cpp | 2 -- game/hud/HudScript.cpp | 10 +++++++++ game/hud/HudScript.h | 3 +++ game/menus/ButtonNextMainMenuScript.cpp | 37 +++++++++++++++++++++++++++++++++ game/menus/ButtonNextMainMenuScript.h | 15 +++++++++++++ game/menus/ButtonSetMainMenuScript.cpp | 4 ---- game/menus/ButtonSubScene.cpp | 4 ++++ game/menus/ButtonSubScene.h | 1 + game/menus/endgame/EndGameSubScene.cpp | 2 +- 10 files changed, 72 insertions(+), 7 deletions(-) create mode 100644 game/menus/ButtonNextMainMenuScript.cpp create mode 100644 game/menus/ButtonNextMainMenuScript.h diff --git a/game/CMakeLists.txt b/game/CMakeLists.txt index a936ca0..ccafc9b 100644 --- a/game/CMakeLists.txt +++ b/game/CMakeLists.txt @@ -28,6 +28,7 @@ add_executable(main menus/IButtonScript.cpp menus/ButtonSetShopScript.cpp menus/ButtonSetMainMenuScript.cpp + menus/ButtonNextMainMenuScript.cpp menus/FloatingWindowSubScene.cpp menus/IFloatingWindowScript.cpp menus/shop/ShopMenuScene.cpp diff --git a/game/coins/CoinScript.cpp b/game/coins/CoinScript.cpp index a3ee3b9..2ecbb98 100644 --- a/game/coins/CoinScript.cpp +++ b/game/coins/CoinScript.cpp @@ -19,7 +19,6 @@ bool CoinScript::on_collision(const CollisionEvent & collisionData){ void CoinScript::init(){ this->subscribe([this](const CollisionEvent & ev) -> bool { return this->on_collision(ev); }); - this->subscribe([this](const EndGameEvent e)-> bool { return this->save(); }); } void CoinScript::fixed_update(crepe::duration_t dt) { @@ -31,6 +30,5 @@ void CoinScript::fixed_update(crepe::duration_t dt) { bool CoinScript::save(){ SaveManager & savemgr = this->get_save_manager(); savemgr.set(TOTAL_COINS_RUN, this->amount); - this->amount = 0; return false; } diff --git a/game/hud/HudScript.cpp b/game/hud/HudScript.cpp index 30a5c15..165f245 100644 --- a/game/hud/HudScript.cpp +++ b/game/hud/HudScript.cpp @@ -3,6 +3,7 @@ #include "api/Transform.h" #include "manager/SaveManager.h" #include "../Config.h" +#include "../Events.h" #include "HudConfig.h" #include @@ -20,6 +21,7 @@ void HudScript::init() { this->subscribe([this](const GetCoinEvent e)-> bool { return this->get_coin(e); }); this->subscribe([this](const KeyPressEvent & ev) -> bool { return this->toggle_fps(ev);}); + this->subscribe([this](const EndGameEvent e)-> bool { return this->save(); }); } bool HudScript::toggle_fps(crepe::KeyPressEvent ev){ @@ -42,6 +44,7 @@ void HudScript::frame_update(crepe::duration_t dt) { Text & txt_dt = this->get_components_by_name(HUD_DISTANCE).front(); Transform & tf = this->get_components_by_name(PLAYER_NAME).front(); string distance = to_string(static_cast(tf.position.x/STEP_SIZE_DISTANCE)) + DISTANCE_UNIT; + this->distance_st = distance; txt_dt.text = distance; txt_dt.dimensions = {DISTANCE_CHAR_WIDTH*distance.size(),(DISTANCE_CHAR_WIDTH)*2}; txt_dt.offset = TOP_LEFT+FONTOFFSET + vec2{distance.size() * DISTANCE_CHAR_WIDTH/2,0}; @@ -49,6 +52,7 @@ void HudScript::frame_update(crepe::duration_t dt) { // Coins Text & txt_co = this->get_components_by_name(HUD_COINS).front(); string amount_of_coins = to_string(this->coin_amount); + this->coin_amount_st = amount_of_coins; txt_co.text = amount_of_coins; txt_co.dimensions = {COINS_CHAR_WIDTH*amount_of_coins.size(),(COINS_CHAR_WIDTH)*2}; txt_co.offset = TOP_LEFT+FONTOFFSET+COINS_OFFSET + vec2{amount_of_coins.size() * COINS_CHAR_WIDTH/2,0}; @@ -71,3 +75,9 @@ bool HudScript::get_coin(const GetCoinEvent e){ return true; } +bool HudScript::save(){ + SaveManager & savemgr = this->get_save_manager(); + savemgr.set(TOTAL_COINS_RUN, this->coin_amount); + savemgr.set(DISTANCE_RUN, this->distance_st); + return false; +} diff --git a/game/hud/HudScript.h b/game/hud/HudScript.h index d780d4b..cf939f4 100644 --- a/game/hud/HudScript.h +++ b/game/hud/HudScript.h @@ -14,8 +14,11 @@ public: void frame_update(crepe::duration_t dt) override; bool get_coin(const GetCoinEvent e); bool toggle_fps(crepe::KeyPressEvent ev); + bool save(); private: crepe::SaveManager* savemgr; bool show_fps = false; int coin_amount = 0; + std::string coin_amount_st = ""; + std::string distance_st = ""; }; diff --git a/game/menus/ButtonNextMainMenuScript.cpp b/game/menus/ButtonNextMainMenuScript.cpp new file mode 100644 index 0000000..d7f48e2 --- /dev/null +++ b/game/menus/ButtonNextMainMenuScript.cpp @@ -0,0 +1,37 @@ +#include "ButtonNextMainMenuScript.h" +#include "MenusConfig.h" +#include "ValueBroker.h" +#include "api/AudioSource.h" +#include "manager/SaveManager.h" +#include "types.h" +#include "../Config.h" + +using namespace crepe; +using namespace std; + +void ButtonNextMainMenuScript::init(){ + IButtonScript::init(); + this->subscribe([this](const ButtonPressEvent& e) { return this->on_button_press(e); }); +} + +bool ButtonNextMainMenuScript::on_button_press(const ButtonPressEvent& e){ + RefVector audios = this->get_components_by_name("background_music"); + + for (AudioSource & audio : audios) { + audio.stop(); + } + + SaveManager & savemgr = this->get_save_manager(); + + ValueBroker coins = savemgr.get(TOTAL_COINS_RUN,0); + ValueBroker coins_game = savemgr.get(TOTAL_COINS_GAME,0); + savemgr.set(TOTAL_COINS_GAME, coins_game.get()+coins.get()); + + ValueBroker distance = savemgr.get(DISTANCE_RUN,0); + ValueBroker distance_game = savemgr.get(DISTANCE_GAME,0); + if(distance.get() > distance_game.get()) savemgr.set(DISTANCE_GAME, distance.get()); + + this->set_next_scene(MAINMENU_SCENE); + return false; +} + diff --git a/game/menus/ButtonNextMainMenuScript.h b/game/menus/ButtonNextMainMenuScript.h new file mode 100644 index 0000000..b9f70b3 --- /dev/null +++ b/game/menus/ButtonNextMainMenuScript.h @@ -0,0 +1,15 @@ +#pragma once + +#include "IButtonScript.h" + +#include + +class ButtonNextMainMenuScript : public IButtonScript { +public: + void init() override; + bool on_button_press(const crepe::ButtonPressEvent& e); +private: + float velocity = 20; +protected: + bool transition = false; +}; diff --git a/game/menus/ButtonSetMainMenuScript.cpp b/game/menus/ButtonSetMainMenuScript.cpp index e9232b5..e967dfb 100644 --- a/game/menus/ButtonSetMainMenuScript.cpp +++ b/game/menus/ButtonSetMainMenuScript.cpp @@ -14,10 +14,6 @@ void ButtonSetMainMenuScript::init(){ bool ButtonSetMainMenuScript::on_button_press(const ButtonPressEvent& e){ RefVector audios = this->get_components_by_name("background_music"); - for (AudioSource & audio : audios) { - audio.stop(); - } - this->set_next_scene(MAINMENU_SCENE); return false; } diff --git a/game/menus/ButtonSubScene.cpp b/game/menus/ButtonSubScene.cpp index 8574b9b..ea0df8a 100644 --- a/game/menus/ButtonSubScene.cpp +++ b/game/menus/ButtonSubScene.cpp @@ -1,4 +1,5 @@ #include "ButtonSubScene.h" +#include "ButtonNextMainMenuScript.h" #include "ButtonSetMainMenuScript.h" #include "ButtonSetShopScript.h" #include "IButtonScript.h" @@ -46,6 +47,9 @@ void ButtonSubScene::set_script(crepe::GameObject & button_object,const Data & d case ScriptSelect::MAINMENU: button_object.add_component().set_script(); break; + case ScriptSelect::NEXT: + button_object.add_component().set_script(); + break; case ScriptSelect::NONE: button_object.add_component().set_script(); break; diff --git a/game/menus/ButtonSubScene.h b/game/menus/ButtonSubScene.h index 28daed2..09c2fcd 100644 --- a/game/menus/ButtonSubScene.h +++ b/game/menus/ButtonSubScene.h @@ -15,6 +15,7 @@ public: PREVIEW, SHOP, MAINMENU, + NEXT, NONE, }; //icon enum diff --git a/game/menus/endgame/EndGameSubScene.cpp b/game/menus/endgame/EndGameSubScene.cpp index 41556af..5360c96 100644 --- a/game/menus/endgame/EndGameSubScene.cpp +++ b/game/menus/endgame/EndGameSubScene.cpp @@ -45,7 +45,7 @@ void EndGameSubScene::create(Scene & scn){ .text = "NEXT", .text_width = 100, .position = button_position, - .script_type = ButtonSubScene::ScriptSelect::MAINMENU, + .script_type = ButtonSubScene::ScriptSelect::NEXT, .button_type = ButtonSubScene::ButtonSelect::NEXT, .scale = 0.6, .worldspace = false, -- cgit v1.2.3