aboutsummaryrefslogtreecommitdiffstats
path: root/src/shared
diff options
context:
space:
mode:
authorLibravatar Alexander Foremny <aforemny@posteo.de>2024-03-20 07:09:22 +0100
committerLibravatar Alexander Foremny <aforemny@posteo.de>2024-03-20 07:09:22 +0100
commit445a51c344ecea346051cf59d03b95c98bb28e75 (patch)
tree33f0327659b9f8ea0422b2452c8ec48e532cef3c /src/shared
parent716bd0618308d6100556d1231b0b156f48c64778 (diff)
feat: flash ability
Diffstat (limited to 'src/shared')
-rw-r--r--src/shared/ability.rs35
-rw-r--r--src/shared/champion.rs6
2 files changed, 38 insertions, 3 deletions
diff --git a/src/shared/ability.rs b/src/shared/ability.rs
index 8decfc6..b7b3664 100644
--- a/src/shared/ability.rs
+++ b/src/shared/ability.rs
@@ -180,6 +180,7 @@ fn speed_activation(speed: Speed) -> ActivatedAbilityActivation {
#[derive(Copy, Clone, PartialEq, Debug, Deserialize, Serialize)]
pub enum DirectionalAbility {
Dash(Dash),
+ Flash(Flash),
Pull(Pull),
Spear(Spear),
}
@@ -191,6 +192,11 @@ pub struct Dash {
}
#[derive(Copy, Clone, PartialEq, Debug, Deserialize, Serialize)]
+pub struct Flash {
+ pub max_distance: f32,
+}
+
+#[derive(Copy, Clone, PartialEq, Debug, Deserialize, Serialize)]
pub struct Pull {
pub max_distance: f32,
pub damage: f32,
@@ -202,18 +208,41 @@ pub struct Spear {
pub damage: f32,
}
+// `direction: Vec2` is NOT normalized (cf. `Flash`)!
pub type DirectionalAbilityActivation = Box<dyn FnOnce(&mut Commands, PlayerId, Vec2) -> ()>;
impl DirectionalAbility {
pub fn activate(self) -> DirectionalAbilityActivation {
match self {
DirectionalAbility::Dash(dash) => dash_activation(dash),
+ DirectionalAbility::Flash(flash) => flash_activation(flash),
DirectionalAbility::Pull(pull) => pull_activation(pull),
DirectionalAbility::Spear(spear) => spear_activation(spear),
}
}
}
+fn flash_activation(flash: Flash) -> DirectionalAbilityActivation {
+ Box::new(
+ move |commands: &mut Commands, source_player: PlayerId, direction: Vec2| {
+ commands.add(move |world: &mut World| {
+ world.run_system_once(
+ move |entity_map: Res<EntityMap>, mut positions: Query<&mut PlayerPosition>| {
+ let Some(entity_id) = entity_map.0.get(&source_player.0) else {
+ return;
+ };
+ let Ok(mut position) = positions.get_mut(*entity_id) else {
+ return;
+ };
+ position.0 += direction.length().min(flash.max_distance)
+ * direction.normalize_or_zero();
+ },
+ );
+ });
+ },
+ )
+}
+
fn dash_activation(dash: Dash) -> DirectionalAbilityActivation {
Box::new(
move |commands: &mut Commands, source_player: PlayerId, direction: Vec2| {
@@ -259,7 +288,7 @@ fn dash_activation(dash: Dash) -> DirectionalAbilityActivation {
dash_collision(
source_player,
source_position.0,
- direction,
+ direction.normalize_or_zero(),
dash.max_distance,
&dash_targets,
)
@@ -409,7 +438,7 @@ fn pull_activation(pull: Pull) -> DirectionalAbilityActivation {
pull_collision(
source_player,
source_position.0,
- direction,
+ direction.normalize_or_zero(),
pull.max_distance,
&pull_targets,
)
@@ -520,7 +549,7 @@ fn spear_activation(spear: Spear) -> DirectionalAbilityActivation {
commands.spawn(ProjectileBundle::new(Projectile {
type_: ProjectileType::Free(FreeProjectile {
position: position.0,
- direction,
+ direction: direction.normalize_or_zero(),
starting_position: position.0,
max_distance: spear.max_distance,
scale_damage: Some((0.75, 2.5)),
diff --git a/src/shared/champion.rs b/src/shared/champion.rs
index ecd6e10..f48faa1 100644
--- a/src/shared/champion.rs
+++ b/src/shared/champion.rs
@@ -64,6 +64,9 @@ impl Champion {
AbilitySlot::R => {
Ability::Targeted(TargetedAbility::MeeleAttack(MeeleAttack { damage: 45. }))
}
+ AbilitySlot::F => {
+ Ability::Directional(DirectionalAbility::Flash(Flash { max_distance: 100. }))
+ }
AbilitySlot::G => {
Ability::Activated(ActivatedAbility::Speed(Speed { duration: 2.5 }))
}
@@ -77,6 +80,9 @@ impl Champion {
AbilitySlot::R => {
Ability::Activated(ActivatedAbility::Focus(Focus { duration: 5. }))
}
+ AbilitySlot::F => {
+ Ability::Directional(DirectionalAbility::Flash(Flash { max_distance: 100. }))
+ }
AbilitySlot::G => {
Ability::Activated(ActivatedAbility::Speed(Speed { duration: 2.5 }))
}