aboutsummaryrefslogtreecommitdiff
path: root/game/player/PlayerScript.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'game/player/PlayerScript.cpp')
-rw-r--r--game/player/PlayerScript.cpp37
1 files changed, 34 insertions, 3 deletions
diff --git a/game/player/PlayerScript.cpp b/game/player/PlayerScript.cpp
index 472d7c8..8372080 100644
--- a/game/player/PlayerScript.cpp
+++ b/game/player/PlayerScript.cpp
@@ -1,10 +1,12 @@
+#include <iostream>
#include "PlayerScript.h"
#include "../Config.h"
-
+#include "../enemy/BattleScript.h"
#include <crepe/api/Animator.h>
#include <crepe/api/ParticleEmitter.h>
#include <crepe/api/Rigidbody.h>
+#include <crepe/api/BoxCollider.h>
#include <crepe/api/Transform.h>
#include <crepe/types.h>
@@ -16,7 +18,6 @@ void PlayerScript::init() {
return this->on_collision(ev);
});
}
-
bool PlayerScript::on_collision(const CollisionEvent & ev) {
BehaviorScript & play_scr = this->get_components_by_name<BehaviorScript>("player").front();
BehaviorScript & end_scr = this->get_components_by_name<BehaviorScript>("player").back();
@@ -77,8 +78,16 @@ void PlayerScript::fixed_update(crepe::duration_t dt) {
for (ParticleEmitter & emitter : emitters) {
emitter.data.boundary.offset = vec2(0, -transform.position.y);
}
-
+
Rigidbody & rb = this->get_components_by_name<Rigidbody>("player").front();
+ if (this->get_key_state(Keycode::P)) {
+ this->trigger_event<BattleStartEvent>(BattleStartEvent{
+ .num_enemies = 5,
+ });
+ }
+ if(this->get_key_state(Keycode::ENTER)){
+ this->shoot(transform.position,0);
+ }
if (this->get_key_state(Keycode::SPACE)) {
rb.add_force_linear(vec2(0, -PLAYER_GRAVITY_SCALE / 2.5) * dt.count() / 0.02);
if (prev_anim != 1) {
@@ -117,3 +126,25 @@ void PlayerScript::fixed_update(crepe::duration_t dt) {
}
}
}
+
+void PlayerScript::shoot(const vec2& location,float angle){
+ cout << "player shot" << endl;
+ RefVector<Transform> bullet_transforms = this->get_components_by_tag<Transform>("PlayerBullet");
+
+ for(Transform& bullet_pos : bullet_transforms){
+ //cout << "bullet pos x: " << bullet_pos.position.x << " y: " << bullet_pos.position.y << endl;
+ if(bullet_pos.position.x == 0 && bullet_pos.position.y == -850){
+
+ cout << "bullet found\n";
+ bullet_pos.position = location;
+ bullet_pos.position.x += 20;
+ cout << "bullet pos x: " << bullet_pos.position.x << " y: " << bullet_pos.position.y << endl;
+ Rigidbody& bullet_body = this->get_components_by_id<Rigidbody>(bullet_pos.game_object_id).front();
+ BoxCollider bullet_collider = this->get_components_by_id<BoxCollider>(bullet_pos.game_object_id).front();
+ //bullet_collider.active = true;
+ bullet_body.active = true;
+ return;
+ }
+ }
+ cout << "bullet not found\n";
+}