aboutsummaryrefslogtreecommitdiff
path: root/game/menus
diff options
context:
space:
mode:
authorLoek Le Blansch <loek@pipeframe.xyz>2025-01-08 15:03:14 +0100
committerLoek Le Blansch <loek@pipeframe.xyz>2025-01-08 15:03:14 +0100
commit261a2cfd2bedafbc7fcf54e1b86adee206dea519 (patch)
treef099bca292e99ae54035f9a5ac7a455eec073c3e /game/menus
parentd9c67da9b8c2d8d25ef4dd2c700ddc78573d3a60 (diff)
parent0b9574bdd6c5968c07bcf165d66032b75649b5da (diff)
merge w/ master
Diffstat (limited to 'game/menus')
-rw-r--r--game/menus/BannerSubScene.cpp53
-rw-r--r--game/menus/BannerSubScene.h9
-rw-r--r--game/menus/ButtonNextMainMenuSubScript.cpp42
-rw-r--r--game/menus/ButtonNextMainMenuSubScript.h (renamed from game/menus/ButtonSetShopScript.h)7
-rw-r--r--game/menus/ButtonSetMainMenuScript.cpp16
-rw-r--r--game/menus/ButtonSetMainMenuSubScript.cpp23
-rw-r--r--game/menus/ButtonSetMainMenuSubScript.h (renamed from game/menus/ButtonSetMainMenuScript.h)7
-rw-r--r--game/menus/ButtonSetShopSubScript.cpp (renamed from game/menus/ButtonSetShopScript.cpp)11
-rw-r--r--game/menus/ButtonSetShopSubScript.h14
-rw-r--r--game/menus/ButtonSubScene.cpp237
-rw-r--r--game/menus/ButtonSubScene.h34
-rw-r--r--game/menus/FloatingWindowSubScene.cpp238
-rw-r--r--game/menus/FloatingWindowSubScene.h11
-rw-r--r--game/menus/IButtonScript.cpp27
-rw-r--r--game/menus/IButtonScript.h6
-rw-r--r--game/menus/IFloatingWindowScript.cpp17
-rw-r--r--game/menus/IFloatingWindowScript.h4
-rw-r--r--game/menus/MenusConfig.h18
-rw-r--r--game/menus/endgame/EndGameSubScene.cpp104
-rw-r--r--game/menus/endgame/EndGameSubScene.h2
-rw-r--r--game/menus/endgame/EndGameSubScript.cpp37
-rw-r--r--game/menus/endgame/EndGameSubScript.h7
-rw-r--r--game/menus/mainmenu/ButtonTransitionPreviewScript.cpp21
-rw-r--r--game/menus/mainmenu/ButtonTransitionPreviewScript.h12
-rw-r--r--game/menus/mainmenu/ButtonTransitionPreviewSubScript.cpp23
-rw-r--r--game/menus/mainmenu/ButtonTransitionPreviewSubScript.h12
-rw-r--r--game/menus/mainmenu/ITransitionScript.cpp21
-rw-r--r--game/menus/mainmenu/ITransitionScript.h4
-rw-r--r--game/menus/mainmenu/MainMenuConfig.h17
-rw-r--r--game/menus/mainmenu/MainMenuScene.cpp125
-rw-r--r--game/menus/mainmenu/TransitionStartScript.cpp15
-rw-r--r--game/menus/mainmenu/TransitionStartSubScript.cpp16
-rw-r--r--game/menus/mainmenu/TransitionStartSubScript.h (renamed from game/menus/mainmenu/TransitionStartScript.h)4
-rw-r--r--game/menus/shop/ShopMenuScene.cpp58
34 files changed, 728 insertions, 524 deletions
diff --git a/game/menus/BannerSubScene.cpp b/game/menus/BannerSubScene.cpp
index ea43c69..006a829 100644
--- a/game/menus/BannerSubScene.cpp
+++ b/game/menus/BannerSubScene.cpp
@@ -3,40 +3,47 @@
#include "../Config.h"
-#include <crepe/api/Sprite.h>
#include <crepe/api/Scene.h>
+#include <crepe/api/Sprite.h>
#include <crepe/api/Text.h>
using namespace crepe;
using namespace std;
-void BannerSubScene::create(Scene & scn,const Data & data){
- GameObject menu_banner = scn.new_object("menu_banner","", {0,-414});
+void BannerSubScene::create(Scene & scn, const Data & data) {
+ GameObject menu_banner = scn.new_object("menu_banner", "", {0, -414});
menu_banner.add_component<Sprite>(
Asset("asset/ui/settings_container/top_middle_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1,
- .size = {1100,88},
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1,
+ .size = {1100, 88},
+ }
+ );
menu_banner.add_component<Sprite>(
Asset("asset/ui/settings_container/top_2_middle_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1,
- .size = {1100,66},
- .position_offset {0,77},
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1,
+ .size = {1100, 66},
+ .position_offset {0, 77},
+ }
+ );
menu_banner.add_component<Sprite>(
Asset("asset/ui/settings_container/banner_bottom.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1,
- .size = {1100,7},
- .position_offset {0,113},
- });
- crepe::vec2 size = {data.banner_title_width,(data.banner_title_width/data.banner_title.size())*2};
-
- menu_banner.add_component<Text>( size, FONT, Text::Data{
- .world_space = true,
- .text_color = Color::WHITE,
- }, data.banner_title_offset + FONTOFFSET, data.banner_title);
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1,
+ .size = {1100, 7},
+ .position_offset {0, 113},
+ }
+ );
+ crepe::vec2 size
+ = {data.banner_title_width, (data.banner_title_width / data.banner_title.size()) * 2};
+ menu_banner.add_component<Text>(
+ size, FONT,
+ Text::Data {
+ .world_space = true,
+ .text_color = Color::WHITE,
+ },
+ data.banner_title_offset + FONTOFFSET, data.banner_title
+ );
}
diff --git a/game/menus/BannerSubScene.h b/game/menus/BannerSubScene.h
index 888897d..c194dfc 100644
--- a/game/menus/BannerSubScene.h
+++ b/game/menus/BannerSubScene.h
@@ -1,7 +1,7 @@
#pragma once
-#include <crepe/types.h>
#include <crepe/api/GameObject.h>
+#include <crepe/types.h>
namespace crepe {
class Scene;
@@ -9,11 +9,12 @@ class Scene;
class BannerSubScene {
public:
-struct Data{
+ struct Data {
const std::string & banner_title = "NODATA";
const float banner_title_width = 100;
- const crepe::vec2 & banner_title_offset = {0,0};
+ const crepe::vec2 & banner_title_offset = {0, 0};
};
+
public:
- void create(crepe::Scene & scn,const Data & data);
+ void create(crepe::Scene & scn, const Data & data);
};
diff --git a/game/menus/ButtonNextMainMenuSubScript.cpp b/game/menus/ButtonNextMainMenuSubScript.cpp
new file mode 100644
index 0000000..e03a34a
--- /dev/null
+++ b/game/menus/ButtonNextMainMenuSubScript.cpp
@@ -0,0 +1,42 @@
+#include "ButtonNextMainMenuSubScript.h"
+#include "MenusConfig.h"
+#include "ValueBroker.h"
+
+#include "manager/SaveManager.h"
+
+#include "../Config.h"
+
+#include <crepe/api/AudioSource.h>
+#include <crepe/types.h>
+
+using namespace crepe;
+using namespace std;
+
+void ButtonNextMainMenuSubScript::init() {
+ IButtonScript::init();
+ this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent & e) {
+ return this->on_button_press(e);
+ });
+}
+
+bool ButtonNextMainMenuSubScript::on_button_press(const ButtonPressEvent & e) {
+ RefVector<AudioSource> audios
+ = this->get_components_by_name<AudioSource>("background_music");
+
+ for (AudioSource & audio : audios) {
+ audio.stop();
+ }
+
+ SaveManager & savemgr = this->get_save_manager();
+
+ ValueBroker<int> coins = savemgr.get<int>(TOTAL_COINS_RUN, 0);
+ ValueBroker<int> coins_game = savemgr.get<int>(TOTAL_COINS_GAME, 0);
+ savemgr.set(TOTAL_COINS_GAME, coins_game.get() + coins.get());
+
+ ValueBroker<int> distance = savemgr.get<int>(DISTANCE_RUN, 0);
+ ValueBroker<int> distance_game = savemgr.get<int>(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/ButtonSetShopScript.h b/game/menus/ButtonNextMainMenuSubScript.h
index 434abc0..3bc3f52 100644
--- a/game/menus/ButtonSetShopScript.h
+++ b/game/menus/ButtonNextMainMenuSubScript.h
@@ -4,12 +4,11 @@
#include <crepe/api/Script.h>
-class ButtonSetShopScript : public IButtonScript {
+class ButtonNextMainMenuSubScript : public IButtonScript {
public:
void init() override;
- bool on_button_press(const crepe::ButtonPressEvent& e);
-private:
- float velocity = 20;
+ bool on_button_press(const crepe::ButtonPressEvent & e);
+
protected:
bool transition = false;
};
diff --git a/game/menus/ButtonSetMainMenuScript.cpp b/game/menus/ButtonSetMainMenuScript.cpp
deleted file mode 100644
index 12b7256..0000000
--- a/game/menus/ButtonSetMainMenuScript.cpp
+++ /dev/null
@@ -1,16 +0,0 @@
-#include "ButtonSetMainMenuScript.h"
-#include "MenusConfig.h"
-
-using namespace crepe;
-using namespace std;
-
-void ButtonSetMainMenuScript::init(){
- IButtonScript::init();
- this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent& e) { return this->on_button_press(e); });
-}
-
-bool ButtonSetMainMenuScript::on_button_press(const ButtonPressEvent& e){
- this->set_next_scene(MAINMENU_SCENE);
- return false;
-}
-
diff --git a/game/menus/ButtonSetMainMenuSubScript.cpp b/game/menus/ButtonSetMainMenuSubScript.cpp
new file mode 100644
index 0000000..1c6bcb2
--- /dev/null
+++ b/game/menus/ButtonSetMainMenuSubScript.cpp
@@ -0,0 +1,23 @@
+#include "ButtonSetMainMenuSubScript.h"
+#include "MenusConfig.h"
+
+#include <crepe/api/AudioSource.h>
+#include <crepe/types.h>
+
+using namespace crepe;
+using namespace std;
+
+void ButtonSetMainMenuSubScript::init() {
+ IButtonScript::init();
+ this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent & e) {
+ return this->on_button_press(e);
+ });
+}
+
+bool ButtonSetMainMenuSubScript::on_button_press(const ButtonPressEvent & e) {
+ RefVector<AudioSource> audios
+ = this->get_components_by_name<AudioSource>("background_music");
+
+ this->set_next_scene(MAINMENU_SCENE);
+ return false;
+}
diff --git a/game/menus/ButtonSetMainMenuScript.h b/game/menus/ButtonSetMainMenuSubScript.h
index 13a33bf..2fb2634 100644
--- a/game/menus/ButtonSetMainMenuScript.h
+++ b/game/menus/ButtonSetMainMenuSubScript.h
@@ -4,12 +4,11 @@
#include <crepe/api/Script.h>
-class ButtonSetMainMenuScript : public IButtonScript {
+class ButtonSetMainMenuSubScript : public IButtonScript {
public:
void init() override;
- bool on_button_press(const crepe::ButtonPressEvent& e);
-private:
- float velocity = 20;
+ bool on_button_press(const crepe::ButtonPressEvent & e);
+
protected:
bool transition = false;
};
diff --git a/game/menus/ButtonSetShopScript.cpp b/game/menus/ButtonSetShopSubScript.cpp
index 88639bd..4f395eb 100644
--- a/game/menus/ButtonSetShopScript.cpp
+++ b/game/menus/ButtonSetShopSubScript.cpp
@@ -1,16 +1,17 @@
-#include "ButtonSetShopScript.h"
+#include "ButtonSetShopSubScript.h"
#include "MenusConfig.h"
using namespace crepe;
using namespace std;
-void ButtonSetShopScript::init(){
+void ButtonSetShopSubScript::init() {
IButtonScript::init();
- this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent& e) { return this->on_button_press(e); });
+ this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent & e) {
+ return this->on_button_press(e);
+ });
}
-bool ButtonSetShopScript::on_button_press(const ButtonPressEvent& e){
+bool ButtonSetShopSubScript::on_button_press(const ButtonPressEvent & e) {
this->set_next_scene(SHOP_SCENE);
return false;
}
-
diff --git a/game/menus/ButtonSetShopSubScript.h b/game/menus/ButtonSetShopSubScript.h
new file mode 100644
index 0000000..4017a4c
--- /dev/null
+++ b/game/menus/ButtonSetShopSubScript.h
@@ -0,0 +1,14 @@
+#pragma once
+
+#include "IButtonScript.h"
+
+#include <crepe/api/Script.h>
+
+class ButtonSetShopSubScript : public IButtonScript {
+public:
+ void init() override;
+ bool on_button_press(const crepe::ButtonPressEvent & e);
+
+protected:
+ bool transition = false;
+};
diff --git a/game/menus/ButtonSubScene.cpp b/game/menus/ButtonSubScene.cpp
index 8574b9b..e41c798 100644
--- a/game/menus/ButtonSubScene.cpp
+++ b/game/menus/ButtonSubScene.cpp
@@ -1,50 +1,62 @@
#include "ButtonSubScene.h"
-#include "ButtonSetMainMenuScript.h"
-#include "ButtonSetShopScript.h"
+#include "ButtonNextMainMenuSubScript.h"
+#include "ButtonSetMainMenuSubScript.h"
+#include "ButtonSetShopSubScript.h"
#include "IButtonScript.h"
#include "MenusConfig.h"
-#include "mainmenu/ButtonTransitionPreviewScript.h"
+#include "mainmenu/ButtonTransitionPreviewSubScript.h"
#include "../Config.h"
#include <crepe/api/BehaviorScript.h>
-#include <crepe/api/Sprite.h>
-#include <crepe/api/Scene.h>
#include <crepe/api/Button.h>
-#include <crepe/api/Text.h>
#include <crepe/api/Color.h>
+#include <crepe/api/Scene.h>
+#include <crepe/api/Sprite.h>
+#include <crepe/api/Text.h>
using namespace crepe;
using namespace std;
-void ButtonSubScene::create(Scene & scn,const Data & data){
- GameObject button_object = scn.new_object("button",data.tag,data.position,0,data.scale);
- this->set_button_overlay(button_object,data);
- this->btn_text(button_object,data);
- this->set_script(button_object,data);
- this->set_icon(button_object,data);
+void ButtonSubScene::create(Scene & scn, const Data & data) {
+ GameObject button_object
+ = scn.new_object("button", data.tag, data.position, 0, data.scale);
+ this->set_button_overlay(button_object, data);
+ this->btn_text(button_object, data);
+ this->set_script(button_object, data);
+ this->set_icon(button_object, data);
}
-void ButtonSubScene::btn_text(crepe::GameObject & button_object,const Data & data){
+void ButtonSubScene::btn_text(crepe::GameObject & button_object, const Data & data) {
- crepe::vec2 size = {data.text_width,(data.text_width/data.text.size())*2};
- button_object.add_component<Text>(size, FONT,Text::Data{
- .world_space = data.worldspace,
- .text_color = Color::WHITE,
- }, data.text_offset+FONTOFFSET, data.text);
+ crepe::vec2 size = {data.text_width, (data.text_width / data.text.size()) * 2};
+ button_object.add_component<Text>(
+ size, FONT,
+ Text::Data {
+ .world_space = data.worldspace,
+ .text_color = Color::WHITE,
+ },
+ data.text_offset + FONTOFFSET, data.text
+ );
}
-void ButtonSubScene::set_script(crepe::GameObject & button_object,const Data & data){
+void ButtonSubScene::set_script(crepe::GameObject & button_object, const Data & data) {
switch (data.script_type) {
case ScriptSelect::PREVIEW:
- button_object.add_component<BehaviorScript>().set_script<ButtonTransitionPreviewScript>();
+ button_object.add_component<BehaviorScript>()
+ .set_script<ButtonTransitionPreviewSubScript>();
break;
case ScriptSelect::SHOP:
- button_object.add_component<BehaviorScript>().set_script<ButtonSetShopScript>();
+ button_object.add_component<BehaviorScript>().set_script<ButtonSetShopSubScript>();
break;
case ScriptSelect::MAINMENU:
- button_object.add_component<BehaviorScript>().set_script<ButtonSetMainMenuScript>();
+ button_object.add_component<BehaviorScript>()
+ .set_script<ButtonSetMainMenuSubScript>();
+ break;
+ case ScriptSelect::NEXT:
+ button_object.add_component<BehaviorScript>()
+ .set_script<ButtonNextMainMenuSubScript>();
break;
case ScriptSelect::NONE:
button_object.add_component<BehaviorScript>().set_script<IButtonScript>();
@@ -52,100 +64,141 @@ void ButtonSubScene::set_script(crepe::GameObject & button_object,const Data & d
}
}
-void ButtonSubScene::set_icon(crepe::GameObject & button_object,const Data & data){
+void ButtonSubScene::set_icon(crepe::GameObject & button_object, const Data & data) {
switch (data.icon_type) {
case IconSelect::SHOP:
- button_object.add_component<Sprite>(Asset("asset/ui/buttonCoinsSmall.png"),Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+3 + data.sorting_layer_offset,
- .size = ICON_SIZE,
- .position_offset = data.icon_offset,
- .world_space = data.worldspace,
- });
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/buttonCoinsSmall.png"),
+ Sprite::Data {
+ .sorting_in_layer
+ = STARTING_SORTING_IN_LAYER + 3 + data.sorting_layer_offset,
+ .size = ICON_SIZE,
+ .position_offset = data.icon_offset,
+ .world_space = data.worldspace,
+ }
+ );
break;
case IconSelect::COINS:
- button_object.add_component<Sprite>(Asset("asset/ui/buttonCoinsSmall.png"),Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+3 + data.sorting_layer_offset,
- .size = ICON_SIZE,
- .position_offset = data.icon_offset,
- .world_space = data.worldspace,
- });
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/buttonCoinsSmall.png"),
+ Sprite::Data {
+ .sorting_in_layer
+ = STARTING_SORTING_IN_LAYER + 3 + data.sorting_layer_offset,
+ .size = ICON_SIZE,
+ .position_offset = data.icon_offset,
+ .world_space = data.worldspace,
+ }
+ );
break;
case IconSelect::NONE:
break;
}
}
-void ButtonSubScene::set_button_overlay(crepe::GameObject & button_object,const Data & data){
+void ButtonSubScene::set_button_overlay(crepe::GameObject & button_object, const Data & data) {
switch (data.button_type) {
case ButtonSelect::LARGE:
- this->large_btn_overlay(button_object,data);
+ this->large_btn_overlay(button_object, data);
break;
case ButtonSelect::BACK:
- this->back_btn_overlay(button_object,data);
+ this->back_btn_overlay(button_object, data);
break;
case ButtonSelect::NEXT:
- this->next_btn_overlay(button_object,data);
+ this->next_btn_overlay(button_object, data);
break;
}
}
-void ButtonSubScene::large_btn_overlay(crepe::GameObject & button_object,const Data & data){
- button_object.add_component<Sprite>(Asset("asset/ui/buttonBacking.png"),Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1 + data.sorting_layer_offset,
- .size = LARGE_OVERLAY_SIZE,
- .world_space = data.worldspace,
- });
- button_object.add_component<Button>(LARGE_OVERLAY_SIZE,Button::Data{});
- if(!data.color_side) return;
- this->btn_color_side(button_object,SIDE_PANEL_OFFSET,data);
+void ButtonSubScene::large_btn_overlay(crepe::GameObject & button_object, const Data & data) {
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/buttonBacking.png"),
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1 + data.sorting_layer_offset,
+ .size = LARGE_OVERLAY_SIZE,
+ .world_space = data.worldspace,
+ }
+ );
+ button_object.add_component<Button>(LARGE_OVERLAY_SIZE, Button::Data {});
+ if (!data.color_side) return;
+ this->btn_color_side(button_object, SIDE_PANEL_OFFSET, data);
}
-void ButtonSubScene::back_btn_overlay(crepe::GameObject & button_object,const Data & data){
- button_object.add_component<Sprite>(Asset("asset/ui/backbuttonright.png"),Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1+ data.sorting_layer_offset,
- .size = SMALL_OVERLAY_SIZE_RIGHT,
- .position_offset = {20,0},
- .world_space = data.worldspace,
- });
- button_object.add_component<Sprite>(Asset("asset/ui/backbuttonleft.png"),Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1+ data.sorting_layer_offset,
- .size = SMALL_OVERLAY_SIZE_LEFT,
- .position_offset = {-80,0},
- .world_space = data.worldspace,
- });
- button_object.add_component<Button>(vec2{SMALL_OVERLAY_SIZE_LEFT.x+SMALL_OVERLAY_SIZE_RIGHT.x,SMALL_OVERLAY_SIZE_LEFT.y},Button::Data{});
+void ButtonSubScene::back_btn_overlay(crepe::GameObject & button_object, const Data & data) {
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/backbuttonright.png"),
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1 + data.sorting_layer_offset,
+ .size = SMALL_OVERLAY_SIZE_RIGHT,
+ .position_offset = {20, 0},
+ .world_space = data.worldspace,
+ }
+ );
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/backbuttonleft.png"),
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1 + data.sorting_layer_offset,
+ .size = SMALL_OVERLAY_SIZE_LEFT,
+ .position_offset = {-80, 0},
+ .world_space = data.worldspace,
+ }
+ );
+ button_object.add_component<Button>(
+ vec2 {
+ SMALL_OVERLAY_SIZE_LEFT.x + SMALL_OVERLAY_SIZE_RIGHT.x, SMALL_OVERLAY_SIZE_LEFT.y
+ },
+ Button::Data {}
+ );
}
-void ButtonSubScene::next_btn_overlay(crepe::GameObject & button_object,const Data & data){
- button_object.add_component<Sprite>(Asset("asset/ui/backbuttonright.png"),Sprite::Data{
- .flip = {true,false},
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1+ data.sorting_layer_offset,
- .size = SMALL_OVERLAY_SIZE_RIGHT,
- .position_offset = {-20,0},
- .world_space = data.worldspace,
- });
- button_object.add_component<Sprite>(Asset("asset/ui/backbuttonleft.png"),Sprite::Data{
- .flip = {true,false},
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+1+ data.sorting_layer_offset,
- .size = SMALL_OVERLAY_SIZE_LEFT,
- .position_offset = {80,0},
- .world_space = data.worldspace,
- });
- button_object.add_component<Button>(vec2{SMALL_OVERLAY_SIZE_LEFT.x+SMALL_OVERLAY_SIZE_RIGHT.x,SMALL_OVERLAY_SIZE_LEFT.y},Button::Data{});
+void ButtonSubScene::next_btn_overlay(crepe::GameObject & button_object, const Data & data) {
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/backbuttonright.png"),
+ Sprite::Data {
+ .flip = {true, false},
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1 + data.sorting_layer_offset,
+ .size = SMALL_OVERLAY_SIZE_RIGHT,
+ .position_offset = {-20, 0},
+ .world_space = data.worldspace,
+ }
+ );
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/backbuttonleft.png"),
+ Sprite::Data {
+ .flip = {true, false},
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 1 + data.sorting_layer_offset,
+ .size = SMALL_OVERLAY_SIZE_LEFT,
+ .position_offset = {80, 0},
+ .world_space = data.worldspace,
+ }
+ );
+ button_object.add_component<Button>(
+ vec2 {
+ SMALL_OVERLAY_SIZE_LEFT.x + SMALL_OVERLAY_SIZE_RIGHT.x, SMALL_OVERLAY_SIZE_LEFT.y
+ },
+ Button::Data {}
+ );
}
-void ButtonSubScene::btn_color_side(crepe::GameObject & button_object,const vec2 & offset,const Data & data){
- button_object.add_component<Sprite>(Asset("asset/ui/buttonSmallBlue.png"),Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER + 2 + data.sorting_layer_offset,
- .size = SIDE_PANEL_SIZE,
- .position_offset = offset,
- .world_space = data.worldspace,
- });
- button_object.add_component<Sprite>(Asset("asset/ui/buttonSmallBlue.png"),Sprite::Data{
- .flip = {true,false},
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+2 + data.sorting_layer_offset,
- .size = SIDE_PANEL_SIZE,
- .position_offset = {-offset.x,offset.y},
- .world_space = data.worldspace,
- });
+void ButtonSubScene::btn_color_side(
+ crepe::GameObject & button_object, const vec2 & offset, const Data & data
+) {
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/buttonSmallBlue.png"),
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 2 + data.sorting_layer_offset,
+ .size = SIDE_PANEL_SIZE,
+ .position_offset = offset,
+ .world_space = data.worldspace,
+ }
+ );
+ button_object.add_component<Sprite>(
+ Asset("asset/ui/buttonSmallBlue.png"),
+ Sprite::Data {
+ .flip = {true, false},
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 2 + data.sorting_layer_offset,
+ .size = SIDE_PANEL_SIZE,
+ .position_offset = {-offset.x, offset.y},
+ .world_space = data.worldspace,
+ }
+ );
}
diff --git a/game/menus/ButtonSubScene.h b/game/menus/ButtonSubScene.h
index 28daed2..c1c6de8 100644
--- a/game/menus/ButtonSubScene.h
+++ b/game/menus/ButtonSubScene.h
@@ -15,6 +15,7 @@ public:
PREVIEW,
SHOP,
MAINMENU,
+ NEXT,
NONE,
};
//icon enum
@@ -30,13 +31,13 @@ public:
LARGE,
};
//data struct
- struct Data{
+ struct Data {
const std::string & text = "NODATA";
- const crepe::vec2 & text_offset = {0,0};
+ const crepe::vec2 & text_offset = {0, 0};
const float text_width = 200;
- const crepe::vec2 & icon_offset = {0,0};
+ const crepe::vec2 & icon_offset = {0, 0};
const IconSelect icon_type = IconSelect::NONE;
- const crepe::vec2 & position = {0,0};
+ const crepe::vec2 & position = {0, 0};
const ScriptSelect script_type = ScriptSelect::NONE;
const ButtonSelect button_type = ButtonSelect::LARGE;
const float scale = 1;
@@ -45,17 +46,22 @@ public:
const std::string & tag = "";
const int sorting_layer_offset = 0;
};
+
public:
- void create(crepe::Scene & scn,const Data & data);
+ void create(crepe::Scene & scn, const Data & data);
+
private:
- void large_btn_overlay(crepe::GameObject & button_object,const Data & data);
- void back_btn_overlay(crepe::GameObject & button_object,const Data & data);
- void next_btn_overlay(crepe::GameObject & button_object,const Data & data);
- void btn_color_side(crepe::GameObject & button_object,const crepe::vec2 & offset,const Data & data);
- void btn_text(crepe::GameObject & button_object,const Data & data);
- void set_script(crepe::GameObject & button_object,const Data & data);
- void set_icon(crepe::GameObject & button_object,const Data & data);
- void set_button_overlay(crepe::GameObject & button_object,const Data & data);
+ void large_btn_overlay(crepe::GameObject & button_object, const Data & data);
+ void back_btn_overlay(crepe::GameObject & button_object, const Data & data);
+ void next_btn_overlay(crepe::GameObject & button_object, const Data & data);
+ void btn_color_side(
+ crepe::GameObject & button_object, const crepe::vec2 & offset, const Data & data
+ );
+ void btn_text(crepe::GameObject & button_object, const Data & data);
+ void set_script(crepe::GameObject & button_object, const Data & data);
+ void set_icon(crepe::GameObject & button_object, const Data & data);
+ void set_button_overlay(crepe::GameObject & button_object, const Data & data);
+
private:
- static constexpr crepe::vec2 SIDE_PANEL_OFFSET = {113,0};
+ static constexpr crepe::vec2 SIDE_PANEL_OFFSET = {113, 0};
};
diff --git a/game/menus/FloatingWindowSubScene.cpp b/game/menus/FloatingWindowSubScene.cpp
index 16963bb..4420bfa 100644
--- a/game/menus/FloatingWindowSubScene.cpp
+++ b/game/menus/FloatingWindowSubScene.cpp
@@ -1,19 +1,19 @@
#include "FloatingWindowSubScene.h"
#include "MenusConfig.h"
-#include "types.h"
+#include <crepe/api/Camera.h>
#include <crepe/api/GameObject.h>
#include <crepe/api/Scene.h>
#include <crepe/api/Sprite.h>
-#include <crepe/api/Camera.h>
+#include <crepe/types.h>
using namespace crepe;
using namespace std;
-void FloatingWindowSubScene::create(Scene & scn,const Data & data){
- const vec2 SIZE = {data.width,data.width*0.75f};
- const vec2 POSITION_CORRECTION = vec2{0,-SIZE.y/2} + data.offset;
+void FloatingWindowSubScene::create(Scene & scn, const Data & data) {
+ const vec2 SIZE = {data.width, data.width * 0.75f};
+ const vec2 POSITION_CORRECTION = vec2 {0, -SIZE.y / 2} + data.offset;
const float THICKNESS_BANNER = 34;
const float MIDDLE_OFFSET_FACTOR_TICKNESS = 0.83;
const float MIDDLE_OFFSET_FACTOR_OFFSET = 1.2;
@@ -22,157 +22,199 @@ void FloatingWindowSubScene::create(Scene & scn,const Data & data){
const float BOTTOM_OFFSET_X = 3;
const float BOTTOM_OFFSET_Y = -3;
- GameObject floatingwindow = scn.new_object("FloatingWindow",data.group_tag);
+ GameObject floatingwindow = scn.new_object("FloatingWindow", data.group_tag);
// Top_middle
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_middle_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {SIZE.x,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{0,0},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {SIZE.x, THICKNESS_BANNER},
+ .position_offset = POSITION_CORRECTION + vec2 {0, 0},
+ .world_space = false,
+ }
+ );
// Top_Left
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_left_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{-SIZE.x/2-THICKNESS_BANNER/2,0},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER, THICKNESS_BANNER},
+ .position_offset
+ = POSITION_CORRECTION + vec2 {-SIZE.x / 2 - THICKNESS_BANNER / 2, 0},
+ .world_space = false,
+ }
+ );
// Top_Right
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_right_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{SIZE.x/2+THICKNESS_BANNER/2,0},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER, THICKNESS_BANNER},
+ .position_offset
+ = POSITION_CORRECTION + vec2 {SIZE.x / 2 + THICKNESS_BANNER / 2, 0},
+ .world_space = false,
+ }
+ );
// Top_middle_2
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_2_middle_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {SIZE.x,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{0,THICKNESS_BANNER},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {SIZE.x, THICKNESS_BANNER},
+ .position_offset = POSITION_CORRECTION + vec2 {0, THICKNESS_BANNER},
+ .world_space = false,
+ }
+ );
// Top_Left_2
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_2_left_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{-SIZE.x/2-THICKNESS_BANNER/2,THICKNESS_BANNER},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER, THICKNESS_BANNER},
+ .position_offset = POSITION_CORRECTION
+ + vec2 {-SIZE.x / 2 - THICKNESS_BANNER / 2, THICKNESS_BANNER},
+ .world_space = false,
+ }
+ );
// Top_Right_2
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_2_right_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{SIZE.x/2+THICKNESS_BANNER/2,THICKNESS_BANNER},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER, THICKNESS_BANNER},
+ .position_offset
+ = POSITION_CORRECTION + vec2 {SIZE.x / 2 + THICKNESS_BANNER / 2, THICKNESS_BANNER},
+ .world_space = false,
+ }
+ );
// Top_middle_3
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_3_middle_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {SIZE.x,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{0,THICKNESS_BANNER*2},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {SIZE.x, THICKNESS_BANNER},
+ .position_offset = POSITION_CORRECTION + vec2 {0, THICKNESS_BANNER * 2},
+ .world_space = false,
+ }
+ );
// Top_Left_3
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_3_left_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{-SIZE.x/2-THICKNESS_BANNER/2,THICKNESS_BANNER*2},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER, THICKNESS_BANNER},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {-SIZE.x / 2 - THICKNESS_BANNER / 2, THICKNESS_BANNER * 2},
+ .world_space = false,
+ }
+ );
// Top_Right_3
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/top_3_right_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER,THICKNESS_BANNER},
- .position_offset = POSITION_CORRECTION + vec2{SIZE.x/2+THICKNESS_BANNER/2,THICKNESS_BANNER*2},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER, THICKNESS_BANNER},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {SIZE.x / 2 + THICKNESS_BANNER / 2, THICKNESS_BANNER * 2},
+ .world_space = false,
+ }
+ );
// Middle_Mid
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/middle_mid_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+7,
- .size = {SIZE.x*MIDDLE_OFFSET_FACTOR_OFFSET*MIDDLE_OFFSET_FACTOR_MIDDLE_WIDTH+data.width_middle_offset,SIZE.y},
- .position_offset = POSITION_CORRECTION + vec2{0,THICKNESS_BANNER*3+SIZE.y/2-THICKNESS_BANNER/2},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 7,
+ .size
+ = {SIZE.x * MIDDLE_OFFSET_FACTOR_OFFSET * MIDDLE_OFFSET_FACTOR_MIDDLE_WIDTH
+ + data.width_middle_offset,
+ SIZE.y},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {0, THICKNESS_BANNER * 3 + SIZE.y / 2 - THICKNESS_BANNER / 2},
+ .world_space = false,
+ }
+ );
// Middle_Left
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/middle_left_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS,SIZE.y},
- .position_offset = POSITION_CORRECTION + vec2{-SIZE.x/2-THICKNESS_BANNER/2*MIDDLE_OFFSET_FACTOR_OFFSET-MIDDLE_OFFSET_OFFSET_ADDITION,THICKNESS_BANNER*3+SIZE.y/2-THICKNESS_BANNER/2},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS, SIZE.y},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {-SIZE.x / 2 - THICKNESS_BANNER / 2 * MIDDLE_OFFSET_FACTOR_OFFSET - MIDDLE_OFFSET_OFFSET_ADDITION, THICKNESS_BANNER * 3 + SIZE.y / 2 - THICKNESS_BANNER / 2},
+ .world_space = false,
+ }
+ );
// Middle_Right
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/middle_right_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS,SIZE.y},
- .position_offset = POSITION_CORRECTION + vec2{SIZE.x/2+THICKNESS_BANNER/2*MIDDLE_OFFSET_FACTOR_OFFSET+MIDDLE_OFFSET_OFFSET_ADDITION,THICKNESS_BANNER*3+SIZE.y/2-THICKNESS_BANNER/2},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size = {THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS, SIZE.y},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {SIZE.x / 2 + THICKNESS_BANNER / 2 * MIDDLE_OFFSET_FACTOR_OFFSET + MIDDLE_OFFSET_OFFSET_ADDITION, THICKNESS_BANNER * 3 + SIZE.y / 2 - THICKNESS_BANNER / 2},
+ .world_space = false,
+ }
+ );
// Bot_Middle
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/bot_middle_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+7,
- .size = {SIZE.x*MIDDLE_OFFSET_FACTOR_OFFSET*MIDDLE_OFFSET_FACTOR_MIDDLE_WIDTH+data.width_middle_offset,THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS},
- .position_offset = POSITION_CORRECTION + vec2{0,THICKNESS_BANNER*3+SIZE.y+BOTTOM_OFFSET_Y},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 7,
+ .size
+ = {SIZE.x * MIDDLE_OFFSET_FACTOR_OFFSET * MIDDLE_OFFSET_FACTOR_MIDDLE_WIDTH
+ + data.width_middle_offset,
+ THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS},
+ .position_offset
+ = POSITION_CORRECTION + vec2 {0, THICKNESS_BANNER * 3 + SIZE.y + BOTTOM_OFFSET_Y},
+ .world_space = false,
+ }
+ );
// Bot_Left
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/bot_left_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS,THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS},
- .position_offset = POSITION_CORRECTION + vec2{-SIZE.x/2-THICKNESS_BANNER/2-BOTTOM_OFFSET_X,THICKNESS_BANNER*3+SIZE.y+BOTTOM_OFFSET_Y},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size
+ = {THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS,
+ THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {-SIZE.x / 2 - THICKNESS_BANNER / 2 - BOTTOM_OFFSET_X, THICKNESS_BANNER * 3 + SIZE.y + BOTTOM_OFFSET_Y},
+ .world_space = false,
+ }
+ );
// Bot_Right
floatingwindow.add_component<Sprite>(
Asset("asset/ui/settings_container/bot_right_setting.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+8,
- .size = {THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS,THICKNESS_BANNER*MIDDLE_OFFSET_FACTOR_TICKNESS},
- .position_offset = POSITION_CORRECTION + vec2{SIZE.x/2+THICKNESS_BANNER/2+BOTTOM_OFFSET_X,THICKNESS_BANNER*3+SIZE.y+BOTTOM_OFFSET_Y},
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 8,
+ .size
+ = {THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS,
+ THICKNESS_BANNER * MIDDLE_OFFSET_FACTOR_TICKNESS},
+ .position_offset
+ = POSITION_CORRECTION
+ + vec2 {SIZE.x / 2 + THICKNESS_BANNER / 2 + BOTTOM_OFFSET_X, THICKNESS_BANNER * 3 + SIZE.y + BOTTOM_OFFSET_Y},
+ .world_space = false,
+ }
+ );
}
-
-
diff --git a/game/menus/FloatingWindowSubScene.h b/game/menus/FloatingWindowSubScene.h
index a0bd854..7b9de96 100644
--- a/game/menus/FloatingWindowSubScene.h
+++ b/game/menus/FloatingWindowSubScene.h
@@ -1,16 +1,17 @@
#pragma once
-#include "types.h"
#include <crepe/api/Scene.h>
+#include <crepe/types.h>
-class FloatingWindowSubScene {
+class FloatingWindowSubScene {
public:
- struct Data{
+ struct Data {
const std::string group_tag = "";
float width = 200;
- crepe::vec2 offset = {0,0};
+ crepe::vec2 offset = {0, 0};
float width_middle_offset = 0;
};
+
public:
- void create(crepe::Scene & scn,const Data & data);
+ void create(crepe::Scene & scn, const Data & data);
};
diff --git a/game/menus/IButtonScript.cpp b/game/menus/IButtonScript.cpp
index da535ca..34efbd0 100644
--- a/game/menus/IButtonScript.cpp
+++ b/game/menus/IButtonScript.cpp
@@ -2,30 +2,31 @@
#include "system/InputSystem.h"
-#include <crepe/types.h>
#include <crepe/api/Sprite.h>
+#include <crepe/types.h>
using namespace crepe;
using namespace std;
-void IButtonScript::init(){
- this->subscribe<ButtonExitEvent>([this](const ButtonExitEvent& e) { return this->on_button_exit(e); });
- this->subscribe<ButtonEnterEvent>([this](const ButtonEnterEvent& e) { return this->on_button_enter(e); });
+void IButtonScript::init() {
+ this->subscribe<ButtonExitEvent>([this](const ButtonExitEvent & e) {
+ return this->on_button_exit(e);
+ });
+ this->subscribe<ButtonEnterEvent>([this](const ButtonEnterEvent & e) {
+ return this->on_button_enter(e);
+ });
}
-bool IButtonScript::on_button_exit(const ButtonExitEvent& e){
+bool IButtonScript::on_button_exit(const ButtonExitEvent & e) {
RefVector<Sprite> sprites = this->get_components<Sprite>();
- for(Sprite & sprite : sprites)
- {
- sprite.data.color = Color{255,255,255,255};
+ for (Sprite & sprite : sprites) {
+ sprite.data.color = Color {255, 255, 255, 255};
}
return false;
}
-bool IButtonScript::on_button_enter(const ButtonEnterEvent& e){
+bool IButtonScript::on_button_enter(const ButtonEnterEvent & e) {
RefVector<Sprite> sprites = this->get_components<Sprite>();
- for(Sprite & sprite : sprites)
- {
- sprite.data.color = Color{200,200,200,255};
+ for (Sprite & sprite : sprites) {
+ sprite.data.color = Color {200, 200, 200, 255};
}
return false;
}
-
diff --git a/game/menus/IButtonScript.h b/game/menus/IButtonScript.h
index 10b57bf..e45375b 100644
--- a/game/menus/IButtonScript.h
+++ b/game/menus/IButtonScript.h
@@ -5,8 +5,6 @@
class IButtonScript : public virtual crepe::Script {
public:
virtual void init();
- virtual bool on_button_exit(const crepe::ButtonExitEvent& e);
- virtual bool on_button_enter(const crepe::ButtonEnterEvent& e);
+ virtual bool on_button_exit(const crepe::ButtonExitEvent & e);
+ virtual bool on_button_enter(const crepe::ButtonEnterEvent & e);
};
-
-
diff --git a/game/menus/IFloatingWindowScript.cpp b/game/menus/IFloatingWindowScript.cpp
index ce84de7..4b538ef 100644
--- a/game/menus/IFloatingWindowScript.cpp
+++ b/game/menus/IFloatingWindowScript.cpp
@@ -1,23 +1,22 @@
#include "IFloatingWindowScript.h"
-#include "api/Sprite.h"
-#include "types.h"
+
+#include <crepe/api/Sprite.h>
+#include <crepe/types.h>
using namespace crepe;
-void IFloatingWindowScript::init(){
- this->disable_all_sprites();
-}
+void IFloatingWindowScript::init() { this->disable_all_sprites(); }
-void IFloatingWindowScript::disable_all_sprites(){
+void IFloatingWindowScript::disable_all_sprites() {
RefVector<Sprite> sprites = this->get_components_by_tag<Sprite>(this->tag);
- for(Sprite & sprite : sprites){
+ for (Sprite & sprite : sprites) {
sprite.active = false;
}
}
-void IFloatingWindowScript::enable_all_sprites(){
+void IFloatingWindowScript::enable_all_sprites() {
RefVector<Sprite> sprites = this->get_components_by_tag<Sprite>(this->tag);
- for(Sprite & sprite : sprites){
+ for (Sprite & sprite : sprites) {
sprite.active = true;
}
}
diff --git a/game/menus/IFloatingWindowScript.h b/game/menus/IFloatingWindowScript.h
index 9775726..e39378f 100644
--- a/game/menus/IFloatingWindowScript.h
+++ b/game/menus/IFloatingWindowScript.h
@@ -1,6 +1,7 @@
#pragma once
#include <crepe/api/Script.h>
+
#include <string>
class IFloatingWindowScript : public virtual crepe::Script {
@@ -8,8 +9,7 @@ public:
virtual void init();
void disable_all_sprites();
void enable_all_sprites();
+
protected:
std::string tag = "";
};
-
-
diff --git a/game/menus/MenusConfig.h b/game/menus/MenusConfig.h
index 8d3672e..24b60e8 100644
--- a/game/menus/MenusConfig.h
+++ b/game/menus/MenusConfig.h
@@ -4,13 +4,13 @@
//generic menu config
static constexpr int STARTING_SORTING_IN_LAYER = 7;
//Scene names
-static constexpr const char* START_SCENE = "scene1";
-static constexpr const char* PREVIEW_SCENE = "scene1";
-static constexpr const char* SHOP_SCENE = "shopmenu";
-static constexpr const char* MAINMENU_SCENE = "mainmenu";
+static constexpr const char * START_SCENE = "scene1";
+static constexpr const char * PREVIEW_SCENE = "scene1";
+static constexpr const char * SHOP_SCENE = "shopmenu";
+static constexpr const char * MAINMENU_SCENE = "mainmenu";
//button config
-static constexpr crepe::vec2 LARGE_OVERLAY_SIZE = {250,100};
-static constexpr crepe::vec2 SMALL_OVERLAY_SIZE_RIGHT = {150,100};
-static constexpr crepe::vec2 SMALL_OVERLAY_SIZE_LEFT = {50,100};
-static constexpr crepe::vec2 SIDE_PANEL_SIZE = {50,150};
-static constexpr crepe::vec2 ICON_SIZE = {50,50};
+static constexpr crepe::vec2 LARGE_OVERLAY_SIZE = {250, 100};
+static constexpr crepe::vec2 SMALL_OVERLAY_SIZE_RIGHT = {150, 100};
+static constexpr crepe::vec2 SMALL_OVERLAY_SIZE_LEFT = {50, 100};
+static constexpr crepe::vec2 SIDE_PANEL_SIZE = {50, 150};
+static constexpr crepe::vec2 ICON_SIZE = {50, 50};
diff --git a/game/menus/endgame/EndGameSubScene.cpp b/game/menus/endgame/EndGameSubScene.cpp
index 41556af..3ef0f9a 100644
--- a/game/menus/endgame/EndGameSubScene.cpp
+++ b/game/menus/endgame/EndGameSubScene.cpp
@@ -1,19 +1,22 @@
#include "EndGameSubScene.h"
-#include "../FloatingWindowSubScene.h"
+#include "EndGameSubScript.h"
+
+#include "../../Config.h"
#include "../ButtonSubScene.h"
-#include <crepe/api/Text.h>
+#include "../FloatingWindowSubScene.h"
+
#include <string>
-#include <crepe/api/GameObject.h>
+
#include <crepe/api/BehaviorScript.h>
-#include "EndGameSubScript.h"
-#include "types.h"
-#include "../../Config.h"
+#include <crepe/api/GameObject.h>
+#include <crepe/api/Text.h>
+#include <crepe/types.h>
using namespace crepe;
using namespace std;
-void EndGameSubScene::create(Scene & scn){
+void EndGameSubScene::create(Scene & scn) {
const std::string TAG = "end_game_tag";
GameObject script = scn.new_object("script");
@@ -21,50 +24,59 @@ void EndGameSubScene::create(Scene & scn){
// Window
FloatingWindowSubScene window;
- window.create(scn, FloatingWindowSubScene::Data{
- .group_tag = TAG,
- .width = 500,
- .offset = {0,-50},
- .width_middle_offset = -2,
- });
+ window.create(
+ scn,
+ FloatingWindowSubScene::Data {
+ .group_tag = TAG,
+ .width = 500,
+ .offset = {0, -50},
+ .width_middle_offset = -2,
+ }
+ );
// Titel
const string TITEL_STRING = "GAME OVER";
- GameObject titel = scn.new_object("titel",TAG);
- crepe::vec2 size = {200,(200.0f/TITEL_STRING.size())*2};
- titel.add_component<Text>(size, FONT,Text::Data{
- .world_space = false,
- .text_color = Color::WHITE,
- }, vec2{0,-207}+FONTOFFSET, TITEL_STRING);
-
+ GameObject titel = scn.new_object("titel", TAG);
+ crepe::vec2 size = {200, (200.0f / TITEL_STRING.size()) * 2};
+ titel.add_component<Text>(
+ size, FONT,
+ Text::Data {
+ .world_space = false,
+ .text_color = Color::WHITE,
+ },
+ vec2 {0, -207} + FONTOFFSET, TITEL_STRING
+ );
// Buttons
- vec2 button_position = {190,190};
+ vec2 button_position = {190, 190};
ButtonSubScene button;
- button.create(scn,ButtonSubScene::Data{
- .text = "NEXT",
- .text_width = 100,
- .position = button_position,
- .script_type = ButtonSubScene::ScriptSelect::MAINMENU,
- .button_type = ButtonSubScene::ButtonSelect::NEXT,
- .scale = 0.6,
- .worldspace = false,
- .tag = TAG,
- .sorting_layer_offset = 20,
- });
-
- button.create(scn,ButtonSubScene::Data{
- .text = "REPLAY",
- .text_width = 150,
- .position = {-button_position.x,button_position.y},
- // .script_type = ButtonSubScene::ScriptSelect::MAINMENU,
- .button_type = ButtonSubScene::ButtonSelect::BACK,
- .scale = 0.6,
- .worldspace = false,
- .tag = TAG,
- .sorting_layer_offset = 20,
- });
+ button.create(
+ scn,
+ ButtonSubScene::Data {
+ .text = "NEXT",
+ .text_width = 100,
+ .position = button_position,
+ .script_type = ButtonSubScene::ScriptSelect::NEXT,
+ .button_type = ButtonSubScene::ButtonSelect::NEXT,
+ .scale = 0.6,
+ .worldspace = false,
+ .tag = TAG,
+ .sorting_layer_offset = 20,
+ }
+ );
+ button.create(
+ scn,
+ ButtonSubScene::Data {
+ .text = "REPLAY",
+ .text_width = 150,
+ .position = {-button_position.x, button_position.y},
+ // .script_type = ButtonSubScene::ScriptSelect::MAINMENU,
+ .button_type = ButtonSubScene::ButtonSelect::BACK,
+ .scale = 0.6,
+ .worldspace = false,
+ .tag = TAG,
+ .sorting_layer_offset = 20,
+ }
+ );
}
-
-
diff --git a/game/menus/endgame/EndGameSubScene.h b/game/menus/endgame/EndGameSubScene.h
index aa60a49..204f3b7 100644
--- a/game/menus/endgame/EndGameSubScene.h
+++ b/game/menus/endgame/EndGameSubScene.h
@@ -2,7 +2,7 @@
#include <crepe/api/Scene.h>
-class EndGameSubScene {
+class EndGameSubScene {
public:
void create(crepe::Scene & scn);
diff --git a/game/menus/endgame/EndGameSubScript.cpp b/game/menus/endgame/EndGameSubScript.cpp
index 2be6931..f120e2d 100644
--- a/game/menus/endgame/EndGameSubScript.cpp
+++ b/game/menus/endgame/EndGameSubScript.cpp
@@ -1,51 +1,54 @@
#include "EndGameSubScript.h"
-#include "../IFloatingWindowScript.h"
-#include "api/Button.h"
-#include "api/Sprite.h"
-#include "api/Text.h"
-#include "types.h"
+
#include "../../Events.h"
+#include "../IFloatingWindowScript.h"
+
#include <string>
+#include <crepe/api/Button.h>
+#include <crepe/api/Sprite.h>
+#include <crepe/api/Text.h>
+#include <crepe/types.h>
+
using namespace crepe;
-EndGameSubScript::EndGameSubScript(const std::string & tag){
- this->tag = tag;
-}
+EndGameSubScript::EndGameSubScript(const std::string & tag) { this->tag = tag; }
-void EndGameSubScript::init(){
+void EndGameSubScript::init() {
this->disable_all();
this->subscribe<EndGameEvent>([this](const EndGameEvent e) { return this->enable_all(); });
- this->subscribe<EndGameEvent>([this](const EndGameEvent e) { return this->reset_timescale(); });
+ this->subscribe<EndGameEvent>([this](const EndGameEvent e) {
+ return this->reset_timescale();
+ });
}
-bool EndGameSubScript::disable_all(){
+bool EndGameSubScript::disable_all() {
IFloatingWindowScript::disable_all_sprites();
RefVector<Button> buttons = this->get_components_by_tag<Button>(this->tag);
- for(Button & button : buttons){
+ for (Button & button : buttons) {
button.active = false;
}
RefVector<Text> texts = this->get_components_by_tag<Text>(this->tag);
- for(Text & text : texts){
+ for (Text & text : texts) {
text.active = false;
}
return false;
}
-bool EndGameSubScript::enable_all(){
+bool EndGameSubScript::enable_all() {
IFloatingWindowScript::enable_all_sprites();
RefVector<Button> buttons = this->get_components_by_tag<Button>(this->tag);
- for(Button & button : buttons){
+ for (Button & button : buttons) {
button.active = true;
}
RefVector<Text> texts = this->get_components_by_tag<Text>(this->tag);
- for(Text & text : texts){
+ for (Text & text : texts) {
text.active = true;
}
return false;
}
-bool EndGameSubScript::reset_timescale(){
+bool EndGameSubScript::reset_timescale() {
this->get_loop_timer().set_time_scale(1);
return false;
}
diff --git a/game/menus/endgame/EndGameSubScript.h b/game/menus/endgame/EndGameSubScript.h
index 2ce3ec7..62a2f0c 100644
--- a/game/menus/endgame/EndGameSubScript.h
+++ b/game/menus/endgame/EndGameSubScript.h
@@ -1,16 +1,15 @@
#pragma once
#include "../IFloatingWindowScript.h"
-#include "api/Event.h"
+
+#include <crepe/api/Event.h>
#include <crepe/api/Script.h>
class EndGameSubScript : public IFloatingWindowScript {
public:
EndGameSubScript(const std::string & tag);
- void init() override;
+ void init() override;
bool disable_all();
bool enable_all();
bool reset_timescale();
};
-
-
diff --git a/game/menus/mainmenu/ButtonTransitionPreviewScript.cpp b/game/menus/mainmenu/ButtonTransitionPreviewScript.cpp
deleted file mode 100644
index 084d02b..0000000
--- a/game/menus/mainmenu/ButtonTransitionPreviewScript.cpp
+++ /dev/null
@@ -1,21 +0,0 @@
-#include "ButtonTransitionPreviewScript.h"
-
-#include "../MenusConfig.h"
-
-using namespace crepe;
-using namespace std;
-
-void ButtonTransitionPreviewScript::init(){
- IButtonScript::init();
- this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent& e) { return this->on_button_press(e); });
-}
-
-bool ButtonTransitionPreviewScript::on_button_press(const ButtonPressEvent& e){
- if(!this->transition) this->transition = true;
- return false;
-}
-
-const char* ButtonTransitionPreviewScript::get_scene_name() const {
- // Provide the next scene defined in MainMenuConfig
- return PREVIEW_SCENE;
-}
diff --git a/game/menus/mainmenu/ButtonTransitionPreviewScript.h b/game/menus/mainmenu/ButtonTransitionPreviewScript.h
deleted file mode 100644
index 5973dbf..0000000
--- a/game/menus/mainmenu/ButtonTransitionPreviewScript.h
+++ /dev/null
@@ -1,12 +0,0 @@
-#pragma once
-
-#include "ITransitionScript.h"
-
-#include "../IButtonScript.h"
-
-class ButtonTransitionPreviewScript : public ITransitionScript, public IButtonScript {
-public:
- void init() override;
- bool on_button_press(const crepe::ButtonPressEvent& e);
- const char* get_scene_name() const override;
-};
diff --git a/game/menus/mainmenu/ButtonTransitionPreviewSubScript.cpp b/game/menus/mainmenu/ButtonTransitionPreviewSubScript.cpp
new file mode 100644
index 0000000..4c4dfc1
--- /dev/null
+++ b/game/menus/mainmenu/ButtonTransitionPreviewSubScript.cpp
@@ -0,0 +1,23 @@
+#include "ButtonTransitionPreviewSubScript.h"
+
+#include "../MenusConfig.h"
+
+using namespace crepe;
+using namespace std;
+
+void ButtonTransitionPreviewSubScript::init() {
+ IButtonScript::init();
+ this->subscribe<ButtonPressEvent>([this](const ButtonPressEvent & e) {
+ return this->on_button_press(e);
+ });
+}
+
+bool ButtonTransitionPreviewSubScript::on_button_press(const ButtonPressEvent & e) {
+ if (!this->transition) this->transition = true;
+ return false;
+}
+
+const char * ButtonTransitionPreviewSubScript::get_scene_name() const {
+ // Provide the next scene defined in MainMenuConfig
+ return PREVIEW_SCENE;
+}
diff --git a/game/menus/mainmenu/ButtonTransitionPreviewSubScript.h b/game/menus/mainmenu/ButtonTransitionPreviewSubScript.h
new file mode 100644
index 0000000..d6d8149
--- /dev/null
+++ b/game/menus/mainmenu/ButtonTransitionPreviewSubScript.h
@@ -0,0 +1,12 @@
+#pragma once
+
+#include "ITransitionScript.h"
+
+#include "../IButtonScript.h"
+
+class ButtonTransitionPreviewSubScript : public ITransitionScript, public IButtonScript {
+public:
+ void init() override;
+ bool on_button_press(const crepe::ButtonPressEvent & e);
+ const char * get_scene_name() const override;
+};
diff --git a/game/menus/mainmenu/ITransitionScript.cpp b/game/menus/mainmenu/ITransitionScript.cpp
index e2974d4..3e51a90 100644
--- a/game/menus/mainmenu/ITransitionScript.cpp
+++ b/game/menus/mainmenu/ITransitionScript.cpp
@@ -4,30 +4,27 @@
#include "../MenusConfig.h"
#include "../../Config.h"
-#include <crepe/types.h>
-#include <crepe/api/Transform.h>
#include <crepe/api/Camera.h>
+#include <crepe/api/Transform.h>
+#include <crepe/types.h>
using namespace crepe;
using namespace std;
-void ITransitionScript::frame_update(crepe::duration_t delta_time){
- if(this->transition)
- {
+void ITransitionScript::frame_update(crepe::duration_t delta_time) {
+ if (this->transition) {
// cout << "transition:" << velocity << std::endl;
Transform & cam = this->get_components_by_name<Transform>(CAMERA_NAME).front();
RefVector<Transform> info_tf = this->get_components_by_tag<Transform>(MENU_INFO_TAG);
for (Transform & tf : info_tf) {
tf.position.y -= VELOCITY_INFO_UP * delta_time.count();
}
- if(velocity < VELOCITY_MAX && cam.position.x < SLOW_DOWN) velocity += VELOCITY_STEP * delta_time.count();
- else if(velocity > 20) velocity -= VELOCITY_STEP * delta_time.count();
- if(cam.position.x < END) cam.position.x += (velocity * delta_time.count());
- if(cam.position.x >= END)
- {
+ if (velocity < VELOCITY_MAX && cam.position.x < SLOW_DOWN)
+ velocity += VELOCITY_STEP * delta_time.count();
+ else if (velocity > 20) velocity -= VELOCITY_STEP * delta_time.count();
+ if (cam.position.x < END) cam.position.x += (velocity * delta_time.count());
+ if (cam.position.x >= END) {
this->set_next_scene(this->get_scene_name());
}
-
}
}
-
diff --git a/game/menus/mainmenu/ITransitionScript.h b/game/menus/mainmenu/ITransitionScript.h
index 78f1016..9a2ef90 100644
--- a/game/menus/mainmenu/ITransitionScript.h
+++ b/game/menus/mainmenu/ITransitionScript.h
@@ -5,9 +5,11 @@
class ITransitionScript : public virtual crepe::Script {
public:
void frame_update(crepe::duration_t delta_time) override;
- virtual const char* get_scene_name() const = 0;
+ virtual const char * get_scene_name() const = 0;
+
private:
float velocity = 20;
+
protected:
bool transition = false;
};
diff --git a/game/menus/mainmenu/MainMenuConfig.h b/game/menus/mainmenu/MainMenuConfig.h
index 01995f0..f4ca5a6 100644
--- a/game/menus/mainmenu/MainMenuConfig.h
+++ b/game/menus/mainmenu/MainMenuConfig.h
@@ -3,20 +3,17 @@
//main menu config
static constexpr float STARTMAP_OFFSET = 50;
-static constexpr crepe::vec2 MENU_OFFSET = {0,0};
+static constexpr crepe::vec2 MENU_OFFSET = {0, 0};
static constexpr float MENU_BUTTON_SPACING = 10;
-static constexpr const char* MENU_BUTTON_NAME = "menu_button_background";
-static constexpr crepe::vec2 MENU_OFFSET_BUTTON = {-400,-200};
-static constexpr crepe::vec2 MENU_OFFSET_BUTTON_BACKGROUND = {-400,0};
-static constexpr const char* MENU_INFO_TAG = "menu_info";
-static constexpr crepe::vec2 MENU_OFFSET_INFO = {350,-365};
-static constexpr crepe::vec2 MENU_OFFSET_INFO_BACKGROUND = {350,-365}; //375
+static constexpr const char * MENU_BUTTON_NAME = "menu_button_background";
+static constexpr crepe::vec2 MENU_OFFSET_BUTTON = {-400, -200};
+static constexpr crepe::vec2 MENU_OFFSET_BUTTON_BACKGROUND = {-400, 0};
+static constexpr const char * MENU_INFO_TAG = "menu_info";
+static constexpr crepe::vec2 MENU_OFFSET_INFO = {350, -365};
+static constexpr crepe::vec2 MENU_OFFSET_INFO_BACKGROUND = {350, -365}; //375
//Moving to new scene (Start and Preview)
static constexpr float SLOW_DOWN = 200;
static constexpr float END = 300;
static constexpr float VELOCITY_MAX = 200;
static constexpr float VELOCITY_STEP = 200;
static constexpr float VELOCITY_INFO_UP = 40;
-
-
-
diff --git a/game/menus/mainmenu/MainMenuScene.cpp b/game/menus/mainmenu/MainMenuScene.cpp
index 15cf6d5..43418e3 100644
--- a/game/menus/mainmenu/MainMenuScene.cpp
+++ b/game/menus/mainmenu/MainMenuScene.cpp
@@ -1,104 +1,115 @@
#include "MainMenuScene.h"
-#include "TransitionStartScript.h"
#include "MainMenuConfig.h"
+#include "TransitionStartSubScript.h"
#include "../ButtonSubScene.h"
#include "../MenusConfig.h"
-#include "../../background/StartSubScene.h"
-#include "../../background/HallwaySubScene.h"
#include "../../Config.h"
+#include "../../background/HallwaySubScene.h"
+#include "../../background/StartSubScene.h"
#include "../endgame/EndGameSubScene.h"
#include <crepe/api/BehaviorScript.h>
+#include <crepe/api/Camera.h>
#include <crepe/api/GameObject.h>
#include <crepe/api/Sprite.h>
-#include <crepe/api/Camera.h>
#include <crepe/manager/SaveManager.h>
using namespace crepe;
using namespace std;
-void MainMenuScene::load_scene(){
+void MainMenuScene::load_scene() {
ButtonSubScene button;
GameObject camera_object = this->new_object(CAMERA_NAME);
- camera_object.add_component<Camera>(ivec2(990, 720), vec2(1100, 800),
- Camera::Data{
- .bg_color = Color::RED,
- });
- camera_object.add_component<BehaviorScript>().set_script<TransitionStartScript>();
-
+ camera_object.add_component<Camera>(
+ ivec2(990, 720), vec2(1100, 800),
+ Camera::Data {
+ .bg_color = Color::RED,
+ }
+ );
+ camera_object.add_component<BehaviorScript>().set_script<TransitionStartSubScript>();
//Button menu
- GameObject menu_button = this->new_object(MENU_BUTTON_NAME,MENU_BUTTON_NAME,MENU_OFFSET);
+ GameObject menu_button = this->new_object(MENU_BUTTON_NAME, MENU_BUTTON_NAME, MENU_OFFSET);
menu_button.add_component<Sprite>(
Asset("asset/ui/background.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+0,
- .size = {300,860},
- .position_offset = MENU_OFFSET_BUTTON_BACKGROUND,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 0,
+ .size = {300, 860},
+ .position_offset = MENU_OFFSET_BUTTON_BACKGROUND,
+ }
+ );
vec2 pos_btn = MENU_OFFSET_BUTTON;
-
+
//Preview btn
- button.create(*this,ButtonSubScene::Data{
- .text = "PREVIEW",
- .text_width = 200,
- .position = pos_btn,
- .script_type = ButtonSubScene::ScriptSelect::PREVIEW,
- });
+ button.create(
+ *this,
+ ButtonSubScene::Data {
+ .text = "PREVIEW",
+ .text_width = 200,
+ .position = pos_btn,
+ .script_type = ButtonSubScene::ScriptSelect::PREVIEW,
+ }
+ );
//Shop btn
pos_btn.y += MENU_BUTTON_SPACING + LARGE_OVERLAY_SIZE.y;
- button.create(*this,ButtonSubScene::Data{
- .text = "SHOP",
- .text_offset = {-20,0},
- .text_width = 115,
- .icon_offset = {60,0},
- .icon_type = ButtonSubScene::IconSelect::SHOP,
- .position = pos_btn,
- .script_type = ButtonSubScene::ScriptSelect::SHOP,
- });
-
+ button.create(
+ *this,
+ ButtonSubScene::Data {
+ .text = "SHOP",
+ .text_offset = {-20, 0},
+ .text_width = 115,
+ .icon_offset = {60, 0},
+ .icon_type = ButtonSubScene::IconSelect::SHOP,
+ .position = pos_btn,
+ .script_type = ButtonSubScene::ScriptSelect::SHOP,
+ }
+ );
+
//Start of map
StartSubScene start;
HallwaySubScene hallway;
float begin_x = start.create(*this, STARTMAP_OFFSET);
begin_x = hallway.create(*this, begin_x, 1, Color::YELLOW);
-
//INFO menu
- GameObject menu_info = this->new_object("MENU_INFO_BACKGROUND",MENU_INFO_TAG,MENU_OFFSET);
+ GameObject menu_info
+ = this->new_object("MENU_INFO_BACKGROUND", MENU_INFO_TAG, MENU_OFFSET);
menu_info.add_component<Sprite>(
Asset("asset/ui/itemsButtonBlankDark.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+0,
- .size = {250,80},
- .position_offset = MENU_OFFSET_INFO,
- .world_space = false,
- });
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 0,
+ .size = {250, 80},
+ .position_offset = MENU_OFFSET_INFO,
+ .world_space = false,
+ }
+ );
SaveManager & savemgr = this->get_save_manager();
- string number = std::to_string(savemgr.get<int>(TOTAL_COINS_GAME,0).get());
+ string number = std::to_string(savemgr.get<int>(TOTAL_COINS_GAME, 0).get());
float amount_number = static_cast<float>(number.size());
// savemgr.set(COIN_GAME_AMOUNT, amount);
- button.create(*this,ButtonSubScene::Data{
- .text = number,
- .text_offset = {-10-(amount_number-1)*10,0},
- .text_width = amount_number*20,
- .icon_offset = {60,0},
- .icon_type = ButtonSubScene::IconSelect::COINS,
- .position = MENU_OFFSET_INFO,
- .script_type = ButtonSubScene::ScriptSelect::SHOP,
- .scale = 0.6,
- .worldspace = false,
- .color_side = false,
- .tag = MENU_INFO_TAG,
- });
-
+ button.create(
+ *this,
+ ButtonSubScene::Data {
+ .text = number,
+ .text_offset = {-10 - (amount_number - 1) * 10, 0},
+ .text_width = amount_number * 20,
+ .icon_offset = {60, 0},
+ .icon_type = ButtonSubScene::IconSelect::COINS,
+ .position = MENU_OFFSET_INFO,
+ .script_type = ButtonSubScene::ScriptSelect::SHOP,
+ .scale = 0.6,
+ .worldspace = false,
+ .color_side = false,
+ .tag = MENU_INFO_TAG,
+ }
+ );
}
string MainMenuScene::get_name() const { return MAINMENU_SCENE; }
diff --git a/game/menus/mainmenu/TransitionStartScript.cpp b/game/menus/mainmenu/TransitionStartScript.cpp
deleted file mode 100644
index 9b395de..0000000
--- a/game/menus/mainmenu/TransitionStartScript.cpp
+++ /dev/null
@@ -1,15 +0,0 @@
-#include "TransitionStartScript.h"
-
-#include "../MenusConfig.h"
-
-using namespace crepe;
-using namespace std;
-
-void TransitionStartScript::fixed_update(crepe::duration_t dt){
- if(this->get_key_state(Keycode::ENTER) && this->transition == false) this->transition = true;
-}
-
-const char* TransitionStartScript::get_scene_name() const {
- // Provide the next scene defined in MainMenuConfig
- return START_SCENE;
-}
diff --git a/game/menus/mainmenu/TransitionStartSubScript.cpp b/game/menus/mainmenu/TransitionStartSubScript.cpp
new file mode 100644
index 0000000..63723cf
--- /dev/null
+++ b/game/menus/mainmenu/TransitionStartSubScript.cpp
@@ -0,0 +1,16 @@
+#include "TransitionStartSubScript.h"
+
+#include "../MenusConfig.h"
+
+using namespace crepe;
+using namespace std;
+
+void TransitionStartSubScript::fixed_update(crepe::duration_t dt) {
+ if (this->get_key_state(Keycode::ENTER) && this->transition == false)
+ this->transition = true;
+}
+
+const char * TransitionStartSubScript::get_scene_name() const {
+ // Provide the next scene defined in MainMenuConfig
+ return START_SCENE;
+}
diff --git a/game/menus/mainmenu/TransitionStartScript.h b/game/menus/mainmenu/TransitionStartSubScript.h
index c6df1b9..f9862ea 100644
--- a/game/menus/mainmenu/TransitionStartScript.h
+++ b/game/menus/mainmenu/TransitionStartSubScript.h
@@ -2,8 +2,8 @@
#include "ITransitionScript.h"
-class TransitionStartScript : public ITransitionScript {
+class TransitionStartSubScript : public ITransitionScript {
public:
void fixed_update(crepe::duration_t dt) override;
- const char* get_scene_name() const override;
+ const char * get_scene_name() const override;
};
diff --git a/game/menus/shop/ShopMenuScene.cpp b/game/menus/shop/ShopMenuScene.cpp
index 5d1348f..f4d5e76 100644
--- a/game/menus/shop/ShopMenuScene.cpp
+++ b/game/menus/shop/ShopMenuScene.cpp
@@ -1,6 +1,7 @@
#include "ShopMenuScene.h"
+#include "../BannerSubScene.h"
#include "../ButtonSubScene.h"
#include "../MenusConfig.h"
#include "../BannerSubScene.h"
@@ -12,36 +13,45 @@
using namespace crepe;
using namespace std;
-void ShopMenuScene::load_scene(){
+void ShopMenuScene::load_scene() {
GameObject camera_object = this->new_object(CAMERA_NAME);
- camera_object.add_component<Camera>(ivec2(990, 720), vec2(1100, 800),
- Camera::Data{
- .bg_color = Color::RED,
- });
+ camera_object.add_component<Camera>(
+ ivec2(990, 720), vec2(1100, 800),
+ Camera::Data {
+ .bg_color = Color::RED,
+ }
+ );
BannerSubScene banner;
- banner.create(*this,{
- .banner_title = "SHOP",
- .banner_title_width = 200,
- .banner_title_offset = {0,65},
- });
+ banner.create(
+ *this,
+ {
+ .banner_title = "SHOP",
+ .banner_title_width = 200,
+ .banner_title_offset = {0, 65},
+ }
+ );
GameObject menu_background = this->new_object("menu_background");
menu_background.add_component<Sprite>(
Asset("asset/ui/background.png"),
- Sprite::Data{
- .sorting_in_layer = STARTING_SORTING_IN_LAYER+0,
- .size = {1100,860},
- .position_offset {0},
- });
-
+ Sprite::Data {
+ .sorting_in_layer = STARTING_SORTING_IN_LAYER + 0,
+ .size = {1100, 860},
+ .position_offset {0},
+ }
+ );
+
ButtonSubScene button;
- button.create(*this,ButtonSubScene::Data{
- .text = "BACK",
- .text_width = 115,
- .position = {-400,-350},
- .script_type = ButtonSubScene::ScriptSelect::MAINMENU,
- .button_type = ButtonSubScene::ButtonSelect::BACK,
- .scale = 0.8
- });
+ button.create(
+ *this,
+ ButtonSubScene::Data {
+ .text = "BACK",
+ .text_width = 115,
+ .position = {-400, -350},
+ .script_type = ButtonSubScene::ScriptSelect::MAINMENU,
+ .button_type = ButtonSubScene::ButtonSelect::BACK,
+ .scale = 0.8
+ }
+ );
}
string ShopMenuScene::get_name() const { return SHOP_SCENE; }