mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Finisher abilities
This commit is contained in:
parent
86dfa34ec9
commit
27463758e5
@ -1,39 +1,20 @@
|
||||
ComboMelee2(
|
||||
strikes: [
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 5,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.15,
|
||||
swing_duration: 0.05,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.1,
|
||||
ori_modifier: 0.6,
|
||||
RapidMelee(
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.033,
|
||||
recover_duration: 0.1,
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 2,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 0,
|
||||
),
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 7.5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.2,
|
||||
ori_modifier: 0.6,
|
||||
),
|
||||
],
|
||||
energy_cost_per_strike: 0,
|
||||
range: 3.0,
|
||||
angle: 10.0,
|
||||
),
|
||||
energy_cost: 2,
|
||||
max_strikes: Some(20),
|
||||
move_modifier: 0.6,
|
||||
ori_modifier: 0.4,
|
||||
minimum_combo: 20,
|
||||
)
|
@ -1,39 +1,17 @@
|
||||
ComboMelee2(
|
||||
strikes: [
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 5,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.15,
|
||||
swing_duration: 0.05,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.1,
|
||||
ori_modifier: 0.6,
|
||||
FinisherMelee(
|
||||
energy_cost: 30,
|
||||
buildup_duration: 0.2,
|
||||
swing_duration: 0.1,
|
||||
recover_duration: 0.4,
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 40,
|
||||
poise: 10,
|
||||
knockback: 0,
|
||||
energy_regen: 0,
|
||||
),
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 7.5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.2,
|
||||
ori_modifier: 0.6,
|
||||
),
|
||||
],
|
||||
energy_cost_per_strike: 0,
|
||||
range: 3.0,
|
||||
angle: 15.0,
|
||||
),
|
||||
minimum_combo: 15,
|
||||
)
|
@ -1,39 +1,21 @@
|
||||
ComboMelee2(
|
||||
strikes: [
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 5,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.15,
|
||||
swing_duration: 0.05,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.1,
|
||||
ori_modifier: 0.6,
|
||||
RapidMelee(
|
||||
buildup_duration: 0.3,
|
||||
swing_duration: 0.15,
|
||||
recover_duration: 0.3,
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 8,
|
||||
poise: 10,
|
||||
knockback: 0,
|
||||
energy_regen: 0,
|
||||
),
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 7.5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.2,
|
||||
ori_modifier: 0.6,
|
||||
),
|
||||
],
|
||||
energy_cost_per_strike: 0,
|
||||
)
|
||||
range: 4.0,
|
||||
angle: 360.0,
|
||||
multi_target: Some(Normal),
|
||||
),
|
||||
energy_cost: 5,
|
||||
max_strikes: Some(6),
|
||||
move_modifier: 0.8,
|
||||
ori_modifier: 1.0,
|
||||
minimum_combo: 10,
|
||||
)
|
||||
|
@ -1,39 +1,21 @@
|
||||
ComboMelee2(
|
||||
strikes: [
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 5,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.15,
|
||||
swing_duration: 0.05,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.1,
|
||||
ori_modifier: 0.6,
|
||||
RapidMelee(
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
recover_duration: 0.3,
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 5,
|
||||
knockback: 0,
|
||||
energy_regen: 0,
|
||||
),
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 7.5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.2,
|
||||
ori_modifier: 0.6,
|
||||
),
|
||||
],
|
||||
energy_cost_per_strike: 0,
|
||||
)
|
||||
range: 4.0,
|
||||
angle: 15.0,
|
||||
damage_effect: Some(BuffsVulnerable(1.0, Bleeding)),
|
||||
),
|
||||
energy_cost: 7.5,
|
||||
max_strikes: Some(4),
|
||||
move_modifier: 0.7,
|
||||
ori_modifier: 0.2,
|
||||
minimum_combo: 12,
|
||||
)
|
||||
|
@ -1,39 +1,18 @@
|
||||
ComboMelee2(
|
||||
strikes: [
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 5,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.15,
|
||||
swing_duration: 0.05,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.1,
|
||||
ori_modifier: 0.6,
|
||||
FinisherMelee(
|
||||
energy_cost: 30,
|
||||
buildup_duration: 0.05,
|
||||
swing_duration: 0.1,
|
||||
recover_duration: 0.6,
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 20,
|
||||
poise: 10,
|
||||
knockback: 0,
|
||||
energy_regen: 0,
|
||||
),
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 7.5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.2,
|
||||
ori_modifier: 0.6,
|
||||
),
|
||||
],
|
||||
energy_cost_per_strike: 0,
|
||||
range: 3.0,
|
||||
angle: 15.0,
|
||||
damage_effect: Some(BuffsVulnerable(2.0, Parried)),
|
||||
),
|
||||
minimum_combo: 15,
|
||||
)
|
@ -1,39 +1,17 @@
|
||||
ComboMelee2(
|
||||
strikes: [
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 5,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.15,
|
||||
swing_duration: 0.05,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.1,
|
||||
ori_modifier: 0.6,
|
||||
FinisherMelee(
|
||||
energy_cost: 30,
|
||||
buildup_duration: 0.4,
|
||||
swing_duration: 0.1,
|
||||
recover_duration: 0.6,
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 60,
|
||||
poise: 100,
|
||||
knockback: 0,
|
||||
energy_regen: 0,
|
||||
),
|
||||
(
|
||||
melee_constructor: (
|
||||
kind: Slash(
|
||||
damage: 10,
|
||||
poise: 0,
|
||||
knockback: 0,
|
||||
energy_regen: 7.5,
|
||||
),
|
||||
range: 3.0,
|
||||
angle: 45.0,
|
||||
),
|
||||
buildup_duration: 0.1,
|
||||
swing_duration: 0.1,
|
||||
hit_timing: 0.5,
|
||||
recover_duration: 0.2,
|
||||
ori_modifier: 0.6,
|
||||
),
|
||||
],
|
||||
energy_cost_per_strike: 0,
|
||||
range: 3.0,
|
||||
angle: 15.0,
|
||||
),
|
||||
minimum_combo: 10,
|
||||
)
|
@ -806,6 +806,8 @@ pub enum CharacterAbility {
|
||||
move_modifier: f32,
|
||||
ori_modifier: f32,
|
||||
#[serde(default)]
|
||||
minimum_combo: u32,
|
||||
#[serde(default)]
|
||||
meta: AbilityMeta,
|
||||
},
|
||||
}
|
||||
@ -862,7 +864,6 @@ impl CharacterAbility {
|
||||
| CharacterAbility::BasicBlock { energy_cost, .. }
|
||||
| CharacterAbility::SelfBuff { energy_cost, .. }
|
||||
| CharacterAbility::RiposteMelee { energy_cost, .. }
|
||||
| CharacterAbility::RapidMelee { energy_cost, .. }
|
||||
| CharacterAbility::ComboMelee2 {
|
||||
energy_cost_per_strike: energy_cost,
|
||||
..
|
||||
@ -890,6 +891,11 @@ impl CharacterAbility {
|
||||
energy_cost,
|
||||
minimum_combo,
|
||||
..
|
||||
}
|
||||
| CharacterAbility::RapidMelee {
|
||||
energy_cost,
|
||||
minimum_combo,
|
||||
..
|
||||
} => {
|
||||
data.combo.map_or(false, |c| c.counter() >= *minimum_combo)
|
||||
&& update.energy.try_change_by(-*energy_cost).is_ok()
|
||||
@ -1476,6 +1482,7 @@ impl CharacterAbility {
|
||||
max_strikes: _,
|
||||
move_modifier: _,
|
||||
ori_modifier: _,
|
||||
minimum_combo: _,
|
||||
meta: _,
|
||||
} => {
|
||||
*buildup_duration /= stats.speed;
|
||||
@ -1542,7 +1549,9 @@ impl CharacterAbility {
|
||||
0
|
||||
}
|
||||
},
|
||||
FinisherMelee { minimum_combo, .. } => *minimum_combo,
|
||||
FinisherMelee { minimum_combo, .. } | RapidMelee { minimum_combo, .. } => {
|
||||
*minimum_combo
|
||||
},
|
||||
BasicMelee { .. }
|
||||
| BasicRanged { .. }
|
||||
| RepeaterRanged { .. }
|
||||
@ -1559,7 +1568,6 @@ impl CharacterAbility {
|
||||
| ComboMelee2 { .. }
|
||||
| DiveMelee { .. }
|
||||
| RiposteMelee { .. }
|
||||
| RapidMelee { .. }
|
||||
| BasicBeam { .. }
|
||||
| Boost { .. }
|
||||
| ComboMelee { .. }
|
||||
@ -2820,6 +2828,7 @@ impl From<(&CharacterAbility, AbilityInfo, &JoinData<'_>)> for CharacterState {
|
||||
max_strikes,
|
||||
move_modifier,
|
||||
ori_modifier,
|
||||
minimum_combo,
|
||||
meta: _,
|
||||
} => CharacterState::RapidMelee(rapid_melee::Data {
|
||||
static_data: rapid_melee::StaticData {
|
||||
@ -2831,6 +2840,7 @@ impl From<(&CharacterAbility, AbilityInfo, &JoinData<'_>)> for CharacterState {
|
||||
max_strikes: *max_strikes,
|
||||
move_modifier: *move_modifier,
|
||||
ori_modifier: *ori_modifier,
|
||||
minimum_combo: *minimum_combo,
|
||||
ability_info,
|
||||
},
|
||||
timer: Duration::default(),
|
||||
|
@ -4,6 +4,7 @@ use crate::{
|
||||
behavior::{CharacterBehavior, JoinData},
|
||||
utils::*,
|
||||
},
|
||||
event::ServerEvent,
|
||||
};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use std::time::Duration;
|
||||
@ -25,6 +26,7 @@ pub struct StaticData {
|
||||
pub max_strikes: Option<u32>,
|
||||
pub move_modifier: f32,
|
||||
pub ori_modifier: f32,
|
||||
pub minimum_combo: u32,
|
||||
/// What key is used to press ability
|
||||
pub ability_info: AbilityInfo,
|
||||
}
|
||||
@ -45,7 +47,7 @@ pub struct Data {
|
||||
}
|
||||
|
||||
impl CharacterBehavior for Data {
|
||||
fn behavior(&self, data: &JoinData, _: &mut OutputEvents) -> StateUpdate {
|
||||
fn behavior(&self, data: &JoinData, output_events: &mut OutputEvents) -> StateUpdate {
|
||||
let mut update = StateUpdate::from(data);
|
||||
|
||||
handle_orientation(data, &mut update, self.static_data.ori_modifier, None);
|
||||
@ -65,6 +67,14 @@ impl CharacterBehavior for Data {
|
||||
c.timer = Duration::default();
|
||||
c.stage_section = StageSection::Action;
|
||||
}
|
||||
|
||||
// Consume combo if any was required
|
||||
if self.static_data.minimum_combo > 0 {
|
||||
output_events.emit_server(ServerEvent::ComboChange {
|
||||
entity: data.entity,
|
||||
change: -data.combo.map_or(0, |c| c.counter() as i32),
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
StageSection::Action => {
|
||||
|
@ -851,330 +851,6 @@ impl Animation for ComboAnimation {
|
||||
next.control.orientation.rotate_x(move2 * 2.7);
|
||||
next.control.position += Vec3::new(0.0, move2 * -9.0, move2 * 17.0);
|
||||
},
|
||||
Some("common.abilities.sword.defensive_combo") => {
|
||||
let (move1, move2) = if strike == current_strike {
|
||||
match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powf(0.5)),
|
||||
Some(StageSection::Recover) => (1.0, 1.0),
|
||||
_ => (0.0, 0.0),
|
||||
}
|
||||
} else {
|
||||
(1.0, 1.0)
|
||||
};
|
||||
let move1 = move1 * multi_strike_pullback;
|
||||
let move2 = move2 * multi_strike_pullback;
|
||||
|
||||
match strike {
|
||||
0 => {
|
||||
let s1_move1_hack = if current_strike == 1 { move1 } else { 0.0 };
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation = Quaternion::rotation_x(s_a.shl.3)
|
||||
* Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position = Vec3::new(
|
||||
-s_a.sc.0 + 6.0 + move1 * -12.0,
|
||||
-4.0 + move1 * 3.0,
|
||||
-2.0,
|
||||
);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3)
|
||||
* Quaternion::rotation_z(s1_move1_hack * PI);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.8);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.3);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.2);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.6);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move1 * 5.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.9);
|
||||
next.head.orientation.rotate_z(move2 * 1.3);
|
||||
next.belt.orientation.rotate_z(move2 * 0.7);
|
||||
next.shorts.orientation.rotate_z(move2 * 1.5);
|
||||
next.control.orientation.rotate_y(move2 * -1.6);
|
||||
next.control.orientation.rotate_z(move2 * -1.1);
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * 12.0, move2 * 5.0, move2 * -1.0);
|
||||
},
|
||||
1 => {
|
||||
next.belt.orientation.rotate_z(move1 * 0.2);
|
||||
next.shorts.orientation.rotate_z(move1 * 0.3);
|
||||
next.control.position += Vec3::new(0.0, move1 * -5.0, move1 * 1.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * 2.1);
|
||||
next.head.orientation.rotate_z(move2 * -1.2);
|
||||
next.belt.orientation.rotate_z(move2 * -1.0);
|
||||
next.shorts.orientation.rotate_z(move2 * -1.8);
|
||||
next.control.orientation.rotate_z(move2 * 0.9);
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * -12.0, move2 * 2.0, move2 * -1.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
},
|
||||
Some("common.abilities.sword.parrying_combo") => {
|
||||
let (move1, move2) = if strike == current_strike {
|
||||
match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.5), 0.0),
|
||||
Some(StageSection::Action) => {
|
||||
(1.0, (anim_time.min(2.0 / 3.0) * 1.5).powi(2))
|
||||
},
|
||||
Some(StageSection::Recover) => (1.0, 1.0),
|
||||
_ => (0.0, 0.0),
|
||||
}
|
||||
} else {
|
||||
(1.0, 1.0)
|
||||
};
|
||||
let move1 = move1 * multi_strike_pullback;
|
||||
let move2 = move2 * multi_strike_pullback;
|
||||
|
||||
match strike {
|
||||
0 => {
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation = Quaternion::rotation_x(s_a.shl.3)
|
||||
* Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position = Vec3::new(
|
||||
-s_a.sc.0 + 6.0 + move1 * -12.0,
|
||||
-4.0 + move1 * 3.0,
|
||||
-2.0,
|
||||
);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3)
|
||||
* Quaternion::rotation_z(move1 * PI / 4.0 + move2 * -PI / 2.0);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.8);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.4);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.3);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.6);
|
||||
next.control.orientation.rotate_z(move1 * -1.5);
|
||||
next.control.orientation.rotate_x(move1 * 0.5);
|
||||
next.control.orientation.rotate_y(move1 * 1.5);
|
||||
next.control.position += Vec3::new(0.0, move1 * 5.0, move1 * 12.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.5);
|
||||
next.head.orientation.rotate_z(move2 * 0.9);
|
||||
next.belt.orientation.rotate_z(move2 * 0.5);
|
||||
next.shorts.orientation.rotate_z(move2 * 1.1);
|
||||
next.control.orientation.rotate_y(move2 * -4.0);
|
||||
next.control.orientation.rotate_z(move2 * -1.0);
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * 12.0, move2 * -6.0, move2 * -9.0);
|
||||
},
|
||||
1 => {
|
||||
next.control.position +=
|
||||
Vec3::new(move1 * -10.0, move1 * 3.0, move1 * 5.0);
|
||||
next.chest.orientation.rotate_z(move1 * 1.8);
|
||||
next.head.orientation.rotate_z(move1 * -1.3);
|
||||
next.belt.orientation.rotate_z(move1 * -0.7);
|
||||
next.shorts.orientation.rotate_z(move1 * -1.4);
|
||||
next.control.orientation.rotate_z(move1.powi(2) * -2.6);
|
||||
next.control.orientation.rotate_x(move1 * 0.3);
|
||||
next.control.orientation.rotate_y(move1 * -0.2);
|
||||
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * 12.0, move2 * 2.0, move2 * -1.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
},
|
||||
Some("common.abilities.sword.parrying_counter") => {
|
||||
let (move1, move2) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.5), 0.0),
|
||||
Some(StageSection::Action) => {
|
||||
(1.0, (anim_time.min(2.0 / 3.0) * 1.5).powi(2))
|
||||
},
|
||||
Some(StageSection::Recover) => (1.0, 1.0),
|
||||
_ => (0.0, 0.0),
|
||||
};
|
||||
let move1 = move1 * multi_strike_pullback;
|
||||
let move2 = move2 * multi_strike_pullback;
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3)
|
||||
* Quaternion::rotation_z(move2 * -PI / 4.0);
|
||||
|
||||
next.foot_l.position = Vec3::new(-s_a.foot.0, s_a.foot.1, s_a.foot.2);
|
||||
next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1, s_a.foot.2);
|
||||
next.foot_l.orientation = Quaternion::identity();
|
||||
next.foot_r.orientation = Quaternion::identity();
|
||||
|
||||
next.foot_r.position +=
|
||||
Vec3::new(0.0, move1 * 4.0, (1.0 - (move1 - 0.5) * 2.0) * 2.0);
|
||||
next.torso.position += Vec3::new(0.0, move1 * -2.0, 0.0);
|
||||
next.chest.position += Vec3::new(0.0, move1 * 2.0, move1 * -3.0);
|
||||
next.shorts.orientation = Quaternion::rotation_x(move1 * 0.5);
|
||||
next.shorts.position += Vec3::new(0.0, move1 * 1.5, 0.0);
|
||||
next.control.orientation.rotate_y(move1 * -1.5);
|
||||
next.control.orientation.rotate_z(move1 * 0.8);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move2 * -0.7);
|
||||
next.head.orientation = Quaternion::rotation_z(move2 * 0.4);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.5);
|
||||
next.belt.orientation = Quaternion::rotation_z(move2 * 0.1);
|
||||
next.control.orientation.rotate_z(move2 * -1.4);
|
||||
next.control.orientation.rotate_x(move2 * 0.5);
|
||||
next.control.position += Vec3::new(move2 * 7.0, 0.0, move2 * 6.0);
|
||||
},
|
||||
Some("common.abilities.sword.mobility_combo") => {
|
||||
let (move1, move2) = if strike == current_strike {
|
||||
match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powi(2)),
|
||||
Some(StageSection::Recover) => (1.0, 1.0),
|
||||
_ => (0.0, 0.0),
|
||||
}
|
||||
} else {
|
||||
(1.0, 1.0)
|
||||
};
|
||||
let move1 = move1 * multi_strike_pullback;
|
||||
let move2 = move2 * multi_strike_pullback;
|
||||
|
||||
match strike {
|
||||
0 => {
|
||||
let rotate_hack = if current_strike > 0 { move1 * 1.9 } else { 0.0 }
|
||||
+ if current_strike > 2 { move1 * 0.0 } else { 0.0 };
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation = Quaternion::rotation_x(s_a.shl.3)
|
||||
* Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position = Vec3::new(
|
||||
-s_a.sc.0 + 6.0 + move1 * -12.0,
|
||||
-4.0 + move1 * 3.0,
|
||||
-2.0,
|
||||
);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3)
|
||||
* Quaternion::rotation_z(move2 * -0.3 + rotate_hack);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.3);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.1);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.2);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.1);
|
||||
next.control.orientation.rotate_y(move1 * -0.3);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move1 * 7.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.0);
|
||||
next.head.orientation.rotate_z(move2 * 0.6);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.7);
|
||||
next.belt.orientation.rotate_z(move2 * 0.3);
|
||||
next.control.orientation.rotate_x(move2 * -1.1);
|
||||
next.control.orientation.rotate_z(move2 * -0.3);
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * 11.0, move2 * 3.0, move2 * -8.0);
|
||||
},
|
||||
1 => {
|
||||
next.control.position += Vec3::new(0.0, 0.0, move1 * 4.0);
|
||||
next.control.orientation.rotate_x(move1 * 0.1);
|
||||
next.control.orientation.rotate_z(move1 * -0.2);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * 1.4);
|
||||
next.head.orientation.rotate_z(move2 * -0.8);
|
||||
next.shorts.orientation.rotate_z(move2 * -0.9);
|
||||
next.belt.orientation.rotate_z(move2 * -0.5);
|
||||
next.control.position += Vec3::new(move2 * -9.0, 0.0, 0.0);
|
||||
next.control.orientation.rotate_z(move2 * 0.7);
|
||||
},
|
||||
2 => {
|
||||
next.control.orientation.rotate_y(move1 * -3.7);
|
||||
next.control.orientation.rotate_z(move1 * 0.6);
|
||||
next.control.position += Vec3::new(0.0, move1 * -2.0, move1 * -4.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.3);
|
||||
next.head.orientation.rotate_z(move2 * 0.7);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.9);
|
||||
next.belt.orientation.rotate_z(move2 * 0.4);
|
||||
next.control.orientation.rotate_z(move2 * -0.7);
|
||||
next.control.orientation.rotate_x(move2 * 0.3);
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * 10.0, move2 * 2.0, move2 * 8.0);
|
||||
},
|
||||
3 => {
|
||||
next.control.orientation.rotate_x(move1 * -0.5);
|
||||
next.control.orientation.rotate_z(move1 * -1.3);
|
||||
next.control.orientation.rotate_x(move1 * 4.4);
|
||||
next.control.orientation.rotate_z(move1 * 1.3);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move1 * -6.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * 1.2);
|
||||
next.head.orientation.rotate_z(move2 * -0.7);
|
||||
next.shorts.orientation.rotate_z(move2 * -0.8);
|
||||
next.belt.orientation.rotate_z(move2 * -0.3);
|
||||
next.control.position += Vec3::new(move2 * -9.0, 0.0, move2 * 4.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
},
|
||||
Some("common.abilities.sword.reaching_combo") => {
|
||||
let (move1, move2) = if strike == current_strike {
|
||||
match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powi(2)),
|
||||
Some(StageSection::Recover) => (1.0, 1.0),
|
||||
_ => (0.0, 0.0),
|
||||
}
|
||||
} else {
|
||||
(1.0, 1.0)
|
||||
};
|
||||
let move1 = move1 * multi_strike_pullback;
|
||||
let move2 = move2 * multi_strike_pullback;
|
||||
|
||||
match strike {
|
||||
0 => {
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation = Quaternion::rotation_x(s_a.shl.3)
|
||||
* Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position = Vec3::new(
|
||||
-s_a.sc.0 + 6.0 + move1 * -12.0,
|
||||
-4.0 + move1 * 3.0,
|
||||
-2.0,
|
||||
);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * -0.6);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * 0.3);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * 0.4);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * 0.2);
|
||||
next.control.orientation.rotate_x(move1 * -1.05);
|
||||
next.control.orientation.rotate_z(move1 * 0.6);
|
||||
next.control.position += Vec3::new(move1 * 12.0, move1 * -2.0, 0.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * 0.6);
|
||||
next.head.orientation.rotate_z(move2 * -0.2);
|
||||
next.shorts.orientation.rotate_z(move2 * -0.4);
|
||||
next.belt.orientation.rotate_z(move2 * -0.2);
|
||||
next.control.orientation.rotate_z(move2 * -0.6);
|
||||
next.control.position +=
|
||||
Vec3::new(move2 * -2.0, move2 * 12.0, move2 * 5.0);
|
||||
},
|
||||
1 => {
|
||||
next.chest.orientation.rotate_z(move1 * 0.5);
|
||||
next.head.orientation.rotate_z(move1 * -0.3);
|
||||
next.shorts.orientation.rotate_z(move1 * -0.3);
|
||||
next.belt.orientation.rotate_z(move1 * -0.1);
|
||||
next.control.orientation.rotate_z(move1 * -0.5);
|
||||
next.control.position +=
|
||||
Vec3::new(move1 * -7.0, move1 * -12.0, move1 * -4.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.0);
|
||||
next.head.orientation.rotate_z(move2 * 0.4);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.6);
|
||||
next.belt.orientation.rotate_z(move2 * 0.2);
|
||||
next.control.orientation.rotate_z(move2 * 1.0);
|
||||
next.control.position += Vec3::new(0.0, move2 * 11.0, move2 * 3.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
}
|
||||
|
@ -27,10 +27,10 @@ impl Animation for DashAnimation {
|
||||
#[allow(clippy::single_match)] // TODO: Pending review in #587
|
||||
fn update_skeleton_inner(
|
||||
skeleton: &Self::Skeleton,
|
||||
(_hands, ability_id, _global_time, stage_section, _ability_info): Self::Dependency<'_>,
|
||||
anim_time: f32,
|
||||
(_hands, ability_id, _global_time, _stage_section, _ability_info): Self::Dependency<'_>,
|
||||
_anim_time: f32,
|
||||
rate: &mut f32,
|
||||
s_a: &SkeletonAttr,
|
||||
_s_a: &SkeletonAttr,
|
||||
) -> Self::Skeleton {
|
||||
*rate = 1.0;
|
||||
let mut next = (*skeleton).clone();
|
||||
@ -43,42 +43,6 @@ impl Animation for DashAnimation {
|
||||
next.off_weapon_trail = true;
|
||||
|
||||
match ability_id {
|
||||
Some("common.abilities.sword.reaching_charge") => {
|
||||
let (move1, move2, move3, move4) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0, 0.0),
|
||||
Some(StageSection::Charge) => (1.0, anim_time, 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, 1.0, anim_time.powi(2), 0.0),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0, 0.0),
|
||||
};
|
||||
let pullback = 1.0 - move4;
|
||||
let move1 = move1 * pullback;
|
||||
let _move2 = move2 * pullback;
|
||||
let move3 = move3 * pullback;
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3);
|
||||
|
||||
next.chest.orientation.rotate_z(move1 * 0.4);
|
||||
next.head.orientation.rotate_z(move1 * -0.2);
|
||||
next.shorts.orientation.rotate_z(move1 * -0.3);
|
||||
next.belt.orientation.rotate_z(move1 * -0.1);
|
||||
next.control.orientation.rotate_z(move1 * -0.7);
|
||||
|
||||
next.control.orientation.rotate_x(move3 * -1.1);
|
||||
next.chest.orientation.rotate_z(move3 * -1.1);
|
||||
next.head.orientation.rotate_z(move3 * 0.4);
|
||||
next.shorts.orientation.rotate_z(move3 * 0.5);
|
||||
next.belt.orientation.rotate_z(move3 * 0.2);
|
||||
next.control.orientation.rotate_z(move3 * 0.9);
|
||||
next.control.position += Vec3::new(0.0, move3 * 6.0, 0.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
|
||||
|
@ -32,7 +32,7 @@ impl Animation for FinisherMeleeAnimation {
|
||||
next.off_weapon_trail = true;
|
||||
|
||||
match ability_id {
|
||||
Some("common.abilities.sword.balanced_finisher") => {
|
||||
Some("common.abilities.sword.basic_mighty_strike") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powf(0.1), 0.0),
|
||||
@ -64,91 +64,7 @@ impl Animation for FinisherMeleeAnimation {
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.25 + move2 * 0.2);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.5 + move2 * 0.4);
|
||||
},
|
||||
Some("common.abilities.sword.offensive_finisher") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powi(2), 0.0),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0),
|
||||
};
|
||||
let pullback = 1.0 - move3;
|
||||
let move1 = move1 * pullback;
|
||||
let move2 = move2 * pullback;
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.9);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.4);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.25);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.6);
|
||||
next.foot_l.orientation = Quaternion::rotation_z(move1 * 0.8);
|
||||
next.foot_l.position += Vec3::new(0.0, move1 * -5.0, 0.0);
|
||||
next.control.orientation.rotate_x(move1 * 1.2);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move1 * 6.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.7);
|
||||
next.head.orientation.rotate_z(move2 * 0.8);
|
||||
next.belt.orientation.rotate_z(move2 * 0.5);
|
||||
next.shorts.orientation.rotate_z(move2 * 1.1);
|
||||
next.foot_l.orientation.rotate_z(move2 * -0.8);
|
||||
next.foot_l.position += Vec3::new(0.0, move2 * 5.0, 0.0);
|
||||
next.control.orientation.rotate_x(move2 * -2.3);
|
||||
next.control.orientation.rotate_z(move2 * 0.6);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move2 * -10.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move3 * 0.6);
|
||||
next.head.orientation.rotate_z(move3 * -0.2);
|
||||
next.shorts.orientation.rotate_z(move3 * -0.2);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move3 * 4.0);
|
||||
next.control.orientation.rotate_x(move3 * 0.6);
|
||||
},
|
||||
Some("common.abilities.sword.cleaving_finisher") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.5), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powi(2), 0.0),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0),
|
||||
};
|
||||
|
||||
let move2_fast = move2.powf(0.25);
|
||||
|
||||
let pullback = 1.0 - move3;
|
||||
let move1 = move1 * pullback;
|
||||
let move2 = move2 * pullback;
|
||||
let move2_fast = move2_fast * pullback;
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation =
|
||||
Quaternion::rotation_x(s_a.sc.3) * Quaternion::rotation_z(move1 * -0.7);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.4);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.1);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.1);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.3);
|
||||
next.control.orientation.rotate_x(move1 * 1.4);
|
||||
next.control.position += Vec3::new(move1 * -2.0, 0.0, move1 * 8.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -0.9);
|
||||
next.head.orientation.rotate_z(move2 * 0.5);
|
||||
next.belt.orientation.rotate_z(move2 * 0.3);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.7);
|
||||
next.control.orientation.rotate_x(move2_fast * -2.8);
|
||||
next.control.position += Vec3::new(move2 * 12.0, 0.0, move2 * -10.0);
|
||||
},
|
||||
Some("common.abilities.sword.heavy_finisher") => {
|
||||
Some("common.abilities.sword.heavy_guillotine") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powi(2), 0.0),
|
||||
@ -192,6 +108,51 @@ impl Animation for FinisherMeleeAnimation {
|
||||
next.control.position += Vec3::new(0.0, move2 * 12.0, 0.0);
|
||||
next.control.orientation.rotate_z(move2 * -0.1);
|
||||
},
|
||||
Some("common.abilities.sword.defensive_counter") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.5), 0.0, 0.0),
|
||||
Some(StageSection::Action) => {
|
||||
(1.0, (anim_time.min(2.0 / 3.0) * 1.5).powi(2), 0.0)
|
||||
},
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0),
|
||||
};
|
||||
let pullback = 1.0 - move3;
|
||||
let move1 = move1 * pullback;
|
||||
let move2 = move2 * pullback;
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation =
|
||||
Quaternion::rotation_x(s_a.sc.3) * Quaternion::rotation_z(move2 * -PI / 4.0);
|
||||
|
||||
next.foot_l.position = Vec3::new(-s_a.foot.0, s_a.foot.1, s_a.foot.2);
|
||||
next.foot_r.position = Vec3::new(s_a.foot.0, s_a.foot.1, s_a.foot.2);
|
||||
next.foot_l.orientation = Quaternion::identity();
|
||||
next.foot_r.orientation = Quaternion::identity();
|
||||
|
||||
next.foot_r.position +=
|
||||
Vec3::new(0.0, move1 * 4.0, (1.0 - (move1 - 0.5) * 2.0) * 2.0);
|
||||
next.torso.position += Vec3::new(0.0, move1 * -2.0, 0.0);
|
||||
next.chest.position += Vec3::new(0.0, move1 * 2.0, move1 * -3.0);
|
||||
next.shorts.orientation = Quaternion::rotation_x(move1 * 0.5);
|
||||
next.shorts.position += Vec3::new(0.0, move1 * 1.5, 0.0);
|
||||
next.control.orientation.rotate_y(move1 * -1.5);
|
||||
next.control.orientation.rotate_z(move1 * 0.8);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move2 * -0.7);
|
||||
next.head.orientation = Quaternion::rotation_z(move2 * 0.4);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.5);
|
||||
next.belt.orientation = Quaternion::rotation_z(move2 * 0.1);
|
||||
next.control.orientation.rotate_z(move2 * -1.4);
|
||||
next.control.orientation.rotate_x(move2 * 0.5);
|
||||
next.control.position += Vec3::new(move2 * 7.0, 0.0, move2 * 6.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
|
||||
|
@ -21,7 +21,7 @@ impl Animation for RapidMeleeAnimation {
|
||||
#[cfg_attr(feature = "be-dyn-lib", export_name = "character_rapid_melee")]
|
||||
fn update_skeleton_inner(
|
||||
skeleton: &Self::Skeleton,
|
||||
(ability_id, stage_section, (current_strike, max_strikes), _ability_info): Self::Dependency<
|
||||
(ability_id, stage_section, (current_strike, _max_strikes), _ability_info): Self::Dependency<
|
||||
'_,
|
||||
>,
|
||||
anim_time: f32,
|
||||
@ -39,7 +39,10 @@ impl Animation for RapidMeleeAnimation {
|
||||
next.off_weapon_trail = true;
|
||||
|
||||
match ability_id {
|
||||
Some("common.abilities.sword.cleaving_whirlwind_slice") => {
|
||||
Some(
|
||||
"common.abilities.sword.cleaving_whirlwind_slice"
|
||||
| "common.abilities.sword.cleaving_bladestorm",
|
||||
) => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time, 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time, 0.0),
|
||||
@ -92,16 +95,15 @@ impl Animation for RapidMeleeAnimation {
|
||||
Some(
|
||||
"common.abilities.sword.agile_perforate" | "common.abilities.sword.agile_flurry",
|
||||
) => {
|
||||
let (move1, move2, move3, move2alt) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0, 0.0),
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (
|
||||
1.0,
|
||||
anim_time.min(0.5).mul(2.0).powi(2) - anim_time.max(0.5).sub(0.5).mul(2.0),
|
||||
0.0,
|
||||
anim_time.powi(2),
|
||||
),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4), 1.0),
|
||||
_ => (0.0, 0.0, 0.0, 0.0),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0),
|
||||
};
|
||||
let pullback = 1.0 - move3;
|
||||
let move1 = move1 * pullback;
|
||||
@ -131,6 +133,100 @@ impl Animation for RapidMeleeAnimation {
|
||||
next.control.orientation.rotate_z(move2 * 1.2);
|
||||
next.control.position += Vec3::new(0.0, move2 * 12.0, 0.0);
|
||||
},
|
||||
Some("common.abilities.sword.agile_hundred_cuts") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (1.0, anim_time.powf(0.25), 0.0),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0),
|
||||
};
|
||||
let pullback = 1.0 - move3;
|
||||
let move1 = move1 * pullback;
|
||||
let move2 = move2 * pullback;
|
||||
let (move2a, move2b, move2c, move2d) = match current_strike % 4 {
|
||||
0 => (move2, 0.0, 0.0, 0.0),
|
||||
1 => (1.0, move2, 0.0, 0.0),
|
||||
2 => (1.0, 1.0, move2, 0.0),
|
||||
3 => (1.0, 1.0, 1.0, move2),
|
||||
_ => (0.0, 0.0, 0.0, 0.0),
|
||||
};
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.4);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.2);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.2);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.1);
|
||||
next.control.orientation.rotate_y(move1 * -1.2);
|
||||
next.control.position += Vec3::new(0.0, 0.0, move1 * 10.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2a * -0.2);
|
||||
next.control.orientation.rotate_z(move2a * -2.0);
|
||||
next.control.position += Vec3::new(move2a * 12.0, 0.0, move2a * -6.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2b * 0.2);
|
||||
next.control.orientation.rotate_z(move2b * 2.9);
|
||||
next.control.position += Vec3::new(move2b * -12.0, 0.0, 0.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2c * -0.2);
|
||||
next.control.orientation.rotate_z(move2c * -2.3);
|
||||
next.control.position += Vec3::new(move2c * 12.0, 0.0, move2c * 12.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2d * -0.2);
|
||||
next.control.orientation.rotate_z(move2d * -2.7);
|
||||
next.control.position += Vec3::new(move2d * 12.0, 0.0, move2a * -6.0);
|
||||
},
|
||||
|
||||
Some("common.abilities.sword.crippling_mutilate") => {
|
||||
let (move1, move2, move3) = match stage_section {
|
||||
Some(StageSection::Buildup) => (anim_time.powf(0.25), 0.0, 0.0),
|
||||
Some(StageSection::Action) => (
|
||||
1.0,
|
||||
if current_strike % 2 == 0 {
|
||||
anim_time
|
||||
} else {
|
||||
1.0 - anim_time
|
||||
},
|
||||
0.0,
|
||||
),
|
||||
Some(StageSection::Recover) => (1.0, 1.0, anim_time.powi(4)),
|
||||
_ => (0.0, 0.0, 0.0),
|
||||
};
|
||||
let pullback = 1.0 - move3;
|
||||
let move1 = move1 * pullback;
|
||||
let move2 = move2 * pullback;
|
||||
|
||||
next.hand_l.position = Vec3::new(s_a.shl.0, s_a.shl.1, s_a.shl.2);
|
||||
next.hand_l.orientation =
|
||||
Quaternion::rotation_x(s_a.shl.3) * Quaternion::rotation_y(s_a.shl.4);
|
||||
next.hand_r.position =
|
||||
Vec3::new(-s_a.sc.0 + 6.0 + move1 * -12.0, -4.0 + move1 * 3.0, -2.0);
|
||||
next.hand_r.orientation = Quaternion::rotation_x(0.9 + move1 * 0.5);
|
||||
next.control.position = Vec3::new(s_a.sc.0, s_a.sc.1, s_a.sc.2);
|
||||
next.control.orientation = Quaternion::rotation_x(s_a.sc.3);
|
||||
|
||||
next.chest.orientation = Quaternion::rotation_z(move1 * 0.7);
|
||||
next.head.orientation = Quaternion::rotation_z(move1 * -0.4);
|
||||
next.shorts.orientation = Quaternion::rotation_z(move1 * -0.5);
|
||||
next.belt.orientation = Quaternion::rotation_z(move1 * -0.2);
|
||||
next.control.orientation.rotate_x(move1 * -0.6);
|
||||
next.control.orientation.rotate_z(move1 * -0.7);
|
||||
next.control.position += Vec3::new(move1 * 1.0, move1 * -4.0, move1 * 4.0);
|
||||
|
||||
next.chest.orientation.rotate_z(move2 * -1.2);
|
||||
next.head.orientation.rotate_z(move2 * 0.6);
|
||||
next.belt.orientation.rotate_z(move2 * 0.3);
|
||||
next.shorts.orientation.rotate_z(move2 * 0.7);
|
||||
next.control.orientation.rotate_z(move2 * 1.2);
|
||||
next.control.position += Vec3::new(0.0, move2 * 14.0, move2 * 12.0);
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user