diff options
| author | WBoerenkamps <wrj.boerenkamps@student.avans.nl> | 2025-01-06 15:27:44 +0100 | 
|---|---|---|
| committer | WBoerenkamps <wrj.boerenkamps@student.avans.nl> | 2025-01-06 15:27:44 +0100 | 
| commit | ceb41b7ae7e2734af954364b319fc0b6f2a86c2f (patch) | |
| tree | f7544f5f68236be02eb96a7d381bce9ad41845dc /game/player/PlayerEndScript.cpp | |
| parent | e9cba1baee564d835b8a3473a9cb146825f56732 (diff) | |
| parent | 77d02bf2e2d5d04e8cacb3c783446541517e8e76 (diff) | |
Merge branch 'master' of https://github.com/lonkaars/crepe into wouter/enemyAI
Diffstat (limited to 'game/player/PlayerEndScript.cpp')
| -rw-r--r-- | game/player/PlayerEndScript.cpp | 96 | 
1 files changed, 96 insertions, 0 deletions
| diff --git a/game/player/PlayerEndScript.cpp b/game/player/PlayerEndScript.cpp new file mode 100644 index 0000000..e04fb9d --- /dev/null +++ b/game/player/PlayerEndScript.cpp @@ -0,0 +1,96 @@ +#include "PlayerEndScript.h" + +#include "../Config.h" +#include "manager/LoopTimerManager.h" + +#include <crepe/api/Animator.h> +#include <crepe/api/BoxCollider.h> +#include <crepe/api/CircleCollider.h> +#include <crepe/api/Rigidbody.h> +#include <crepe/types.h> + +using namespace crepe; +using namespace std; + +void PlayerEndScript::init() { +	Rigidbody & rb_player = this->get_components_by_name<Rigidbody>("player").front(); +	rb_player.data.elasticity_coefficient = 0.7; + +	subscribe<CollisionEvent>([this](const CollisionEvent & ev) -> bool { +		return this->on_collision(ev); +	}); +} + +bool PlayerEndScript::on_collision(const crepe::CollisionEvent & ev) { +	if (ev.info.other.metadata.name == "floor") { +		Transform & transform_player +			= this->get_components_by_name<Transform>("player").front(); +		RefVector<Animator> anim_player = this->get_components_by_name<Animator>("player"); +		Rigidbody & rb_player = this->get_components_by_name<Rigidbody>("player").front(); +		Rigidbody & rb_camera = this->get_components_by_name<Rigidbody>("camera").front(); + +		float dt = this->get_loop_timer().get_fixed_delta_time().count(); + +		if (jump == 0) { +			int random_number = rand() % 4; +			for (Animator & anim : anim_player) { +				anim.active = false; +				anim.set_anim(6); +				for (int i = 0; i < random_number; i++) { +					anim.next_anim(); +				} +			} +		} else if (jump == 1) { +			for (Animator & anim : anim_player) { +				anim.next_anim(); +			} +		} + +		if (jump == 0) { +			rb_player.data.angular_velocity = 16000 * dt; +			rb_player.data.angular_velocity_coefficient = 0.7; +			jump++; +		} else if (jump == 1) { +			jump++; +		} else if (jump == 2) { +			RefVector<Rigidbody> rb_back_forest +				= this->get_components_by_tag<Rigidbody>("forest_background"); +			for (Rigidbody & rb : rb_back_forest) { +				rb.data.linear_velocity_coefficient = vec2(0.5, 0.5); +			} + +			rb_player.data.angular_velocity = 0; +			rb_player.data.elasticity_coefficient = 0; +			rb_player.data.linear_velocity = vec2(PLAYER_SPEED * dt, 0); +			rb_player.data.linear_velocity_coefficient = vec2(0.5, 0.5); +			rb_camera.data.linear_velocity_coefficient = vec2(0.5, 0.5); +			for (Animator & anim : anim_player) { +				anim.active = false; +				anim.set_anim(7); +			} +			if (transform_player.rotation > 0 && transform_player.rotation < 90) { +				// Do not call next_anim() +			} else if (transform_player.rotation > 90 && transform_player.rotation < 180) { +				for (Animator & anim : anim_player) { +					anim.next_anim(); +				} +			} else if (transform_player.rotation > 180 && transform_player.rotation < 270) { +				for (Animator & anim : anim_player) { +					anim.next_anim(); +					anim.next_anim(); +				} +			} else { +				for (Animator & anim : anim_player) { +					anim.next_anim(); +					anim.next_anim(); +					anim.next_anim(); +				} +			} +			jump++; +		} + +		return true; +	} + +	return false; +} |