This commit is contained in:
2025-04-18 23:53:36 +02:00
parent 52e477c7a5
commit 0437f82957
2 changed files with 35 additions and 46 deletions

View File

@@ -3,26 +3,17 @@ mod gun;
mod thrown;
use crate::{
GameState,
aim::AimTarget,
global_observer,
heads::ActiveHeads,
heads_database::HeadsDatabase,
hitpoints::Hit,
physics_layers::GameLayer,
player::{Player, PlayerBodyMesh},
sounds::PlaySound,
tb_entities::EnemySpawn,
};
use avian3d::prelude::*;
use bevy::prelude::*;
use serde::{Deserialize, Serialize};
#[derive(Component)]
pub struct Projectile {
pub owner_head: usize,
}
#[derive(Event, Reflect)]
pub enum TriggerState {
Active,
@@ -83,39 +74,9 @@ pub fn plugin(app: &mut App) {
app.add_plugins(thrown::plugin);
app.add_plugins(arrow::plugin);
app.add_systems(Update, enemy_hit.run_if(in_state(GameState::Playing)));
global_observer!(app, on_trigger_state);
}
fn enemy_hit(
mut commands: Commands,
mut collision_event_reader: EventReader<CollisionStarted>,
query_shot: Query<&Projectile>,
query_npc: Query<&EnemySpawn>,
heads_db: Res<HeadsDatabase>,
) {
for CollisionStarted(e1, e2) in collision_event_reader.read() {
if !query_shot.contains(*e1) && !query_shot.contains(*e2) {
continue;
}
if !query_npc.contains(*e1) && !query_npc.contains(*e2) {
continue;
}
let (enemy_entity, projectile) = if query_npc.contains(*e1) {
(*e1, query_shot.get(*e2))
} else {
(*e2, query_shot.get(*e1))
};
if let Ok(head) = projectile.map(|p| p.owner_head) {
let damage = heads_db.head_stats(head).damage;
commands.entity(enemy_entity).trigger(Hit { damage });
}
}
}
fn on_trigger_state(
trigger: Trigger<TriggerState>,
mut commands: Commands,