Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
About
A straightforward but robust input-action manager for Bevy.
Inputs from various input sources (keyboard, mouse and gamepad) are collected into a common ActionState
on your player entity,
which can be conveniently used in your game logic.
The mapping between inputs and actions is many-to-many, and easily configured and extended with the InputMap
components on each player entity.
A single action can be triggered by multiple inputs (or set directly by UI elements or gameplay logic),
and a single input can result in multiple actions being triggered, which can be handled contextually.
Supported Bevy Versions
Bevy | leafwing-input-manager |
---|---|
0.15 | 0.16 |
0.14 | 0.14..0.15 |
0.13 | 0.13 |
0.12 | 0.11..0.12 |
0.11 | 0.10 |
0.10 | 0.9 |
0.9 | 0.7..0.8 |
Features
- Full keyboard, mouse and joystick support for button-like and axis inputs
- Dual axis support for analog inputs from gamepads and joysticks
- Expressive and easy-to-use axis processing for deadzones, sensitivity and clamping
- Bind arbitrary button inputs into virtual D-Pads
- Effortlessly wire UI buttons to game state with one simple component!
- When clicked, your button will press the appropriate action on the corresponding entity
- Store all your input mappings in a single
InputMap
component- No more bespoke
Keybindings<KeyCode>
,Keybindings<Gamepad>
headaches
- No more bespoke
- Look up your current input state in a single
ActionState
component- That pesky maximum of 16 system parameters got you down? Say goodbye to that input handling mega-system
- Ergonomic insertion API that seamlessly blends multiple input types for you
- Can't decide between
input_map.insert(Action::Jump, KeyCode::Space)
andinput_map.insert(Action::Jump, GamepadButton::South)
? Have both!
- Can't decide between
- Full support for arbitrary button combinations: chord your heart out.
input_map.insert(Action::Console, ButtonlikeChord::new([KeyCode::ControlLeft, KeyCode::Shift, KeyCode::KeyC]))
- Sophisticated input disambiguation with the
ClashStrategy
enum: stop triggering individual buttons when you meant to press a chord! - Create an arbitrary number of strongly typed disjoint action sets by adding multiple copies of this plugin: decouple your camera and player state
- Local multiplayer support: freely bind keys to distinct entities, rather than worrying about singular global state
- Networked multiplayer support: serializable structs, and a space-conscious
ActionDiff
representation to send on the wire - Powerful and easy-to-use input mocking API for integration testing your Bevy applications
- Control which state this plugin is active in: stop wandering around while in a menu!
- Leafwing Studio's trademark
#![forbid(missing_docs)]
Limitations
- Gamepads must be manually assigned to each input map: read from the
Gamepads
resource and useInputMap::set_gamepad
.
Getting started
- Add
leafwing-input-manager
to yourCargo.toml
. - Create an enum of the logical actions you want to represent, and derive the
Actionlike
trait for it. - Add the
InputManagerPlugin
to yourApp
. - Add the
InputManagerBundle
to your player entity (or entities!). - Configure a mapping between your inputs and your actions by modifying the
InputMap
component on your player entity. - Read the
ActionState
component on your player entity to check the collected input state!
use *;
use *;
// This is the list of "things in the game I want to be able to do based on input"
;
// Query for the `ActionState` component in your game logic systems!
This snippet is the minimal.rs
example from the examples
folder: check there for more in-depth learning materials!
Crate Feature Flags
Please refer to the [features]
section in the Cargo.toml
for information about the available crate features.