IsGamepadButtonDown
For thread safety, this property is not safe to read in an unsynchronized thread.
This functions allows a developer to quickly check if a particular button is pressed on a particular gamepad. It returns true if the Enum/UserInputType|gamepad has the specified Enum/KeyCode|button pressed down, otherwise it returns false.
Valid UserInputTypes
The specified gamepad should be one of the following UserInputType enum values:
| Name | 
|---|
| Enum.UserInputType.Gamepad1-8 | 
Valid KeyCodes
The specified button should be one of the following KeyCodes enum values:
| Name | 
|---|
| Enum.KeyCode.ButtonX | 
| Enum.KeyCode.ButtonY | 
| Enum.KeyCode.ButtonA | 
| Enum.KeyCode.ButtonB | 
| Enum.KeyCode.ButtonR1 | 
| Enum.KeyCode.ButtonL1 | 
| Enum.KeyCode.ButtonR3 | 
| Enum.KeyCode.ButtonL3 | 
| Enum.KeyCode.ButtonStart | 
| Enum.KeyCode.ButtonSelect | 
| Enum.KeyCode.DPadLeft | 
| Enum.KeyCode.DPadRight | 
| Enum.KeyCode.DPadUp | 
| Enum.KeyCode.DPadDown | 
This can be used to check whether a specific button, such as A, is being held down. For example:
local UserInputService = game:GetService("UserInputService")
local button = Enum.KeyCode.ButtonA
local gamepad = Enum.UserInputType.Gamepad1
local isButtonHeld = UserInputService:IsGamepadButtonDown(gamepad, button)
Since UserInputService is client-side only, this function can only be used in a LocalScript.
See this page for articles on cross-platform development.
See also
- UserInputService/GamepadConnected
- UserInputService/GamepadDisconnected
- UserInputService/GetConnectedGamepads
- UserInputService/GetNavigationGamepads
- UserInputService/SetNavigationGamepad
- UserInputService/IsNavigationGamepad
- UserInputService/GetSupportedGamepadKeyCodes
- UserInputService/GetGamepadState
- UserInputService/GetGamepadConnected
- UserInputService/GamepadSupports
- UserInputService/GamepadEnabled
- UserInputType/IsKeyDown- A similar event with a different use: To check if a given- Enum/KeyCode|keyon a- Enum/UserInputType|keyboardis pressed.
Parameters
| Name | Type | Default | Description | 
|---|---|---|---|
|  | The  | ||
|  | The  | 
Returns
| Return Type | Summary | 
|---|---|
| Whether the specified gamepad button on the given gamepad is pressed is pressed | 
Code Samples
Special Action on Gamepad Button Combo
This example uses the UserInputService/IsGamepadButtonDown function to create different behaviors when the Enum/KeyCode|X gamepad button is pressed than when a X button is not pressed when user input UserInputBegan|begins.
The local function IsGamepadXDown() returns whether the X gamepad button is down. This function checks if the X button is down for the activeGamepad, which is set by GetActiveGamepad. The GetActiveGamepad() fnction finds the lowest numbered UserInputService/GetNavigationGamepads|navigation gamepad, UserInputService/GetConnectedGamepads|connected gamepad, or Enum/KeyCode|gamepad1 if there are no navigation or connected gamepads.