Skip to content

Gamepad

Overview

Turbo's concept of a "gamepad" is similar to a SNES controller and maps up to 2 player's local gamepad input to the keyboard:

GamepadKeyboard (P1)Keyboard (P2)
UpW or UpArrowI
DownS or DownArrowJ
LeftA or LeftArrowK
RightD or RightArrowL
AZM
BX,
XC.
YV/
StartSpace[
SelectEnter]

API

gamepad

Gets the gamepad data for a player.

pub fn gamepad(player: u32) -> Gamepad<Button>
ParamTypeDefaultDescription
playeru32The player to get gamepad input for.
Gamepad
/// Represents the state of various gamepad buttons.
#[repr(C, packed)]
#[derive(Clone, Copy, Debug, PartialEq, bytemuck::Pod, bytemuck::Zeroable)]
pub struct Gamepad<T: Copy> {
    /// The state of the up button.
    pub up: T,
    /// The state of the down button.
    pub down: T,
    /// The state of the left button.
    pub left: T,
    /// The state of the right button.
    pub right: T,
    /// The state of the A button.
    pub a: T,
    /// The state of the B button.
    pub b: T,
    /// The state of the X button.
    pub x: T,
    /// The state of the Y button.
    pub y: T,
    /// The state of the Start button.
    pub start: T,
    /// The state of the Select button.
    pub select: T,
}
Button
#[derive(Clone, Copy, Debug, PartialEq, Eq)]
pub enum Button {
    Released = 0,
    JustPressed = 1,
    Pressed = 2,
    JustReleased = 3,
}

Usage

Basics

To retrieve the gamepad state of a player, use the gamepad function. The player is 0-indexed, so 0 is player 1, 1 is player 2, etc.

// Get the gamepad state for player 1
let p1_gamepad = gamepad(0);
 
// Get the gamepad state for player 2
let p2_gamepad = gamepad(1);

Convenience Methods

To check the button states for players, utilize the following methods after obtaining the gamepad state using the gamepad function:

// Get the gamepad state for player 1
let gp = gamepad(0);
 
// Checks if the A button is JustPressed
if gp.a.just_pressed() {
    // Handle JustPressed state
}
 
// Checks if the A button is JustPressed or Pressed
if gp.a.pressed() {
    // Handle JustPressed and Pressed states
}
 
// Checks if the A button is JustReleased
if gp.a.just_released() {
    // Handle JustReleased state
}
 
// Checks if the A button is JustReleased or Released
if gp.a.released() {
    // Handle JustReleased and Released states
}

Matching Button Variants

You can also match on the Button variants directly:

// Get the gamepad state for player 1
let gp = gamepad(0);
 
// Check the input state of the Start button
match gp.start {
    Button::JustPressed => {
        // Handle the JustPressed state
    },
    Button::Pressed => {
        // Handle the Pressed state
    },
    Button::JustReleased => {
        // Handle the JustReleased state
    },
    Button::JustReleased => {
        // Handle the Released state
    },
}