aboutsummaryrefslogtreecommitdiff
path: root/game/workers/PanicFromPlayer.cpp
diff options
context:
space:
mode:
authorMax-001 <maxsmits21@kpnmail.nl>2025-01-07 14:34:12 +0100
committerMax-001 <maxsmits21@kpnmail.nl>2025-01-07 14:34:12 +0100
commit1f0edff951e7580163d8c987d4a021b24d45e9f1 (patch)
treea4ffd4334f24b2d72fdd44daef4294f1a2fbf234 /game/workers/PanicFromPlayer.cpp
parent80fc064c77bb61d9b329b58532c9cacd99038e0a (diff)
Added panic from player
Diffstat (limited to 'game/workers/PanicFromPlayer.cpp')
-rw-r--r--game/workers/PanicFromPlayer.cpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/game/workers/PanicFromPlayer.cpp b/game/workers/PanicFromPlayer.cpp
new file mode 100644
index 0000000..fbf4611
--- /dev/null
+++ b/game/workers/PanicFromPlayer.cpp
@@ -0,0 +1,45 @@
+#include "PanicFromPlayer.h"
+
+#include <crepe/api/Animator.h>
+#include <crepe/api/Rigidbody.h>
+#include <crepe/api/Sprite.h>
+#include <crepe/api/Transform.h>
+#include <crepe/types.h>
+
+using namespace crepe;
+using namespace std;
+
+void PanicFromPlayer::fixed_update(duration_t dt) {
+ Animator & anim_player = this->get_components_by_name<Animator>("player").front();
+
+ if (anim_player.data.col == 1) {
+ Transform & trans_player = this->get_components_by_name<Transform>("player").back();
+ Transform & trans_worker = this->get_components<Transform>().back();
+
+ float result_x = trans_player.position.x - trans_worker.position.x;
+
+ if (result_x < 100 && result_x > -20) {
+ RefVector<Animator> anim_worker = this->get_components<Animator>();
+ RefVector<Sprite> sprite_worker = this->get_components<Sprite>();
+ Rigidbody & rb_worker = this->get_components<Rigidbody>().back();
+
+ if (anim_worker.front().get().data.col != 1) {
+ anim_worker.front().get().set_anim(1);
+ anim_worker.back().get().set_anim(1);
+
+ anim_worker.front().get().data.fps = 10;
+ anim_worker.back().get().data.fps = 10;
+ }
+
+ if (result_x < 0) {
+ rb_worker.data.linear_velocity.x = 10000 * dt.count();
+ sprite_worker.front().get().data.flip.flip_x = false;
+ sprite_worker.back().get().data.flip.flip_x = false;
+ } else {
+ rb_worker.data.linear_velocity.x = -5000 * dt.count();
+ sprite_worker.front().get().data.flip.flip_x = true;
+ sprite_worker.back().get().data.flip.flip_x = true;
+ }
+ }
+ }
+};