diff options
Diffstat (limited to 'game')
-rw-r--r-- | game/CMakeLists.txt | 4 | ||||
-rw-r--r-- | game/coins/CoinSystemScript.cpp | 124 | ||||
-rw-r--r-- | game/coins/CoinSystemScript.h | 22 |
3 files changed, 101 insertions, 49 deletions
diff --git a/game/CMakeLists.txt b/game/CMakeLists.txt index 6f3beb5..d3608d1 100644 --- a/game/CMakeLists.txt +++ b/game/CMakeLists.txt @@ -32,7 +32,7 @@ set(SOURCES mainmenu/BannerSubScene.cpp mainmenu/ButtonSetShopScript.cpp coins/CoinSubScene.cpp - coins/CoinSystem.cpp + coins/CoinPool.cpp coins/CoinSystemScript.cpp ) @@ -60,7 +60,7 @@ set(HEADERS mainmenu/ButtonSetShopScript.h coins/CoinData.h coins/CoinSubScene.h - coins/CoinSystem.h + coins/CoinPool.h coins/CoinSystemScript.h ) diff --git a/game/coins/CoinSystemScript.cpp b/game/coins/CoinSystemScript.cpp index da1fc65..6cab12d 100644 --- a/game/coins/CoinSystemScript.cpp +++ b/game/coins/CoinSystemScript.cpp @@ -1,5 +1,5 @@ #include "CoinSystemScript.h" -#include "CoinSystem.h" +#include "CoinPool.h" #include "api/CircleCollider.h" #include "api/Metadata.h" #include "api/Sprite.h" @@ -11,53 +11,87 @@ using namespace std; std::vector<CoinData> CoinSystemScript::coin_locations; void CoinSystemScript::init() { - this->add_location(vec2{1500,-30}); - this->add_location(vec2{1500,0}); - this->add_location(vec2{1500,30}); - this->add_location(vec2{1500,60}); - this->add_location(vec2{1550,-30}); - this->add_location(vec2{1550,0}); - this->add_location(vec2{1550,30}); - this->add_location(vec2{1550,60}); - - this->add_location(vec2{2500,-30}); - this->add_location(vec2{2500,0}); - this->add_location(vec2{2500,30}); - this->add_location(vec2{2500,60}); - this->add_location(vec2{2550,-30}); - this->add_location(vec2{2550,0}); - this->add_location(vec2{2550,30}); - this->add_location(vec2{2550,60}); - this->add_location(vec2{2600,-30}); - this->add_location(vec2{2600,0}); - this->add_location(vec2{2600,30}); - this->add_location(vec2{2600,60}); - this->add_location(vec2{2650,-30}); - this->add_location(vec2{2650,0}); - this->add_location(vec2{2650,30}); - this->add_location(vec2{2650,60}); - this->add_location(vec2{2700,-30}); - this->add_location(vec2{2700,0}); - this->add_location(vec2{2700,30}); - this->add_location(vec2{2700,60}); - this->add_location(vec2{2750,-30}); - this->add_location(vec2{2750,0}); - this->add_location(vec2{2750,30}); - this->add_location(vec2{2750,60}); - this->add_location(vec2{2800,-30}); - this->add_location(vec2{2800,0}); - this->add_location(vec2{2800,30}); - this->add_location(vec2{2800,60}); - this->add_location(vec2{2850,-30}); - this->add_location(vec2{2850,0}); - this->add_location(vec2{2850,30}); - this->add_location(vec2{2850,60}); + float position = 1200; + position += this->preset_1({position,0}); + position += 100; + position += this->preset_2({position,0}); } + + + 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)}; + + // Add locations for the top row + for (int i = 0; i < COLUM_AMOUNT_1; ++i) { + add_location(top); + top.x += this->COLUM_OFFSET_1; + } + + // Add locations for the bottom row + bottom.x +=this->COLUM_OFFSET_1 * COLUM_AMOUNT_1; + for (int i = 0; i < COLUM_AMOUNT_1; ++i) { + add_location(bottom); + bottom.x += this->COLUM_OFFSET_1; + } + + // Add locations for the next set of the top row + top.x += this->COLUM_OFFSET_1 * COLUM_AMOUNT_1; + for (int i = 0; i < COLUM_AMOUNT_1; ++i) { + add_location(top); + top.x += this->COLUM_OFFSET_1; + } + + // Add locations for the next set of the bottom row + bottom.x +=this->COLUM_OFFSET_1 * COLUM_AMOUNT_1; + for (int i = 0; i < COLUM_AMOUNT_1; ++i) { + add_location(bottom); + bottom.x += this->COLUM_OFFSET_1; + } + + return bottom.x-begin_position.x; +} + +float CoinSystemScript::preset_2(const vec2 & begin_position){ + vec2 top = {begin_position.x+this->COLUM_OFFSET_2, begin_position.y - this->ROW_OFFSET_2}; + vec2 middle = begin_position; + vec2 bottom = {begin_position.x+this->COLUM_OFFSET_2, begin_position.y + this->ROW_OFFSET_2}; + + // Add locations for the next set of the bottom row + for (int i = 0; i < COLUM_AMOUNT_2-2; ++i) { + add_location(bottom); + bottom.x += this->COLUM_OFFSET_2; + } + + // Add locations for the next set of the middle row + for (int i = 0; i < COLUM_AMOUNT_2; ++i) { + add_location(middle); + middle.x += this->COLUM_OFFSET_2; + } + + // Add locations for the next set of the top row + for (int i = 0; i < COLUM_AMOUNT_2-2; ++i) { + add_location(top); + top.x += this->COLUM_OFFSET_2; + } + + return middle.x-begin_position.x; +} + + +void CoinSystemScript::frame_update(crepe::duration_t dt) +{ + this->despawn_coins(); + this->spawn_coins(); +} + void CoinSystemScript::despawn_coins() { // Get the current x-position of the CoinSystem's Transform component float position = this->get_component<Transform>().position.x; @@ -132,11 +166,7 @@ void CoinSystemScript::spawn_coins(){ } } -void CoinSystemScript::frame_update(crepe::duration_t dt) -{ - this->despawn_coins(); - this->spawn_coins(); -} + diff --git a/game/coins/CoinSystemScript.h b/game/coins/CoinSystemScript.h index 6cf613a..f17c160 100644 --- a/game/coins/CoinSystemScript.h +++ b/game/coins/CoinSystemScript.h @@ -15,9 +15,31 @@ private: void add_location(const crepe::vec2& location); void despawn_coins(); void spawn_coins(); + float preset_1(const crepe::vec2 & begin_position); + float preset_2(const crepe::vec2 & begin_position); private: static constexpr float SPAWN_DISTANCE = 400; static constexpr float DESPAWN_DISTANCE = 400; static constexpr float SPAWN_AREA = 50; static std::vector<CoinData> coin_locations; +private: +// preset one settings +// ***** ***** +// +// +// +// ***** ***** + static constexpr float ROW_OFFSET_1 = 100; + static constexpr float COLUM_OFFSET_1 = 25; + static constexpr int COLUM_AMOUNT_1 = 5; +private: +// preset two settings +// ***** ***** +// +// +// +// ***** ***** + static constexpr float ROW_OFFSET_2 = 25; + static constexpr float COLUM_OFFSET_2 = 25; + static constexpr int COLUM_AMOUNT_2 = 10; }; |