mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
better triple_strike
This commit is contained in:
parent
4153df66ea
commit
0cdb80427d
@ -150,6 +150,7 @@ impl From<&CharacterAbility> for CharacterState {
|
|||||||
stage: 0,
|
stage: 0,
|
||||||
stage_exhausted: false,
|
stage_exhausted: false,
|
||||||
stage_time_active: Duration::default(),
|
stage_time_active: Duration::default(),
|
||||||
|
should_transition: true,
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ use vek::vec::Vec2;
|
|||||||
const STAGE_DURATION: u64 = 600;
|
const STAGE_DURATION: u64 = 600;
|
||||||
|
|
||||||
const BASE_ACCEL: f32 = 200.0;
|
const BASE_ACCEL: f32 = 200.0;
|
||||||
const BASE_SPEED: f32 = 250.0;
|
const BASE_SPEED: f32 = 25.0;
|
||||||
/// ### A sequence of 3 incrementally increasing attacks.
|
/// ### A sequence of 3 incrementally increasing attacks.
|
||||||
///
|
///
|
||||||
/// While holding down the `primary` button, perform a series of 3 attacks,
|
/// While holding down the `primary` button, perform a series of 3 attacks,
|
||||||
@ -27,6 +27,8 @@ pub struct Data {
|
|||||||
pub stage_time_active: Duration,
|
pub stage_time_active: Duration,
|
||||||
/// Whether current stage has exhausted its attack
|
/// Whether current stage has exhausted its attack
|
||||||
pub stage_exhausted: bool,
|
pub stage_exhausted: bool,
|
||||||
|
/// Whether to go to next stage
|
||||||
|
pub should_transition: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl CharacterBehavior for Data {
|
impl CharacterBehavior for Data {
|
||||||
@ -41,26 +43,28 @@ impl CharacterBehavior for Data {
|
|||||||
server_events: VecDeque::new(),
|
server_events: VecDeque::new(),
|
||||||
};
|
};
|
||||||
|
|
||||||
let new_stage_time_active = self
|
let stage_time_active = self
|
||||||
.stage_time_active
|
.stage_time_active
|
||||||
.checked_add(Duration::from_secs_f32(data.dt.0))
|
.checked_add(Duration::from_secs_f32(data.dt.0))
|
||||||
.unwrap_or(Duration::default());
|
.unwrap_or(Duration::default());
|
||||||
|
|
||||||
|
let mut should_transition = self.should_transition;
|
||||||
|
|
||||||
// If player stops holding input,
|
// If player stops holding input,
|
||||||
if !data.inputs.primary.is_pressed() {
|
if !data.inputs.primary.is_pressed() {
|
||||||
// Done
|
// // Done
|
||||||
update.character = CharacterState::Wielding;
|
// update.character = CharacterState::Wielding;
|
||||||
// Make sure attack component is removed
|
// // Make sure attack component is removed
|
||||||
data.updater.remove::<Attacking>(data.entity);
|
// data.updater.remove::<Attacking>(data.entity);
|
||||||
return update;
|
// return update;
|
||||||
|
|
||||||
|
should_transition = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
handle_move(data, &mut update);
|
|
||||||
|
|
||||||
if self.stage < 3 {
|
if self.stage < 3 {
|
||||||
if new_stage_time_active < Duration::from_millis(STAGE_DURATION / 3) {
|
// Handling movement
|
||||||
|
if stage_time_active < Duration::from_millis(STAGE_DURATION / 3) {
|
||||||
// Move player forward while in first third of each stage
|
// Move player forward while in first third of each stage
|
||||||
// Move player according to move_dir
|
|
||||||
if update.vel.0.magnitude_squared() < BASE_SPEED.powf(2.0) {
|
if update.vel.0.magnitude_squared() < BASE_SPEED.powf(2.0) {
|
||||||
update.vel.0 =
|
update.vel.0 =
|
||||||
update.vel.0 + Vec2::broadcast(data.dt.0) * data.ori.0 * BASE_ACCEL;
|
update.vel.0 + Vec2::broadcast(data.dt.0) * data.ori.0 * BASE_ACCEL;
|
||||||
@ -69,14 +73,12 @@ impl CharacterBehavior for Data {
|
|||||||
update.vel.0 = update.vel.0.normalized() * BASE_SPEED;
|
update.vel.0 = update.vel.0.normalized() * BASE_SPEED;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
} else {
|
||||||
|
handle_orientation(data, &mut update);
|
||||||
|
}
|
||||||
|
|
||||||
update.character = CharacterState::TripleStrike(Data {
|
// Handling attacking
|
||||||
base_damage: self.base_damage,
|
if stage_time_active > Duration::from_millis(STAGE_DURATION / 2)
|
||||||
stage: self.stage,
|
|
||||||
stage_time_active: new_stage_time_active,
|
|
||||||
stage_exhausted: false,
|
|
||||||
});
|
|
||||||
} else if new_stage_time_active > Duration::from_millis(STAGE_DURATION / 2)
|
|
||||||
&& !self.stage_exhausted
|
&& !self.stage_exhausted
|
||||||
{
|
{
|
||||||
// Try to deal damage in second half of stage
|
// Try to deal damage in second half of stage
|
||||||
@ -90,22 +92,32 @@ impl CharacterBehavior for Data {
|
|||||||
update.character = CharacterState::TripleStrike(Data {
|
update.character = CharacterState::TripleStrike(Data {
|
||||||
base_damage: self.base_damage,
|
base_damage: self.base_damage,
|
||||||
stage: self.stage,
|
stage: self.stage,
|
||||||
stage_time_active: new_stage_time_active,
|
stage_time_active,
|
||||||
stage_exhausted: true,
|
stage_exhausted: true,
|
||||||
|
should_transition,
|
||||||
});
|
});
|
||||||
} else if new_stage_time_active > Duration::from_millis(STAGE_DURATION) {
|
} else if stage_time_active > Duration::from_millis(STAGE_DURATION) {
|
||||||
update.character = CharacterState::TripleStrike(Data {
|
if should_transition {
|
||||||
base_damage: self.base_damage,
|
update.character = CharacterState::TripleStrike(Data {
|
||||||
stage: self.stage + 1,
|
base_damage: self.base_damage,
|
||||||
stage_time_active: Duration::default(),
|
stage: self.stage + 1,
|
||||||
stage_exhausted: false,
|
stage_time_active: Duration::default(),
|
||||||
});
|
stage_exhausted: false,
|
||||||
|
should_transition,
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
// Done
|
||||||
|
update.character = CharacterState::Wielding;
|
||||||
|
// Make sure attack component is removed
|
||||||
|
data.updater.remove::<Attacking>(data.entity);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
update.character = CharacterState::TripleStrike(Data {
|
update.character = CharacterState::TripleStrike(Data {
|
||||||
base_damage: self.base_damage,
|
base_damage: self.base_damage,
|
||||||
stage: self.stage,
|
stage: self.stage,
|
||||||
stage_time_active: new_stage_time_active,
|
stage_time_active,
|
||||||
stage_exhausted: self.stage_exhausted,
|
stage_exhausted: self.stage_exhausted,
|
||||||
|
should_transition,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -53,6 +53,10 @@ fn basic_move(data: &JoinData, update: &mut StateUpdate) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handle_orientation(data, update);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn handle_orientation(data: &JoinData, update: &mut StateUpdate) {
|
||||||
// Set direction based on move direction
|
// Set direction based on move direction
|
||||||
let ori_dir = if update.character.is_attack() || update.character.is_block() {
|
let ori_dir = if update.character.is_attack() || update.character.is_block() {
|
||||||
Vec2::from(data.inputs.look_dir).normalized()
|
Vec2::from(data.inputs.look_dir).normalized()
|
||||||
|
@ -504,7 +504,14 @@ impl FigureMgr {
|
|||||||
)
|
)
|
||||||
},
|
},
|
||||||
CharacterState::TripleStrike(s) => match s.stage {
|
CharacterState::TripleStrike(s) => match s.stage {
|
||||||
0 | 2 => anim::character::AttackAnimation::update_skeleton(
|
0 => anim::character::AttackAnimation::update_skeleton(
|
||||||
|
&target_base,
|
||||||
|
(active_tool_kind, time),
|
||||||
|
state.state_time,
|
||||||
|
&mut state_animation_rate,
|
||||||
|
skeleton_attr,
|
||||||
|
),
|
||||||
|
1 => anim::character::AttackAnimation::update_skeleton(
|
||||||
&target_base,
|
&target_base,
|
||||||
(active_tool_kind, time),
|
(active_tool_kind, time),
|
||||||
state.state_time,
|
state.state_time,
|
||||||
|
Loading…
Reference in New Issue
Block a user