Input

BeginnerProgrammer

Users interact with games and applications using input devices such as gamepads, mice, and keyboards. Every interactive application must support at least one input device.

Input devices

Xenko handles input entirely via scripts. There are low-level and high-level APIs to handle different input types:

Handle input

Handle input with the InputManager class. You can access this class from a script with its properties and methods.

To check whether a particular input device is available, use the corresponding InputManager property. For example, to check if a mouse is connected, use Input.HasMouse.

After you check the device availability, there are four ways to handle input in Xenko.

Query state

You can query the state of digital keys and buttons (ie Up or Down) and the numeric values of analog buttons and sensors. For example, DownKeys gets a list of the keys that were in the state Down in the last update.

Query key and button states

Analog stick positions

Sometimes a user performs more than one action between updates. If there's no state change between the updates (the end result is the same), Xenko registers no action:

Several actions between updates

Query a state change

You can query the change of state of buttons and keys since the previous update.In this case, you don't get the list of all buttons and keys, but have to query each button and key separately.

  • For digital buttons and keys, query if the button or key was Pressed, Down or Released in the last update.

Query key state change

  • For mouse positions and mouse wheel scrolling, query Delta Values since the previous update:

Mouse wheel delta

Sometimes a user performs several actions between two updates. If there's no state change between two updates (the end result is the same), Xenko registers no action.

Query the list of events

For pointers, gestures, and keyboards, you can query all the events that happened in the last update.

Several actions between updates

Note

Even if a user performs several actions between two updates, Xenko registers all these events.

Use virtual buttons

You can use virtual buttons to associate input to actions rather than physical keys, then let the user define their own keys. For more information, see virtual buttons.

In this section