input: simpler input interface via an Input resource

This commit is contained in:
Carter Anderson 2020-06-04 22:48:53 -07:00
parent fde8292a04
commit b3a57c21a7
6 changed files with 264 additions and 199 deletions

View File

@ -0,0 +1,72 @@
use crate::keyboard::{KeyCode, KeyboardInput, ElementState};
use bevy_app::{EventReader, Events};
use legion::prelude::{Res, ResMut};
use std::collections::HashSet;
#[derive(Default)]
pub struct Input {
pressed_keys: HashSet<KeyCode>,
just_pressed_keys: HashSet<KeyCode>,
just_released_keys: HashSet<KeyCode>,
}
impl Input {
pub fn press_key(&mut self, key_code: KeyCode) {
if !self.key_pressed(key_code) {
self.just_pressed_keys.insert(key_code);
}
self.pressed_keys.insert(key_code);
}
pub fn release_key(&mut self, key_code: KeyCode) {
self.pressed_keys.remove(&key_code);
self.just_released_keys.insert(key_code);
}
pub fn key_pressed(&self, key_code: KeyCode) -> bool {
self.pressed_keys.contains(&key_code)
}
pub fn key_just_pressed(&self, key_code: KeyCode) -> bool {
self.just_pressed_keys.contains(&key_code)
}
pub fn key_just_released(&self, key_code: KeyCode) -> bool {
self.just_released_keys.contains(&key_code)
}
pub fn update(&mut self) {
self.just_pressed_keys.clear();
self.just_released_keys.clear();
}
}
#[derive(Default)]
pub struct InputState {
keyboard_input_event_reader: EventReader<KeyboardInput>,
}
pub fn input_system(
mut state: ResMut<InputState>,
mut input: ResMut<Input>,
keyboard_input_events: Res<Events<KeyboardInput>>,
) {
input.update();
for event in state
.keyboard_input_event_reader
.iter(&keyboard_input_events)
{
if let KeyboardInput {
key_code: Some(key_code),
state,
..
} = event
{
match state {
ElementState::Pressed => input.press_key(*key_code),
ElementState::Released => input.release_key(*key_code),
}
}
}
}

View File

@ -1,7 +1,7 @@
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct KeyboardInput { pub struct KeyboardInput {
pub scan_code: u32, pub scan_code: u32,
pub virtual_key_code: Option<VirtualKeyCode>, pub key_code: Option<KeyCode>,
pub state: ElementState, pub state: ElementState,
} }
@ -22,7 +22,7 @@ impl ElementState {
#[derive(Debug, Hash, Ord, PartialOrd, PartialEq, Eq, Clone, Copy)] #[derive(Debug, Hash, Ord, PartialOrd, PartialEq, Eq, Clone, Copy)]
#[repr(u32)] #[repr(u32)]
pub enum VirtualKeyCode { pub enum KeyCode {
/// The '1' key over the letters. /// The '1' key over the letters.
Key1, Key1,
/// The '2' key over the letters. /// The '2' key over the letters.

View File

@ -1,10 +1,14 @@
mod input;
pub mod keyboard; pub mod keyboard;
pub mod mouse; pub mod mouse;
pub mod system; pub mod system;
pub use input::*;
use bevy_app::{AppBuilder, AppPlugin}; use bevy_app::{AppBuilder, AppPlugin};
use keyboard::KeyboardInput; use keyboard::KeyboardInput;
use mouse::{MouseButtonInput, MouseMotionInput}; use mouse::{MouseButtonInput, MouseMotionInput};
use legion::prelude::IntoSystem;
#[derive(Default)] #[derive(Default)]
pub struct InputPlugin; pub struct InputPlugin;
@ -13,6 +17,9 @@ impl AppPlugin for InputPlugin {
fn build(&self, app: &mut AppBuilder) { fn build(&self, app: &mut AppBuilder) {
app.add_event::<KeyboardInput>() app.add_event::<KeyboardInput>()
.add_event::<MouseButtonInput>() .add_event::<MouseButtonInput>()
.add_event::<MouseMotionInput>(); .add_event::<MouseMotionInput>()
.init_resource::<Input>()
.init_resource::<InputState>()
.add_system_to_stage(bevy_app::stage::EVENT_UPDATE, input_system.system());
} }
} }

View File

@ -1,4 +1,4 @@
use crate::keyboard::{ElementState, KeyboardInput, VirtualKeyCode}; use crate::keyboard::{ElementState, KeyboardInput, KeyCode};
use bevy_app::{AppExit, EventReader, Events}; use bevy_app::{AppExit, EventReader, Events};
use legion::prelude::*; use legion::prelude::*;
@ -7,9 +7,9 @@ pub fn exit_on_esc_system(_resources: &mut Resources) -> Box<dyn Schedulable> {
(move |keyboard_input_events: Res<Events<KeyboardInput>>, (move |keyboard_input_events: Res<Events<KeyboardInput>>,
mut app_exit_events: ResMut<Events<AppExit>>| { mut app_exit_events: ResMut<Events<AppExit>>| {
for event in keyboard_input_event_reader.iter(&keyboard_input_events) { for event in keyboard_input_event_reader.iter(&keyboard_input_events) {
if let Some(virtual_key_code) = event.virtual_key_code { if let Some(key_code) = event.key_code {
if event.state == ElementState::Pressed if event.state == ElementState::Pressed
&& virtual_key_code == VirtualKeyCode::Escape && key_code == KeyCode::Escape
{ {
app_exit_events.send(AppExit); app_exit_events.send(AppExit);
} }

View File

@ -1,5 +1,5 @@
use bevy_input::{ use bevy_input::{
keyboard::{ElementState, KeyboardInput, VirtualKeyCode}, keyboard::{ElementState, KeyboardInput, KeyCode},
mouse::MouseButton, mouse::MouseButton,
}; };
@ -7,7 +7,7 @@ pub fn convert_keyboard_input(keyboard_input: &winit::event::KeyboardInput) -> K
KeyboardInput { KeyboardInput {
scan_code: keyboard_input.scancode, scan_code: keyboard_input.scancode,
state: convert_element_state(keyboard_input.state), state: convert_element_state(keyboard_input.state),
virtual_key_code: keyboard_input key_code: keyboard_input
.virtual_keycode .virtual_keycode
.map(|v| convert_virtual_key_code(v)), .map(|v| convert_virtual_key_code(v)),
} }
@ -29,168 +29,168 @@ pub fn convert_mouse_button(mouse_button: winit::event::MouseButton) -> MouseBut
} }
} }
pub fn convert_virtual_key_code(virtual_key_code: winit::event::VirtualKeyCode) -> VirtualKeyCode { pub fn convert_virtual_key_code(virtual_key_code: winit::event::VirtualKeyCode) -> KeyCode {
match virtual_key_code { match virtual_key_code {
winit::event::VirtualKeyCode::Key1 => VirtualKeyCode::Key1, winit::event::VirtualKeyCode::Key1 => KeyCode::Key1,
winit::event::VirtualKeyCode::Key2 => VirtualKeyCode::Key2, winit::event::VirtualKeyCode::Key2 => KeyCode::Key2,
winit::event::VirtualKeyCode::Key3 => VirtualKeyCode::Key3, winit::event::VirtualKeyCode::Key3 => KeyCode::Key3,
winit::event::VirtualKeyCode::Key4 => VirtualKeyCode::Key4, winit::event::VirtualKeyCode::Key4 => KeyCode::Key4,
winit::event::VirtualKeyCode::Key5 => VirtualKeyCode::Key5, winit::event::VirtualKeyCode::Key5 => KeyCode::Key5,
winit::event::VirtualKeyCode::Key6 => VirtualKeyCode::Key6, winit::event::VirtualKeyCode::Key6 => KeyCode::Key6,
winit::event::VirtualKeyCode::Key7 => VirtualKeyCode::Key7, winit::event::VirtualKeyCode::Key7 => KeyCode::Key7,
winit::event::VirtualKeyCode::Key8 => VirtualKeyCode::Key8, winit::event::VirtualKeyCode::Key8 => KeyCode::Key8,
winit::event::VirtualKeyCode::Key9 => VirtualKeyCode::Key9, winit::event::VirtualKeyCode::Key9 => KeyCode::Key9,
winit::event::VirtualKeyCode::Key0 => VirtualKeyCode::Key0, winit::event::VirtualKeyCode::Key0 => KeyCode::Key0,
winit::event::VirtualKeyCode::A => VirtualKeyCode::A, winit::event::VirtualKeyCode::A => KeyCode::A,
winit::event::VirtualKeyCode::B => VirtualKeyCode::B, winit::event::VirtualKeyCode::B => KeyCode::B,
winit::event::VirtualKeyCode::C => VirtualKeyCode::C, winit::event::VirtualKeyCode::C => KeyCode::C,
winit::event::VirtualKeyCode::D => VirtualKeyCode::D, winit::event::VirtualKeyCode::D => KeyCode::D,
winit::event::VirtualKeyCode::E => VirtualKeyCode::E, winit::event::VirtualKeyCode::E => KeyCode::E,
winit::event::VirtualKeyCode::F => VirtualKeyCode::F, winit::event::VirtualKeyCode::F => KeyCode::F,
winit::event::VirtualKeyCode::G => VirtualKeyCode::G, winit::event::VirtualKeyCode::G => KeyCode::G,
winit::event::VirtualKeyCode::H => VirtualKeyCode::H, winit::event::VirtualKeyCode::H => KeyCode::H,
winit::event::VirtualKeyCode::I => VirtualKeyCode::I, winit::event::VirtualKeyCode::I => KeyCode::I,
winit::event::VirtualKeyCode::J => VirtualKeyCode::J, winit::event::VirtualKeyCode::J => KeyCode::J,
winit::event::VirtualKeyCode::K => VirtualKeyCode::K, winit::event::VirtualKeyCode::K => KeyCode::K,
winit::event::VirtualKeyCode::L => VirtualKeyCode::L, winit::event::VirtualKeyCode::L => KeyCode::L,
winit::event::VirtualKeyCode::M => VirtualKeyCode::M, winit::event::VirtualKeyCode::M => KeyCode::M,
winit::event::VirtualKeyCode::N => VirtualKeyCode::N, winit::event::VirtualKeyCode::N => KeyCode::N,
winit::event::VirtualKeyCode::O => VirtualKeyCode::O, winit::event::VirtualKeyCode::O => KeyCode::O,
winit::event::VirtualKeyCode::P => VirtualKeyCode::P, winit::event::VirtualKeyCode::P => KeyCode::P,
winit::event::VirtualKeyCode::Q => VirtualKeyCode::Q, winit::event::VirtualKeyCode::Q => KeyCode::Q,
winit::event::VirtualKeyCode::R => VirtualKeyCode::R, winit::event::VirtualKeyCode::R => KeyCode::R,
winit::event::VirtualKeyCode::S => VirtualKeyCode::S, winit::event::VirtualKeyCode::S => KeyCode::S,
winit::event::VirtualKeyCode::T => VirtualKeyCode::T, winit::event::VirtualKeyCode::T => KeyCode::T,
winit::event::VirtualKeyCode::U => VirtualKeyCode::U, winit::event::VirtualKeyCode::U => KeyCode::U,
winit::event::VirtualKeyCode::V => VirtualKeyCode::V, winit::event::VirtualKeyCode::V => KeyCode::V,
winit::event::VirtualKeyCode::W => VirtualKeyCode::W, winit::event::VirtualKeyCode::W => KeyCode::W,
winit::event::VirtualKeyCode::X => VirtualKeyCode::X, winit::event::VirtualKeyCode::X => KeyCode::X,
winit::event::VirtualKeyCode::Y => VirtualKeyCode::Y, winit::event::VirtualKeyCode::Y => KeyCode::Y,
winit::event::VirtualKeyCode::Z => VirtualKeyCode::Z, winit::event::VirtualKeyCode::Z => KeyCode::Z,
winit::event::VirtualKeyCode::Escape => VirtualKeyCode::Escape, winit::event::VirtualKeyCode::Escape => KeyCode::Escape,
winit::event::VirtualKeyCode::F1 => VirtualKeyCode::F1, winit::event::VirtualKeyCode::F1 => KeyCode::F1,
winit::event::VirtualKeyCode::F2 => VirtualKeyCode::F2, winit::event::VirtualKeyCode::F2 => KeyCode::F2,
winit::event::VirtualKeyCode::F3 => VirtualKeyCode::F3, winit::event::VirtualKeyCode::F3 => KeyCode::F3,
winit::event::VirtualKeyCode::F4 => VirtualKeyCode::F4, winit::event::VirtualKeyCode::F4 => KeyCode::F4,
winit::event::VirtualKeyCode::F5 => VirtualKeyCode::F5, winit::event::VirtualKeyCode::F5 => KeyCode::F5,
winit::event::VirtualKeyCode::F6 => VirtualKeyCode::F6, winit::event::VirtualKeyCode::F6 => KeyCode::F6,
winit::event::VirtualKeyCode::F7 => VirtualKeyCode::F7, winit::event::VirtualKeyCode::F7 => KeyCode::F7,
winit::event::VirtualKeyCode::F8 => VirtualKeyCode::F8, winit::event::VirtualKeyCode::F8 => KeyCode::F8,
winit::event::VirtualKeyCode::F9 => VirtualKeyCode::F9, winit::event::VirtualKeyCode::F9 => KeyCode::F9,
winit::event::VirtualKeyCode::F10 => VirtualKeyCode::F10, winit::event::VirtualKeyCode::F10 => KeyCode::F10,
winit::event::VirtualKeyCode::F11 => VirtualKeyCode::F11, winit::event::VirtualKeyCode::F11 => KeyCode::F11,
winit::event::VirtualKeyCode::F12 => VirtualKeyCode::F12, winit::event::VirtualKeyCode::F12 => KeyCode::F12,
winit::event::VirtualKeyCode::F13 => VirtualKeyCode::F13, winit::event::VirtualKeyCode::F13 => KeyCode::F13,
winit::event::VirtualKeyCode::F14 => VirtualKeyCode::F14, winit::event::VirtualKeyCode::F14 => KeyCode::F14,
winit::event::VirtualKeyCode::F15 => VirtualKeyCode::F15, winit::event::VirtualKeyCode::F15 => KeyCode::F15,
winit::event::VirtualKeyCode::F16 => VirtualKeyCode::F16, winit::event::VirtualKeyCode::F16 => KeyCode::F16,
winit::event::VirtualKeyCode::F17 => VirtualKeyCode::F17, winit::event::VirtualKeyCode::F17 => KeyCode::F17,
winit::event::VirtualKeyCode::F18 => VirtualKeyCode::F18, winit::event::VirtualKeyCode::F18 => KeyCode::F18,
winit::event::VirtualKeyCode::F19 => VirtualKeyCode::F19, winit::event::VirtualKeyCode::F19 => KeyCode::F19,
winit::event::VirtualKeyCode::F20 => VirtualKeyCode::F20, winit::event::VirtualKeyCode::F20 => KeyCode::F20,
winit::event::VirtualKeyCode::F21 => VirtualKeyCode::F21, winit::event::VirtualKeyCode::F21 => KeyCode::F21,
winit::event::VirtualKeyCode::F22 => VirtualKeyCode::F22, winit::event::VirtualKeyCode::F22 => KeyCode::F22,
winit::event::VirtualKeyCode::F23 => VirtualKeyCode::F23, winit::event::VirtualKeyCode::F23 => KeyCode::F23,
winit::event::VirtualKeyCode::F24 => VirtualKeyCode::F24, winit::event::VirtualKeyCode::F24 => KeyCode::F24,
winit::event::VirtualKeyCode::Snapshot => VirtualKeyCode::Snapshot, winit::event::VirtualKeyCode::Snapshot => KeyCode::Snapshot,
winit::event::VirtualKeyCode::Scroll => VirtualKeyCode::Scroll, winit::event::VirtualKeyCode::Scroll => KeyCode::Scroll,
winit::event::VirtualKeyCode::Pause => VirtualKeyCode::Pause, winit::event::VirtualKeyCode::Pause => KeyCode::Pause,
winit::event::VirtualKeyCode::Insert => VirtualKeyCode::Insert, winit::event::VirtualKeyCode::Insert => KeyCode::Insert,
winit::event::VirtualKeyCode::Home => VirtualKeyCode::Home, winit::event::VirtualKeyCode::Home => KeyCode::Home,
winit::event::VirtualKeyCode::Delete => VirtualKeyCode::Delete, winit::event::VirtualKeyCode::Delete => KeyCode::Delete,
winit::event::VirtualKeyCode::End => VirtualKeyCode::End, winit::event::VirtualKeyCode::End => KeyCode::End,
winit::event::VirtualKeyCode::PageDown => VirtualKeyCode::PageDown, winit::event::VirtualKeyCode::PageDown => KeyCode::PageDown,
winit::event::VirtualKeyCode::PageUp => VirtualKeyCode::PageUp, winit::event::VirtualKeyCode::PageUp => KeyCode::PageUp,
winit::event::VirtualKeyCode::Left => VirtualKeyCode::Left, winit::event::VirtualKeyCode::Left => KeyCode::Left,
winit::event::VirtualKeyCode::Up => VirtualKeyCode::Up, winit::event::VirtualKeyCode::Up => KeyCode::Up,
winit::event::VirtualKeyCode::Right => VirtualKeyCode::Right, winit::event::VirtualKeyCode::Right => KeyCode::Right,
winit::event::VirtualKeyCode::Down => VirtualKeyCode::Down, winit::event::VirtualKeyCode::Down => KeyCode::Down,
winit::event::VirtualKeyCode::Back => VirtualKeyCode::Back, winit::event::VirtualKeyCode::Back => KeyCode::Back,
winit::event::VirtualKeyCode::Return => VirtualKeyCode::Return, winit::event::VirtualKeyCode::Return => KeyCode::Return,
winit::event::VirtualKeyCode::Space => VirtualKeyCode::Space, winit::event::VirtualKeyCode::Space => KeyCode::Space,
winit::event::VirtualKeyCode::Compose => VirtualKeyCode::Compose, winit::event::VirtualKeyCode::Compose => KeyCode::Compose,
winit::event::VirtualKeyCode::Caret => VirtualKeyCode::Caret, winit::event::VirtualKeyCode::Caret => KeyCode::Caret,
winit::event::VirtualKeyCode::Numlock => VirtualKeyCode::Numlock, winit::event::VirtualKeyCode::Numlock => KeyCode::Numlock,
winit::event::VirtualKeyCode::Numpad0 => VirtualKeyCode::Numpad0, winit::event::VirtualKeyCode::Numpad0 => KeyCode::Numpad0,
winit::event::VirtualKeyCode::Numpad1 => VirtualKeyCode::Numpad1, winit::event::VirtualKeyCode::Numpad1 => KeyCode::Numpad1,
winit::event::VirtualKeyCode::Numpad2 => VirtualKeyCode::Numpad2, winit::event::VirtualKeyCode::Numpad2 => KeyCode::Numpad2,
winit::event::VirtualKeyCode::Numpad3 => VirtualKeyCode::Numpad3, winit::event::VirtualKeyCode::Numpad3 => KeyCode::Numpad3,
winit::event::VirtualKeyCode::Numpad4 => VirtualKeyCode::Numpad4, winit::event::VirtualKeyCode::Numpad4 => KeyCode::Numpad4,
winit::event::VirtualKeyCode::Numpad5 => VirtualKeyCode::Numpad5, winit::event::VirtualKeyCode::Numpad5 => KeyCode::Numpad5,
winit::event::VirtualKeyCode::Numpad6 => VirtualKeyCode::Numpad6, winit::event::VirtualKeyCode::Numpad6 => KeyCode::Numpad6,
winit::event::VirtualKeyCode::Numpad7 => VirtualKeyCode::Numpad7, winit::event::VirtualKeyCode::Numpad7 => KeyCode::Numpad7,
winit::event::VirtualKeyCode::Numpad8 => VirtualKeyCode::Numpad8, winit::event::VirtualKeyCode::Numpad8 => KeyCode::Numpad8,
winit::event::VirtualKeyCode::Numpad9 => VirtualKeyCode::Numpad9, winit::event::VirtualKeyCode::Numpad9 => KeyCode::Numpad9,
winit::event::VirtualKeyCode::AbntC1 => VirtualKeyCode::AbntC1, winit::event::VirtualKeyCode::AbntC1 => KeyCode::AbntC1,
winit::event::VirtualKeyCode::AbntC2 => VirtualKeyCode::AbntC2, winit::event::VirtualKeyCode::AbntC2 => KeyCode::AbntC2,
winit::event::VirtualKeyCode::Add => VirtualKeyCode::Add, winit::event::VirtualKeyCode::Add => KeyCode::Add,
winit::event::VirtualKeyCode::Apostrophe => VirtualKeyCode::Apostrophe, winit::event::VirtualKeyCode::Apostrophe => KeyCode::Apostrophe,
winit::event::VirtualKeyCode::Apps => VirtualKeyCode::Apps, winit::event::VirtualKeyCode::Apps => KeyCode::Apps,
winit::event::VirtualKeyCode::At => VirtualKeyCode::At, winit::event::VirtualKeyCode::At => KeyCode::At,
winit::event::VirtualKeyCode::Ax => VirtualKeyCode::Ax, winit::event::VirtualKeyCode::Ax => KeyCode::Ax,
winit::event::VirtualKeyCode::Backslash => VirtualKeyCode::Backslash, winit::event::VirtualKeyCode::Backslash => KeyCode::Backslash,
winit::event::VirtualKeyCode::Calculator => VirtualKeyCode::Calculator, winit::event::VirtualKeyCode::Calculator => KeyCode::Calculator,
winit::event::VirtualKeyCode::Capital => VirtualKeyCode::Capital, winit::event::VirtualKeyCode::Capital => KeyCode::Capital,
winit::event::VirtualKeyCode::Colon => VirtualKeyCode::Colon, winit::event::VirtualKeyCode::Colon => KeyCode::Colon,
winit::event::VirtualKeyCode::Comma => VirtualKeyCode::Comma, winit::event::VirtualKeyCode::Comma => KeyCode::Comma,
winit::event::VirtualKeyCode::Convert => VirtualKeyCode::Convert, winit::event::VirtualKeyCode::Convert => KeyCode::Convert,
winit::event::VirtualKeyCode::Decimal => VirtualKeyCode::Decimal, winit::event::VirtualKeyCode::Decimal => KeyCode::Decimal,
winit::event::VirtualKeyCode::Divide => VirtualKeyCode::Divide, winit::event::VirtualKeyCode::Divide => KeyCode::Divide,
winit::event::VirtualKeyCode::Equals => VirtualKeyCode::Equals, winit::event::VirtualKeyCode::Equals => KeyCode::Equals,
winit::event::VirtualKeyCode::Grave => VirtualKeyCode::Grave, winit::event::VirtualKeyCode::Grave => KeyCode::Grave,
winit::event::VirtualKeyCode::Kana => VirtualKeyCode::Kana, winit::event::VirtualKeyCode::Kana => KeyCode::Kana,
winit::event::VirtualKeyCode::Kanji => VirtualKeyCode::Kanji, winit::event::VirtualKeyCode::Kanji => KeyCode::Kanji,
winit::event::VirtualKeyCode::LAlt => VirtualKeyCode::LAlt, winit::event::VirtualKeyCode::LAlt => KeyCode::LAlt,
winit::event::VirtualKeyCode::LBracket => VirtualKeyCode::LBracket, winit::event::VirtualKeyCode::LBracket => KeyCode::LBracket,
winit::event::VirtualKeyCode::LControl => VirtualKeyCode::LControl, winit::event::VirtualKeyCode::LControl => KeyCode::LControl,
winit::event::VirtualKeyCode::LShift => VirtualKeyCode::LShift, winit::event::VirtualKeyCode::LShift => KeyCode::LShift,
winit::event::VirtualKeyCode::LWin => VirtualKeyCode::LWin, winit::event::VirtualKeyCode::LWin => KeyCode::LWin,
winit::event::VirtualKeyCode::Mail => VirtualKeyCode::Mail, winit::event::VirtualKeyCode::Mail => KeyCode::Mail,
winit::event::VirtualKeyCode::MediaSelect => VirtualKeyCode::MediaSelect, winit::event::VirtualKeyCode::MediaSelect => KeyCode::MediaSelect,
winit::event::VirtualKeyCode::MediaStop => VirtualKeyCode::MediaStop, winit::event::VirtualKeyCode::MediaStop => KeyCode::MediaStop,
winit::event::VirtualKeyCode::Minus => VirtualKeyCode::Minus, winit::event::VirtualKeyCode::Minus => KeyCode::Minus,
winit::event::VirtualKeyCode::Multiply => VirtualKeyCode::Multiply, winit::event::VirtualKeyCode::Multiply => KeyCode::Multiply,
winit::event::VirtualKeyCode::Mute => VirtualKeyCode::Mute, winit::event::VirtualKeyCode::Mute => KeyCode::Mute,
winit::event::VirtualKeyCode::MyComputer => VirtualKeyCode::MyComputer, winit::event::VirtualKeyCode::MyComputer => KeyCode::MyComputer,
winit::event::VirtualKeyCode::NavigateForward => VirtualKeyCode::NavigateForward, winit::event::VirtualKeyCode::NavigateForward => KeyCode::NavigateForward,
winit::event::VirtualKeyCode::NavigateBackward => VirtualKeyCode::NavigateBackward, winit::event::VirtualKeyCode::NavigateBackward => KeyCode::NavigateBackward,
winit::event::VirtualKeyCode::NextTrack => VirtualKeyCode::NextTrack, winit::event::VirtualKeyCode::NextTrack => KeyCode::NextTrack,
winit::event::VirtualKeyCode::NoConvert => VirtualKeyCode::NoConvert, winit::event::VirtualKeyCode::NoConvert => KeyCode::NoConvert,
winit::event::VirtualKeyCode::NumpadComma => VirtualKeyCode::NumpadComma, winit::event::VirtualKeyCode::NumpadComma => KeyCode::NumpadComma,
winit::event::VirtualKeyCode::NumpadEnter => VirtualKeyCode::NumpadEnter, winit::event::VirtualKeyCode::NumpadEnter => KeyCode::NumpadEnter,
winit::event::VirtualKeyCode::NumpadEquals => VirtualKeyCode::NumpadEquals, winit::event::VirtualKeyCode::NumpadEquals => KeyCode::NumpadEquals,
winit::event::VirtualKeyCode::OEM102 => VirtualKeyCode::OEM102, winit::event::VirtualKeyCode::OEM102 => KeyCode::OEM102,
winit::event::VirtualKeyCode::Period => VirtualKeyCode::Period, winit::event::VirtualKeyCode::Period => KeyCode::Period,
winit::event::VirtualKeyCode::PlayPause => VirtualKeyCode::PlayPause, winit::event::VirtualKeyCode::PlayPause => KeyCode::PlayPause,
winit::event::VirtualKeyCode::Power => VirtualKeyCode::Power, winit::event::VirtualKeyCode::Power => KeyCode::Power,
winit::event::VirtualKeyCode::PrevTrack => VirtualKeyCode::PrevTrack, winit::event::VirtualKeyCode::PrevTrack => KeyCode::PrevTrack,
winit::event::VirtualKeyCode::RAlt => VirtualKeyCode::RAlt, winit::event::VirtualKeyCode::RAlt => KeyCode::RAlt,
winit::event::VirtualKeyCode::RBracket => VirtualKeyCode::RBracket, winit::event::VirtualKeyCode::RBracket => KeyCode::RBracket,
winit::event::VirtualKeyCode::RControl => VirtualKeyCode::RControl, winit::event::VirtualKeyCode::RControl => KeyCode::RControl,
winit::event::VirtualKeyCode::RShift => VirtualKeyCode::RShift, winit::event::VirtualKeyCode::RShift => KeyCode::RShift,
winit::event::VirtualKeyCode::RWin => VirtualKeyCode::RWin, winit::event::VirtualKeyCode::RWin => KeyCode::RWin,
winit::event::VirtualKeyCode::Semicolon => VirtualKeyCode::Semicolon, winit::event::VirtualKeyCode::Semicolon => KeyCode::Semicolon,
winit::event::VirtualKeyCode::Slash => VirtualKeyCode::Slash, winit::event::VirtualKeyCode::Slash => KeyCode::Slash,
winit::event::VirtualKeyCode::Sleep => VirtualKeyCode::Sleep, winit::event::VirtualKeyCode::Sleep => KeyCode::Sleep,
winit::event::VirtualKeyCode::Stop => VirtualKeyCode::Stop, winit::event::VirtualKeyCode::Stop => KeyCode::Stop,
winit::event::VirtualKeyCode::Subtract => VirtualKeyCode::Subtract, winit::event::VirtualKeyCode::Subtract => KeyCode::Subtract,
winit::event::VirtualKeyCode::Sysrq => VirtualKeyCode::Sysrq, winit::event::VirtualKeyCode::Sysrq => KeyCode::Sysrq,
winit::event::VirtualKeyCode::Tab => VirtualKeyCode::Tab, winit::event::VirtualKeyCode::Tab => KeyCode::Tab,
winit::event::VirtualKeyCode::Underline => VirtualKeyCode::Underline, winit::event::VirtualKeyCode::Underline => KeyCode::Underline,
winit::event::VirtualKeyCode::Unlabeled => VirtualKeyCode::Unlabeled, winit::event::VirtualKeyCode::Unlabeled => KeyCode::Unlabeled,
winit::event::VirtualKeyCode::VolumeDown => VirtualKeyCode::VolumeDown, winit::event::VirtualKeyCode::VolumeDown => KeyCode::VolumeDown,
winit::event::VirtualKeyCode::VolumeUp => VirtualKeyCode::VolumeUp, winit::event::VirtualKeyCode::VolumeUp => KeyCode::VolumeUp,
winit::event::VirtualKeyCode::Wake => VirtualKeyCode::Wake, winit::event::VirtualKeyCode::Wake => KeyCode::Wake,
winit::event::VirtualKeyCode::WebBack => VirtualKeyCode::WebBack, winit::event::VirtualKeyCode::WebBack => KeyCode::WebBack,
winit::event::VirtualKeyCode::WebFavorites => VirtualKeyCode::WebFavorites, winit::event::VirtualKeyCode::WebFavorites => KeyCode::WebFavorites,
winit::event::VirtualKeyCode::WebForward => VirtualKeyCode::WebForward, winit::event::VirtualKeyCode::WebForward => KeyCode::WebForward,
winit::event::VirtualKeyCode::WebHome => VirtualKeyCode::WebHome, winit::event::VirtualKeyCode::WebHome => KeyCode::WebHome,
winit::event::VirtualKeyCode::WebRefresh => VirtualKeyCode::WebRefresh, winit::event::VirtualKeyCode::WebRefresh => KeyCode::WebRefresh,
winit::event::VirtualKeyCode::WebSearch => VirtualKeyCode::WebSearch, winit::event::VirtualKeyCode::WebSearch => KeyCode::WebSearch,
winit::event::VirtualKeyCode::WebStop => VirtualKeyCode::WebStop, winit::event::VirtualKeyCode::WebStop => KeyCode::WebStop,
winit::event::VirtualKeyCode::Yen => VirtualKeyCode::Yen, winit::event::VirtualKeyCode::Yen => KeyCode::Yen,
winit::event::VirtualKeyCode::Copy => VirtualKeyCode::Copy, winit::event::VirtualKeyCode::Copy => KeyCode::Copy,
winit::event::VirtualKeyCode::Paste => VirtualKeyCode::Paste, winit::event::VirtualKeyCode::Paste => KeyCode::Paste,
winit::event::VirtualKeyCode::Cut => VirtualKeyCode::Cut, winit::event::VirtualKeyCode::Cut => KeyCode::Cut,
} }
} }

View File

@ -1,54 +1,40 @@
use bevy::{ use bevy::{input::keyboard::KeyCode, prelude::*};
input::keyboard::{KeyboardInput, VirtualKeyCode}, use bevy_input::Input;
prelude::*,
};
fn main() { fn main() {
App::build() App::build()
.add_default_plugins() .add_default_plugins()
.init_resource::<State>()
.add_startup_system(setup.system()) .add_startup_system(setup.system())
.add_system(move_on_input.system()) .add_system(move_on_input.system())
.run(); .run();
} }
#[derive(Default)]
struct State {
event_reader: EventReader<KeyboardInput>,
}
/// moves our cube left when the "left" key is pressed. moves it right when the "right" key is pressed /// moves our cube left when the "left" key is pressed. moves it right when the "right" key is pressed
fn move_on_input( fn move_on_input(
world: &mut SubWorld, world: &mut SubWorld,
mut state: ResMut<State>,
time: Res<Time>, time: Res<Time>,
keyboard_input_events: Res<Events<KeyboardInput>>, input: Res<Input>,
query: &mut Query<(Write<Translation>, Read<Handle<Mesh>>)>, query: &mut Query<(Write<Translation>, Read<Handle<Mesh>>)>,
) { ) {
let mut moving_left = false; let moving_left = input.key_pressed(KeyCode::Left);
let mut moving_right = false; let moving_right = input.key_pressed(KeyCode::Right);
for event in state.event_reader.iter(&keyboard_input_events) {
if let KeyboardInput { if input.key_just_pressed(KeyCode::Left) {
virtual_key_code: Some(key_code), println!("left just pressed");
state,
..
} = event
{
if *key_code == VirtualKeyCode::Left {
moving_left = state.is_pressed();
} else if *key_code == VirtualKeyCode::Right {
moving_right = state.is_pressed();
}
}
} }
if input.key_just_released(KeyCode::Left) {
println!("left just released");
}
const SPEED: f32 = 3.0;
for (mut translation, _) in query.iter_mut(world) { for (mut translation, _) in query.iter_mut(world) {
if moving_left { if moving_left {
translation.0 += math::vec3(1.0, 0.0, 0.0) * time.delta_seconds; translation.0 += math::vec3(SPEED, 0.0, 0.0) * time.delta_seconds;
} }
if moving_right { if moving_right {
translation.0 += math::vec3(-1.0, 0.0, 0.0) * time.delta_seconds; translation.0 += math::vec3(-SPEED, 0.0, 0.0) * time.delta_seconds;
} }
} }
} }