diff options
| author | JAROWMR <jarorutjes07@gmail.com> | 2024-12-28 20:46:33 +0100 | 
|---|---|---|
| committer | JAROWMR <jarorutjes07@gmail.com> | 2024-12-28 20:46:33 +0100 | 
| commit | e007e8f467349eeddaf503e31897d4135ba6fed4 (patch) | |
| tree | f724b6aa91c77d3f644170b7853420fc7ae2850e | |
| parent | 9afadbd2b2d2c5ec730154a426e83722e4c3da32 (diff) | |
added presets
| -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;  }; |