mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
c984035976
- Separate `invite` machinery from `group_manip` into it's own thing (includes renaming `group_invite` to `invite` where applicable). - Move some invite/trade machinery to `ControlEvent`. - Make `TradePhase` a proper enum instead of a bunch of bools. - Make `TradeId` a proper newtype. - Remove trades from `Trades` on accept (previously was only on decline). - Typo fixes/misc cleanup. - Add bullet point for trading to the changelog.
84 lines
2.1 KiB
Rust
84 lines
2.1 KiB
Rust
use vek::Vec2;
|
|
|
|
pub struct KeyState {
|
|
pub right: bool,
|
|
pub left: bool,
|
|
pub up: bool,
|
|
pub down: bool,
|
|
pub climb_up: bool,
|
|
pub climb_down: bool,
|
|
pub swim_up: bool,
|
|
pub swim_down: bool,
|
|
pub fly: bool,
|
|
pub toggle_wield: bool,
|
|
pub toggle_glide: bool,
|
|
pub toggle_lantern: bool,
|
|
pub toggle_sit: bool,
|
|
pub toggle_sneak: bool,
|
|
pub toggle_dance: bool,
|
|
pub auto_walk: bool,
|
|
pub swap_loadout: bool,
|
|
pub respawn: bool,
|
|
pub interact: bool,
|
|
pub trade: bool,
|
|
pub analog_matrix: Vec2<f32>,
|
|
}
|
|
|
|
impl Default for KeyState {
|
|
fn default() -> Self {
|
|
Self {
|
|
right: false,
|
|
left: false,
|
|
up: false,
|
|
down: false,
|
|
climb_up: false,
|
|
climb_down: false,
|
|
swim_up: false,
|
|
swim_down: false,
|
|
fly: false,
|
|
toggle_wield: false,
|
|
toggle_glide: false,
|
|
toggle_lantern: false,
|
|
toggle_sit: false,
|
|
toggle_sneak: false,
|
|
toggle_dance: false,
|
|
auto_walk: false,
|
|
swap_loadout: false,
|
|
respawn: false,
|
|
interact: false,
|
|
trade: false,
|
|
analog_matrix: Vec2::zero(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl KeyState {
|
|
pub fn dir_vec(&self) -> Vec2<f32> {
|
|
let dir = if self.analog_matrix == Vec2::zero() {
|
|
Vec2::<f32>::new(
|
|
if self.right { 1.0 } else { 0.0 } + if self.left { -1.0 } else { 0.0 },
|
|
if self.up || self.auto_walk { 1.0 } else { 0.0 }
|
|
+ if self.down { -1.0 } else { 0.0 },
|
|
)
|
|
} else {
|
|
self.analog_matrix
|
|
};
|
|
|
|
if dir.magnitude_squared() <= 1.0 {
|
|
dir
|
|
} else {
|
|
dir.normalized()
|
|
}
|
|
}
|
|
|
|
pub fn climb(&self) -> Option<common::comp::Climb> {
|
|
use common::comp::Climb;
|
|
match (self.climb_up, self.climb_down) {
|
|
(true, false) => Some(Climb::Up),
|
|
(false, true) => Some(Climb::Down),
|
|
(true, true) => Some(Climb::Hold),
|
|
(false, false) => None,
|
|
}
|
|
}
|
|
}
|