From 445a51c344ecea346051cf59d03b95c98bb28e75 Mon Sep 17 00:00:00 2001 From: Alexander Foremny Date: Wed, 20 Mar 2024 07:09:22 +0100 Subject: feat: flash ability --- src/client.rs | 29 ++++++++++++++++++----------- 1 file changed, 18 insertions(+), 11 deletions(-) (limited to 'src/client.rs') diff --git a/src/client.rs b/src/client.rs index b4213a2..ce48b4f 100644 --- a/src/client.rs +++ b/src/client.rs @@ -295,9 +295,7 @@ fn buffer_input( let Some(position) = player_position(&client_id, &players) else { return; }; - let Some(direction) = (world_position - position.0).try_normalize() else { - return; - }; + let direction = world_position - position.0; client.add_input(Inputs::Imperative(Imperative::AttackDirection( ability_slot, direction, @@ -340,6 +338,7 @@ fn buffer_input( fn choose_attack( champion: Res, keyboard_input: Res>, + mouse_input: Res>, mut attack: ResMut, mut client: ClientMut, ) { @@ -359,7 +358,9 @@ fn choose_attack( attack.0 = Some(AbilitySlot::G); } else if keyboard_input.just_pressed(KeyCode::Escape) { attack.0 = None; - } else if keyboard_input.just_pressed(KeyCode::ShiftLeft) { + } else if keyboard_input.just_pressed(KeyCode::CapsLock) { + attack.0 = None; + } else if mouse_input.just_pressed(MouseButton::Right) { attack.0 = None; } match attack.0 { @@ -459,20 +460,26 @@ fn gizmos_attack_indicator( let Some(world_position) = cursor_world_position(&windows, &cameras) else { return; }; - let Some(direction) = (world_position - position.0).try_normalize() else { - return; - }; + let direction = world_position - position.0; match ability { DirectionalAbility::Dash(Dash { max_distance, .. }) => { let DashCollisionResult { dash_end, .. } = dash_collision( PlayerId(client_id.0), position.0, - direction, + direction.normalize_or_zero(), max_distance, &player_positions, ); gizmos.arrow_2d(position.0, dash_end, Color::YELLOW); } + DirectionalAbility::Flash(Flash { max_distance, .. }) => { + gizmos.arrow_2d( + position.0, + position.0 + + direction.length().min(max_distance) * direction.normalize_or_zero(), + Color::YELLOW, + ); + } DirectionalAbility::Pull(Pull { max_distance, .. }) => { let Some(PullCollision { pull_end, @@ -481,12 +488,12 @@ fn gizmos_attack_indicator( }) = pull_collision( PlayerId(client_id.0), position.0, - direction, + direction.normalize_or_zero(), max_distance, &player_positions, ) else { - let pull_direction = -max_distance * direction; + let pull_direction = -max_distance * direction.normalize_or_zero(); let pull_start = position.0 - pull_direction; let pull_end = pull_start + (pull_direction.length() - 2. * PLAYER_RADIUS) @@ -499,7 +506,7 @@ fn gizmos_attack_indicator( DirectionalAbility::Spear(Spear { max_distance, .. }) => { gizmos.arrow_2d( position.0, - position.0 + max_distance * direction, + position.0 + max_distance * direction.normalize_or_zero(), Color::YELLOW, ); } -- cgit v1.2.3