aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWBoerenkamps <wrj.boerenkamps@student.avans.nl>2025-01-08 10:46:14 +0100
committerWBoerenkamps <wrj.boerenkamps@student.avans.nl>2025-01-08 10:46:14 +0100
commit6112da75f973b1099fa95fcd9d3113c00302f5b4 (patch)
tree073c4dacfc2c2530d52000ee8865317584898431
parent7f7c5c56dce30d47c32fb57fad6d839d0990b054 (diff)
player bullet working
-rw-r--r--game/player/PlayerBulletScript.cpp2
-rw-r--r--game/player/PlayerBulletSubScene.cpp13
-rw-r--r--game/player/PlayerScript.cpp9
-rw-r--r--game/player/PlayerScript.h5
4 files changed, 20 insertions, 9 deletions
diff --git a/game/player/PlayerBulletScript.cpp b/game/player/PlayerBulletScript.cpp
index e1637c2..50b6617 100644
--- a/game/player/PlayerBulletScript.cpp
+++ b/game/player/PlayerBulletScript.cpp
@@ -20,7 +20,7 @@ void PlayerBulletScript::fixed_update(crepe::duration_t dt){
vec2 half_screen = camera.viewport_size / 2;
float despawn_location = cam_transform.position.x + half_screen.x + 50;
- if(transform.position.x < despawn_location){
+ if(transform.position.x > despawn_location){
this->despawn_bullet();
}
}
diff --git a/game/player/PlayerBulletSubScene.cpp b/game/player/PlayerBulletSubScene.cpp
index eb34046..eb89260 100644
--- a/game/player/PlayerBulletSubScene.cpp
+++ b/game/player/PlayerBulletSubScene.cpp
@@ -1,3 +1,4 @@
+#include <iostream>
#include <string>
#include <crepe/api/GameObject.h>
@@ -19,7 +20,6 @@ using namespace crepe;
using namespace std;
int PlayerBulletSubScene::create(Scene & scn){
vec2 size = {20, 20};
-
static int counter = 0;
string unique_name = "playerBullet_" + to_string(counter++);
GameObject player_bullet = scn.new_object(unique_name.c_str(),"PlayerBullet",vec2{0,-850},0,1);
@@ -27,23 +27,24 @@ int PlayerBulletSubScene::create(Scene & scn){
Rigidbody& player_bullet_body = player_bullet.add_component<Rigidbody>(Rigidbody::Data {
.gravity_scale = 0,
.body_type = Rigidbody::BodyType::DYNAMIC,
- .linear_velocity = vec2{-300,0},
- .collision_layers = {COLL_LAY_PLAYER},
- .collision_layer = COLL_LAY_BULLET,
+ .linear_velocity = vec2{300,0},
+ .angular_velocity = 150,
+ // .collision_layers = {COLL_LAY_PLAYER},
+ // .collision_layer = COLL_LAY_BULLET,
});
player_bullet_body.active = false;
BoxCollider& player_bullet_collider = player_bullet.add_component<BoxCollider>(vec2(60, 40));
player_bullet_collider.active = false;
- Asset player_bullet_asset {"asset/other_effects/effect_smgbullet_x2.png"};
+ Asset player_bullet_asset {"asset/other_effects/crepe.png"};
Sprite & player_bullet_sprite = player_bullet.add_component<Sprite>(
player_bullet_asset,
Sprite::Data {
.flip = {true,false},
.sorting_in_layer = SORT_IN_LAY_PLAYER,
.order_in_layer = 1,
- .size = vec2(60,0),
+ .size = vec2(30,0),
}
);
player_bullet.add_component<BehaviorScript>().set_script<PlayerBulletScript>();
diff --git a/game/player/PlayerScript.cpp b/game/player/PlayerScript.cpp
index 8372080..96a0552 100644
--- a/game/player/PlayerScript.cpp
+++ b/game/player/PlayerScript.cpp
@@ -17,6 +17,7 @@ void PlayerScript::init() {
subscribe<CollisionEvent>([this](const CollisionEvent & ev) -> bool {
return this->on_collision(ev);
});
+ this->last_fired = std::chrono::steady_clock::now();
}
bool PlayerScript::on_collision(const CollisionEvent & ev) {
BehaviorScript & play_scr = this->get_components_by_name<BehaviorScript>("player").front();
@@ -86,7 +87,13 @@ void PlayerScript::fixed_update(crepe::duration_t dt) {
});
}
if(this->get_key_state(Keycode::ENTER)){
- this->shoot(transform.position,0);
+
+ auto now = std::chrono::steady_clock::now();
+ std::chrono::duration<float> elapsed = now - last_fired;
+ if (elapsed > shot_delay) {
+ this->shoot(transform.position,0);
+ last_fired = now;
+ }
}
if (this->get_key_state(Keycode::SPACE)) {
rb.add_force_linear(vec2(0, -PLAYER_GRAVITY_SCALE / 2.5) * dt.count() / 0.02);
diff --git a/game/player/PlayerScript.h b/game/player/PlayerScript.h
index cdb466f..cec27ce 100644
--- a/game/player/PlayerScript.h
+++ b/game/player/PlayerScript.h
@@ -2,7 +2,7 @@
#include <crepe/api/Event.h>
#include <crepe/api/Script.h>
-
+#include <chrono>
class PlayerScript : public crepe::Script {
public:
void init();
@@ -14,4 +14,7 @@ private:
void shoot(const crepe::vec2& location,float angle);
private:
int prev_anim = 0;
+ std::chrono::time_point<std::chrono::steady_clock> last_fired;
+ std::chrono::duration<float> shot_delay = std::chrono::duration<float>(0.5);
+
};