aboutsummaryrefslogtreecommitdiff
path: root/game/workers/PanicFromPlayerScript.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'game/workers/PanicFromPlayerScript.cpp')
-rw-r--r--game/workers/PanicFromPlayerScript.cpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/game/workers/PanicFromPlayerScript.cpp b/game/workers/PanicFromPlayerScript.cpp
new file mode 100644
index 0000000..1e49aaa
--- /dev/null
+++ b/game/workers/PanicFromPlayerScript.cpp
@@ -0,0 +1,45 @@
+#include "PanicFromPlayerScript.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 PanicFromPlayerScript::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;
+ }
+ }
+ }
+};