diff options
-rw-r--r-- | game/CMakeLists.txt | 2 | ||||
-rw-r--r-- | game/coins/CoinScript.cpp | 19 | ||||
-rw-r--r-- | game/coins/CoinScript.h | 10 | ||||
-rw-r--r-- | game/coins/CoinSubScene.cpp | 6 | ||||
-rw-r--r-- | game/coins/CoinSystemScript.cpp | 78 | ||||
-rw-r--r-- | game/coins/CoinSystemScript.h | 28 | ||||
-rw-r--r-- | game/mainmenu/BannerSubScene.cpp | 6 | ||||
-rw-r--r-- | game/mainmenu/BannerSubScene.h | 9 | ||||
-rw-r--r-- | game/mainmenu/ShopMenuScene.cpp | 6 |
9 files changed, 98 insertions, 66 deletions
diff --git a/game/CMakeLists.txt b/game/CMakeLists.txt index c27dcc1..fbbe901 100644 --- a/game/CMakeLists.txt +++ b/game/CMakeLists.txt @@ -35,6 +35,7 @@ set(SOURCES coins/CoinSubScene.cpp coins/CoinPool.cpp coins/CoinSystemScript.cpp + coins/CoinScript.cpp ) set(HEADERS @@ -64,6 +65,7 @@ set(HEADERS coins/CoinSubScene.h coins/CoinPool.h coins/CoinSystemScript.h + coins/CoinScript.h ) add_executable(main ${SOURCES} ${HEADERS}) diff --git a/game/coins/CoinScript.cpp b/game/coins/CoinScript.cpp new file mode 100644 index 0000000..f067f04 --- /dev/null +++ b/game/coins/CoinScript.cpp @@ -0,0 +1,19 @@ +#include "CoinScript.h" +#include "api/CircleCollider.h" +#include "api/Sprite.h" + +using namespace crepe; +using namespace std; + +bool CoinScript::on_collision(const CollisionEvent & collisionData){ + if(collisionData.info.other.metadata.name != PLAYER_NAME) return true; + //collide with player + this->get_component<Sprite>().active = false; + this->get_component<CircleCollider>().active = false; + return true; +} + +void CoinScript::init(){ + subscribe<CollisionEvent>([this](const CollisionEvent & ev) -> bool { return this->on_collision(ev); }); +} + diff --git a/game/coins/CoinScript.h b/game/coins/CoinScript.h new file mode 100644 index 0000000..6c52733 --- /dev/null +++ b/game/coins/CoinScript.h @@ -0,0 +1,10 @@ +#pragma once + +#include "api/Script.h" + +class CoinScript : public crepe::Script { +public: + void init() override; + bool on_collision(const crepe::CollisionEvent & collisionData); + static constexpr const char* PLAYER_NAME = "player"; +}; diff --git a/game/coins/CoinSubScene.cpp b/game/coins/CoinSubScene.cpp index 0a1cd68..d30f5a4 100644 --- a/game/coins/CoinSubScene.cpp +++ b/game/coins/CoinSubScene.cpp @@ -1,11 +1,13 @@ #include "CoinSubScene.h" #include "api/Animator.h" +#include "api/BehaviorScript.h" #include "api/CircleCollider.h" #include "api/Rigidbody.h" #include "api/Scene.h" #include "api/AudioSource.h" #include <concepts> #include <iostream> +#include "CoinScript.h" using namespace crepe; using namespace std; @@ -19,7 +21,8 @@ int CoinSubScene::create(Scene & scn){ GameObject coin = scn.new_object(unique_name.c_str(),"coin",vec2{650,0},0,1); coin.add_component<Rigidbody>(Rigidbody::Data{ - .body_type = Rigidbody::BodyType::KINEMATIC + .body_type = Rigidbody::BodyType::KINEMATIC, + .kinematic_collision = false, }); coin.add_component<CircleCollider>(size.x / 2).active = false; crepe::OptionalRef<crepe::Sprite> coin_sprite = coin.add_component<Sprite>(Asset{"asset/coin/coin1_TVOS.png"}, Sprite::Data{ @@ -34,5 +37,6 @@ int CoinSubScene::create(Scene & scn){ .looping = true, }); coin.add_component<AudioSource>(Asset{"asset/sfx/coin_pickup_1.ogg"}); + coin.add_component<BehaviorScript>().set_script<CoinScript>(); return coin_counter; } diff --git a/game/coins/CoinSystemScript.cpp b/game/coins/CoinSystemScript.cpp index b28dab1..41b1d3d 100644 --- a/game/coins/CoinSystemScript.cpp +++ b/game/coins/CoinSystemScript.cpp @@ -4,6 +4,8 @@ #include "api/Metadata.h" #include "api/Sprite.h" #include "api/Transform.h" +#include <random> +#include "iostream" using namespace crepe; using namespace std; @@ -11,22 +13,13 @@ using namespace std; std::vector<CoinData> CoinSystemScript::coin_locations; void CoinSystemScript::init() { - float position = 1200; - // position += this->preset_1({position,0}); - // position += 100; - // position += this->preset_2({position,0}); - // position += 100; - position += this->preset_5({position,0}); + engine.seed(rd()); } - - - void CoinSystemScript::add_location(const crepe::vec2& location){ coin_locations.push_back(CoinData(location)); } - float CoinSystemScript::preset_1(const vec2 & begin_position){ vec2 top = {begin_position.x, begin_position.y - (this->ROW_OFFSET_1)}; vec2 bottom = {begin_position.x, begin_position.y + (this->ROW_OFFSET_1)}; @@ -147,51 +140,9 @@ float CoinSystemScript::preset_4(const vec2 & begin_position){ float CoinSystemScript::preset_5(const vec2 & begin_position){ vec2 location = {begin_position.x, begin_position.y-ROW_OFFSET_5/2}; - float locationx = 0; - for (int i = 0; i < 2; ++i) { - // Add locations for the top row - location.y -= ROW_OFFSET_5*6; - for (int i = 0; i < COLUM_AMOUNT_5; ++i) { - add_location(location); - location.x += this->COLUM_OFFSET_5; - } - location.x = begin_position.x; - location.y += ROW_OFFSET_5; - for (int i = 0; i < COLUM_AMOUNT_5; ++i) { - add_location(location); - location.x += this->COLUM_OFFSET_5; - } - - - // Add locations for the middle row - location.x = begin_position.x + COLUM_OFFSET_5*COLUM_AMOUNT_5*2; - location.y += ROW_OFFSET_5*6; - for (int i = 0; i < COLUM_AMOUNT_5; ++i) { - add_location(location); - location.x += this->COLUM_OFFSET_5; - } - location.x = begin_position.x + COLUM_OFFSET_5*COLUM_AMOUNT_5*2; - location.y += ROW_OFFSET_5; - for (int i = 0; i < COLUM_AMOUNT_5; ++i) { - add_location(location); - location.x += this->COLUM_OFFSET_5; - } - locationx = location.x; - - // Add locations for the bottom row - location.x = begin_position.x; - location.y += ROW_OFFSET_5*6; - for (int i = 0; i < COLUM_AMOUNT_5; ++i) { - add_location(location); - location.x += this->COLUM_OFFSET_5; - } - location.x = begin_position.x; - location.y += ROW_OFFSET_5; - for (int i = 0; i < COLUM_AMOUNT_5; ++i) { - add_location(location); - location.x += this->COLUM_OFFSET_5; - } - location.x = locationx + COLUM_OFFSET_5; + for (int i = 0; i < COLUM_AMOUNT_5; ++i){ + add_location(location); + location.x += this->COLUM_OFFSET_5; } return location.x-begin_position.x; } @@ -201,6 +152,7 @@ float CoinSystemScript::preset_5(const vec2 & begin_position){ void CoinSystemScript::frame_update(crepe::duration_t dt) { this->despawn_coins(); + this->generate_locations(); this->spawn_coins(); } @@ -278,7 +230,23 @@ void CoinSystemScript::spawn_coins(){ } } +void CoinSystemScript::generate_locations(){ + float position = this->get_component<Transform>().position.x; + if(position + SPAWN_DISTANCE + SYSTEM_POSITION_OFFSET < this->system_position) return; + std::discrete_distribution<int> dist(weights.begin(), weights.end()); + int selected_index = dist(engine); + + std::uniform_real_distribution<float> space_dist(SPAWN_SPACING_MIN, SPAWN_SPACING_MAX); + float spacing = space_dist(engine); + + + cout << "selected " << selected_index << std::endl; + cout << "spacing " << spacing << std::endl; + // Call the corresponding function and return the new x position + this->system_position += functions[selected_index]({this->system_position,0}); + this->system_position += spacing; +} diff --git a/game/coins/CoinSystemScript.h b/game/coins/CoinSystemScript.h index 8dcd793..51739d6 100644 --- a/game/coins/CoinSystemScript.h +++ b/game/coins/CoinSystemScript.h @@ -5,6 +5,7 @@ #include "api/Script.h" #include "api/Sprite.h" #include "api/Transform.h" +#include <random> class CoinSystemScript : public crepe::Script { public: @@ -15,12 +16,28 @@ private: void add_location(const crepe::vec2& location); void despawn_coins(); void spawn_coins(); + void generate_locations(); float preset_1(const crepe::vec2 & begin_position); float preset_2(const crepe::vec2 & begin_position); float preset_3(const crepe::vec2 & begin_position); float preset_4(const crepe::vec2 & begin_position); float preset_5(const crepe::vec2 & begin_position); private: + std::vector<std::function<float(const crepe::vec2&)>> functions = { + [this](const crepe::vec2& pos) { return preset_1(pos); }, + [this](const crepe::vec2& pos) { return preset_2(pos); }, + [this](const crepe::vec2& pos) { return preset_3(pos); }, + [this](const crepe::vec2& pos) { return preset_4(pos); }, + [this](const crepe::vec2& pos) { return preset_5(pos); } + }; + std::vector<int> weights = {20, 20,20,20, 20}; + std::random_device rd; + std::default_random_engine engine; + float system_position = 1200; + static constexpr float SYSTEM_POSITION_OFFSET = 200; +private: + static constexpr float SPAWN_SPACING_MIN = 400; + static constexpr float SPAWN_SPACING_MAX = 1000; static constexpr float SPAWN_DISTANCE = 400; static constexpr float DESPAWN_DISTANCE = 400; static constexpr float SPAWN_AREA = 50; @@ -64,13 +81,10 @@ private: static constexpr float COLUM_OFFSET_4 = 25; static constexpr int COLUM_AMOUNT_4 = 3; // preset five settings -// ** ** -// ** ** -// ** -// ** -// ** ** -// ** ** +// +// *** +// static constexpr float ROW_OFFSET_5 = 25; static constexpr float COLUM_OFFSET_5 = 25; - static constexpr int COLUM_AMOUNT_5 = 2; + static constexpr int COLUM_AMOUNT_5 = 3; }; diff --git a/game/mainmenu/BannerSubScene.cpp b/game/mainmenu/BannerSubScene.cpp index 0f4f075..8de5711 100644 --- a/game/mainmenu/BannerSubScene.cpp +++ b/game/mainmenu/BannerSubScene.cpp @@ -9,7 +9,7 @@ using namespace crepe; using namespace std; -void BannerSubScene::create(Scene & scn){ +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"), @@ -31,5 +31,9 @@ void BannerSubScene::create(Scene & scn){ .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,data.banner_title_offset + MainMenuConfig::FONTOFFSET, MainMenuConfig::FONT, Text::Data{ + .text_color = Color::WHITE, + }, data.banner_title); } diff --git a/game/mainmenu/BannerSubScene.h b/game/mainmenu/BannerSubScene.h index 06cd1a4..341943d 100644 --- a/game/mainmenu/BannerSubScene.h +++ b/game/mainmenu/BannerSubScene.h @@ -1,5 +1,6 @@ #pragma once +#include "types.h" #include <crepe/api/GameObject.h> namespace crepe { @@ -8,5 +9,11 @@ class Scene; class BannerSubScene { public: - void create(crepe::Scene & scn); +struct Data{ + const std::string & banner_title = "NODATA"; + const float banner_title_width = 100; + const crepe::vec2 & banner_title_offset = {0,0}; + }; +public: + void create(crepe::Scene & scn,const Data & data); }; diff --git a/game/mainmenu/ShopMenuScene.cpp b/game/mainmenu/ShopMenuScene.cpp index be2039f..d6ad870 100644 --- a/game/mainmenu/ShopMenuScene.cpp +++ b/game/mainmenu/ShopMenuScene.cpp @@ -16,7 +16,11 @@ void ShopMenuScene::load_scene(){ .bg_color = Color::RED, }); BannerSubScene banner; - banner.create(*this); + 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"), |