Class PlayerInput | Input System | 1.0.2
docs.unity.cn
    Show / Hide Table of Contents

    Class PlayerInput

    Represents a separate player in the game complete with a set of actions exclusive to the player and a set of paired device.

    Inheritance
    Object
    Object
    Component
    Behaviour
    MonoBehaviour
    PlayerInput
    Inherited Members
    MonoBehaviour.IsInvoking()
    MonoBehaviour.CancelInvoke()
    MonoBehaviour.Invoke(String, Single)
    MonoBehaviour.InvokeRepeating(String, Single, Single)
    MonoBehaviour.CancelInvoke(String)
    MonoBehaviour.IsInvoking(String)
    MonoBehaviour.StartCoroutine(String)
    MonoBehaviour.StartCoroutine(String, Object)
    MonoBehaviour.StartCoroutine(IEnumerator)
    MonoBehaviour.StopCoroutine(IEnumerator)
    MonoBehaviour.StopCoroutine(Coroutine)
    MonoBehaviour.StopCoroutine(String)
    MonoBehaviour.StopAllCoroutines()
    MonoBehaviour.print(Object)
    MonoBehaviour.useGUILayout
    MonoBehaviour.runInEditMode
    Behaviour.enabled
    Behaviour.isActiveAndEnabled
    Component.GetComponent(Type)
    Component.GetComponent<T>()
    Component.TryGetComponent(Type, Component)
    Component.TryGetComponent<T>(T)
    Component.GetComponent(String)
    Component.GetComponentInChildren(Type, Boolean)
    Component.GetComponentInChildren(Type)
    Component.GetComponentInChildren<T>(Boolean)
    Component.GetComponentInChildren<T>()
    Component.GetComponentsInChildren(Type, Boolean)
    Component.GetComponentsInChildren(Type)
    Component.GetComponentsInChildren<T>(Boolean)
    Component.GetComponentsInChildren<T>(Boolean, List<T>)
    Component.GetComponentsInChildren<T>()
    Component.GetComponentsInChildren<T>(List<T>)
    Component.GetComponentInParent(Type)
    Component.GetComponentInParent<T>()
    Component.GetComponentsInParent(Type, Boolean)
    Component.GetComponentsInParent(Type)
    Component.GetComponentsInParent<T>(Boolean)
    Component.GetComponentsInParent<T>(Boolean, List<T>)
    Component.GetComponentsInParent<T>()
    Component.GetComponents(Type)
    Component.GetComponents(Type, List<Component>)
    Component.GetComponents<T>(List<T>)
    Component.GetComponents<T>()
    Component.CompareTag(String)
    Component.SendMessageUpwards(String, Object, SendMessageOptions)
    Component.SendMessageUpwards(String, Object)
    Component.SendMessageUpwards(String)
    Component.SendMessageUpwards(String, SendMessageOptions)
    Component.SendMessage(String, Object)
    Component.SendMessage(String)
    Component.SendMessage(String, Object, SendMessageOptions)
    Component.SendMessage(String, SendMessageOptions)
    Component.BroadcastMessage(String, Object, SendMessageOptions)
    Component.BroadcastMessage(String, Object)
    Component.BroadcastMessage(String)
    Component.BroadcastMessage(String, SendMessageOptions)
    Component.transform
    Component.gameObject
    Component.tag
    Object.GetInstanceID()
    Object.GetHashCode()
    Object.Equals(Object)
    Object.Instantiate(Object, Vector3, Quaternion)
    Object.Instantiate(Object, Vector3, Quaternion, Transform)
    Object.Instantiate(Object)
    Object.Instantiate(Object, Transform)
    Object.Instantiate(Object, Transform, Boolean)
    Object.Instantiate<T>(T)
    Object.Instantiate<T>(T, Vector3, Quaternion)
    Object.Instantiate<T>(T, Vector3, Quaternion, Transform)
    Object.Instantiate<T>(T, Transform)
    Object.Instantiate<T>(T, Transform, Boolean)
    Object.Destroy(Object, Single)
    Object.Destroy(Object)
    Object.DestroyImmediate(Object, Boolean)
    Object.DestroyImmediate(Object)
    Object.FindObjectsOfType(Type)
    Object.DontDestroyOnLoad(Object)
    Object.FindObjectsOfType<T>()
    Object.FindObjectOfType<T>()
    Object.FindObjectOfType(Type)
    Object.ToString()
    Object.name
    Object.hideFlags
    Namespace: UnityEngine.InputSystem
    Syntax
    [AddComponentMenu("Input/Player Input")]
    [DisallowMultipleComponent]
    public class PlayerInput : MonoBehaviour
    Remarks

    PlayerInput is a high-level wrapper around much of the input system's functionality which is meant to help getting set up with the new input system quickly. It takes care of InputAction bookkeeping and has a custom UI(requires the "Unity UI" package) to help setting up input.

    The component supports local multiplayer implicitly. Each PlayerInput instance represents a distinct user with its own set of devices and actions. To orchestrate player management and facilitate mechanics such as joining by device activity, use PlayerInputManager.

    The way PlayerInput notifies script code of events is determined by notificationBehavior. By default, this is set to SendMessages which will use SendMessage to send messages to the GameObject that PlayerInput sits on.

    // Component to sit next to PlayerInput.
    [RequireComponent(typeof(PlayerInput))]
    public class MyPlayerLogic : MonoBehaviour
    {
        public GameObject projectilePrefab;
    
        private Vector2 m_Look;
        private Vector2 m_Move;
        private bool m_Fire;
    
        // 'Fire' input action has been triggered. For 'Fire' we want continuous
        // action (i.e. firing) while the fire button is held such that the action
        // gets triggered repeatedly while the button is down. We can easily set this
        // up by having a "Press" interaction on the button and setting it to repeat
        // at fixed intervals.
        public void OnFire()
        {
            Instantiate(projectilePrefab);
        }
    
        // 'Move' input action has been triggered.
        public void OnMove(InputValue value)
        {
            m_Move = value.Get<Vector2>();
        }
    
        // 'Look' input action has been triggered.
        public void OnLook(InputValue value)
        {
            m_Look = value.Get<Vector2>();
        }
    
        public void OnUpdate()
        {
            // Update transform from m_Move and m_Look
        }
    }

    It is also possible to use the polling API of InputActions (see triggered and ReadValue<TValue>()) in combination with PlayerInput.

    // Component to sit next to PlayerInput.
    [RequireComponent(typeof(PlayerInput))]
    public class MyPlayerLogic : MonoBehaviour
    {
        public GameObject projectilePrefab;
    
        private PlayerInput m_PlayerInput;
        private InputAction m_LookAction;
        private InputAction m_MoveAction;
        private InputAction m_FireAction;
    
        public void OnUpdate()
        {
            // First update we look up all the data we need.
            // NOTE: We don't do this in OnEnable as PlayerInput itself performing some
            //       initialization work in OnEnable.
            if (m_PlayerInput == null)
            {
                m_PlayerInput = GetComponent<PlayerInput>();
                m_FireAction = m_PlayerInput.actions["fire"];
                m_LookAction = m_PlayerInput.actions["look"];
                m_MoveAction = m_PlayerInput.actions["move"];
            }
    
            if (m_FireAction.triggered)
                /* firing logic... */;
    
            var move = m_MoveAction.ReadValue<Vector2>();
            var look = m_LookAction.ReadValue<Vector2>();
            /* Update transform from move&look... */
        }
    }

    When enabled, PlayerInput will create an InputUser and pair devices to the user which are then specific to the player. The set of devices can be controlled explicitly when instantiating a PlayerInput through Instantiate(GameObject, Int32, String, Int32, InputDevice[]) or Instantiate(GameObject, Int32, String, Int32, InputDevice). This also makes it possible to assign the same device to two different players, e.g. for split-keyboard play.

    var p1 = PlayerInput.Instantiate(playerPrefab,
        controlScheme: "KeyboardLeft", device: Keyboard.current);
    var p2 = PlayerInput.Instantiate(playerPrefab,
        controlScheme: "KeyboardRight", device: Keyboard.current);

    If no specific devices are given to a PlayerInput, the component will look for compatible devices present in the system and pair them to itself automatically. If the PlayerInput's actions have control schemes defined for them, PlayerInput will look for a control scheme for which all required devices are available and not paired to any other player. It will try defaultControlScheme first (if set), but then fall back to trying all available schemes in order. Once a scheme is found for which all required devices are available, PlayerInput will pair those devices to itself and select the given scheme.

    If no control schemes are defined, PlayerInput will try to bind as many as-of-yet unpaired devices to itself as it can match to bindings present in the actions. This means that if, for example, there's binding for both keyboard and gamepad and there is one keyboard and two gamepads available when PlayerInput is enabled, all three devices will be paired to the player.

    Note that when using PlayerInputManager, device pairing to players is controlled from the joining logic. In that case, PlayerInput will automatically pair the device from which the player joined. If control schemes are present in actions, the first one compatible with that device is chosen. If additional devices are required, these will be paired from the pool of currently unpaired devices.

    Device pairings can be changed at any time by either manually controlling pairing through PerformPairingWithDevice(InputDevice, InputUser, InputUserPairingOptions) (and related methods) using a PlayerInput's assigned user or by switching control schemes (e.g. using SwitchCurrentControlScheme(String, InputDevice[])), if any are present in the PlayerInput's actions.

    When a player loses a device paired to it (e.g. when it is unplugged or loses power), InputUser will signal DeviceLost which is also surfaced as a message, deviceLostEvent, or onDeviceLost (depending on notificationBehavior). When a device is reconnected, InputUser will signal DeviceRegained which also is surfaced as a message, as deviceRegainedEvent, or onDeviceRegained (depending on notificationBehavior).

    When there is only a single active PlayerInput in the game, joining is not enabled (see joiningEnabled), and neverAutoSwitchControlSchemes is not set to true, device pairings for the player will also update automatically based on device usage.

    If control schemes are present in actions, then if a device is used (not merely plugged in but rather receives input on a non-noisy, non-synthetic control) which is compatible with a control scheme other than the currently used one, PlayerInput will attempt to switch to that control scheme. Success depends on whether all device requirements for that scheme are met from the set of available devices. If a control scheme happens, InputUser signals ControlSchemeChanged on onChange.

    If no control schemes are present in actions, PlayerInput will automatically pair any newly available device to itself if the given device has any bindings available for it.

    Both behaviors described in the previous two paragraphs are automatically disabled if more than one PlayerInput is active.

    Fields

    ControlsChangedMessage

    Name of the message that is sent with UnityEngine.Object.SendMessage when the controls used by a player are changed.

    Declaration
    public const string ControlsChangedMessage = "OnControlsChanged"
    Field Value
    Type Description
    String
    See Also
    onControlsChanged

    DeviceLostMessage

    Name of the message that is sent with UnityEngine.Object.SendMessage when a player loses a device.

    Declaration
    public const string DeviceLostMessage = "OnDeviceLost"
    Field Value
    Type Description
    String
    See Also
    onDeviceLost

    DeviceRegainedMessage

    Name of the message that is sent with UnityEngine.Object.SendMessage when a player regains a device.

    Declaration
    public const string DeviceRegainedMessage = "OnDeviceRegained"
    Field Value
    Type Description
    String
    See Also
    onDeviceRegained

    Properties

    actionEvents

    List of events invoked in response to actions being triggered.

    Declaration
    public ReadOnlyArray<PlayerInput.ActionEvent> actionEvents { get; set; }
    Property Value
    Type Description
    ReadOnlyArray<PlayerInput.ActionEvent>
    Remarks

    This array is only used if notificationBehavior is set to InvokeUnityEvents.

    actions

    Input actions associated with the player.

    Declaration
    public InputActionAsset actions { get; set; }
    Property Value
    Type Description
    InputActionAsset

    Asset holding the player's input actions.

    Remarks

    Note that every player will maintain a unique copy of the given actions such that each player receives an identical copy. When assigning the same actions to multiple players, the first player will use the given actions as is but any subsequent player will make a copy of the actions using Instantiate.

    The asset may contain an arbitrary number of action maps. By setting defaultActionMap, one of them can be selected to enabled automatically when PlayerInput is enabled. If no default action map is selected, none of the action maps will be enabled by PlayerInput itself. Use SwitchCurrentActionMap(String) or just call Enable() directly to enable a specific map.

    Notifications will be sent for all actions in the asset, not just for those in the first action map. This means that if additional maps are manually enabled and disabled, notifications will be sent for their actions as they receive input.

    See Also
    actions
    SwitchCurrentActionMap(String)

    all

    List of all players that are currently joined. Sorted by playerIndex in increasing order.

    Declaration
    public static ReadOnlyArray<PlayerInput> all { get; }
    Property Value
    Type Description
    ReadOnlyArray<PlayerInput>

    List of active PlayerInputs.

    Remarks

    While the list is sorted by playerIndex, note that this does not mean that the playerIndex of a player corresponds to the index in this list. If, for example, three players join and then the second player leaves, the list will contain one player with playerIndex 0 followed by one player with playerIndex 2.

    See Also
    JoinPlayer(Int32, Int32, String, InputDevice)
    Instantiate(GameObject, Int32, String, Int32, InputDevice)

    camera

    Optional camera associated with the player.

    Declaration
    public Camera camera { get; set; }
    Property Value
    Type Description
    Camera

    Camera specific to the player or null.

    Remarks

    This is null by default.

    Associating a camera with a player is necessary only when using split-screen (see splitScreen).

    controlsChangedEvent

    Event that is triggered when the controls used by the player change.

    Declaration
    public PlayerInput.ControlsChangedEvent controlsChangedEvent { get; }
    Property Value
    Type Description
    PlayerInput.ControlsChangedEvent
    Remarks

    This event is only used if notificationBehavior is set to InvokeUnityEvents.

    The event is trigger when the set of devices used by the player change, when the player switches to a different control scheme (see currentControlScheme), or when the bindings used by the player are changed (e.g. when rebinding them). Also, for Keyboard devices, the event is triggered when the currently used keyboard layout (see keyboardLayout) changes.

    currentActionMap

    The currently enabled action map.

    Declaration
    public InputActionMap currentActionMap { get; set; }
    Property Value
    Type Description
    InputActionMap

    Reference to the currently enabled action or null if no action map has been enabled by PlayerInput.

    Remarks

    Note that the concept of "current action map" is local to PlayerInput. You can still freely enable and disable action maps directly on the actions asset. This property only tracks which action map has been enabled under the control of PlayerInput, i.e. either by means of defaultActionMap or by using SwitchCurrentActionMap(String).

    See Also
    SwitchCurrentActionMap(String)

    currentControlScheme

    Name of the currently active control scheme.

    Declaration
    public string currentControlScheme { get; }
    Property Value
    Type Description
    String

    Name of the currently active control scheme or null.

    Remarks

    Note that this property will be null if there are no control schemes defined in actions.

    See Also
    SwitchCurrentControlScheme(InputDevice[])
    defaultControlScheme

    defaultActionMap

    Name (see name) or ID (see id) of the action map to enable by default.

    Declaration
    public string defaultActionMap { get; set; }
    Property Value
    Type Description
    String

    Action map to enable by default or null.

    Remarks

    By default, when enabled, PlayerInput will not enable any of the actions in the actions asset. By setting this property, however, PlayerInput can be made to automatically enable the respective action map.

    See Also
    currentActionMap
    SwitchCurrentActionMap(String)

    defaultControlScheme

    The default control scheme to try.

    Declaration
    public string defaultControlScheme { get; set; }
    Property Value
    Type Description
    String

    Name of the default control scheme.

    Remarks

    When PlayerInput is enabled and this is not null and not empty, the PlayerInput will look up the control scheme in controlSchemes of actions. If found, PlayerInput will try to activate the scheme. This will succeed only if all devices required by the control scheme are either already paired to the player or are available as devices not used by other PlayerInputs.

    Note that this property only determines the first control scheme to try. If using the control scheme fails, PlayerInput will fall back to trying the other control schemes (if any) available from actions.

    See Also
    SwitchCurrentControlScheme(InputDevice[])
    currentControlScheme

    deviceLostEvent

    Event that is triggered when the player loses a device (e.g. the batteries run out).

    Declaration
    public PlayerInput.DeviceLostEvent deviceLostEvent { get; }
    Property Value
    Type Description
    PlayerInput.DeviceLostEvent
    Remarks

    This event is only used if notificationBehavior is set to InvokeUnityEvents.

    deviceRegainedEvent

    Event that is triggered when the player recovers from device loss and is good to go again.

    Declaration
    public PlayerInput.DeviceRegainedEvent deviceRegainedEvent { get; }
    Property Value
    Type Description
    PlayerInput.DeviceRegainedEvent
    Remarks

    This event is only used if notificationBehavior is set to InvokeUnityEvents.

    devices

    The devices paired to the player.

    Declaration
    public ReadOnlyArray<InputDevice> devices { get; }
    Property Value
    Type Description
    ReadOnlyArray<InputDevice>

    List of devices paired to player.

    See Also
    pairedDevices

    hasMissingRequiredDevices

    Whether the player is missed required devices. This means that the player's input setup is probably at least partially non-functional.

    Declaration
    public bool hasMissingRequiredDevices { get; }
    Property Value
    Type Description
    Boolean

    True if the player is missing devices required by the control scheme.

    Remarks

    This can happen, for example, if the a device is unplugged during the game.

    See Also
    deviceRequirements
    hasMissingRequiredDevices

    inputIsActive

    Whether input is on the player is active.

    Declaration
    public bool inputIsActive { get; }
    Property Value
    Type Description
    Boolean

    If true, the player is receiving input.

    See Also
    ActivateInput()
    DeactivateInput()

    isSinglePlayer

    Whether PlayerInput operates in single-player mode.

    Declaration
    public static bool isSinglePlayer { get; }
    Property Value
    Type Description
    Boolean

    If true, there is at most a single PlayerInput.

    Remarks

    Single-player mode is active while there is at most one PlayerInput (there can also be none) and while joining is not enabled in PlayerInputManager (if one exists). See joiningEnabled.

    Automatic control scheme switching (if enabled) is predicated on single-player mode being active.

    See Also
    neverAutoSwitchControlSchemes

    neverAutoSwitchControlSchemes

    If true, do not automatically switch control schemes even when there is only a single player. By default, this property is false.

    Declaration
    public bool neverAutoSwitchControlSchemes { get; set; }
    Property Value
    Type Description
    Boolean

    If true, do not switch control schemes when other devices are used.

    Remarks

    By default, when there is only a single PlayerInput enabled, we assume that the game is in single-player mode and that the player should be able to freely switch between the control schemes supported by the game. For example, if the player is currently using mouse and keyboard, but is then switching to a gamepad, PlayerInput should automatically switch to the control scheme for gamepads, if present.

    When there is more than one PlayerInput or when joining is enabled PlayerInputManager, this behavior is automatically turned off as we wouldn't know which player is switching if a currently unpaired device is used.

    By setting this property to true, auto-switching of control schemes is forcibly turned off and will thus not be performed even if there is only a single PlayerInput in the game.

    Note that you can still switch control schemes manually using SwitchCurrentControlScheme(String, InputDevice[]).

    See Also
    currentControlScheme
    isSinglePlayer

    notificationBehavior

    Determines how the component notifies listeners about input actions and other input-related events pertaining to the player.

    Declaration
    public PlayerNotifications notificationBehavior { get; set; }
    Property Value
    Type Description
    PlayerNotifications

    How to trigger notifications on events.

    Remarks

    By default, the component will use SendMessage to send messages to the GameObject. This can be changed by selecting a different PlayerNotifications behavior.

    See Also
    actionEvents
    deviceLostEvent
    deviceRegainedEvent

    playerIndex

    Unique, zero-based index of the player. For example, 2 for the third player.

    Declaration
    public int playerIndex { get; }
    Property Value
    Type Description
    Int32

    Unique index of the player.

    Remarks

    Once assigned, a player index will not change.

    Note that the player index does not necessarily correspond to the player's index in all. The array will always contain all currently enabled players so when a player is disabled or destroyed, it will be removed from the array. However, the player index of the remaining players will not change.

    splitScreenIndex

    If split-screen is enabled (splitScreen), this is the index of the screen area used by the player.

    Declaration
    public int splitScreenIndex { get; }
    Property Value
    Type Description
    Int32

    Index of split-screen area assigned to player or -1 if the player is not using split-screen.

    Remarks

    Split screen areas are enumerated row by row and within rows, column by column. So, if, for example, there are four separate split-screen areas, the upper left one is #0, the upper right one is #1, the lower left one is #2, and the lower right one is #3.

    Split screen areas are usually assigned automatically but players can also be assigned to areas explicitly through Instantiate(GameObject, Int32, String, Int32, InputDevice) or JoinPlayer(Int32, Int32, String, InputDevice).

    See Also
    camera
    splitScreen

    uiInputModule

    UI InputModule that should have it's input actions synchronized to this PlayerInput's actions.

    Declaration
    public InputSystemUIInputModule uiInputModule { get; set; }
    Property Value
    Type Description
    InputSystemUIInputModule

    user

    The internal user tied to the player.

    Declaration
    public InputUser user { get; }
    Property Value
    Type Description
    InputUser

    Methods

    ActivateInput()

    Enable input on the player.

    Declaration
    public void ActivateInput()
    Remarks

    Input will automatically be activated when the PlayerInput component is enabled. However, this method can be called to reactivate input after deactivating it with DeactivateInput().

    Note that activating input will activate the current action map only (see currentActionMap).

    See Also
    DeactivateInput()

    DeactivateInput()

    Disable input on the player.

    Declaration
    public void DeactivateInput()
    Remarks

    Input is automatically activated when the PlayerInput component is enabled. This method can be used to deactivate input manually.

    Note that activating input will deactivate the current action map only (see currentActionMap).

    DebugLogAction(InputAction.CallbackContext)

    Debug helper method that can be hooked up to actions when using InvokeUnityEvents.

    Declaration
    public void DebugLogAction(InputAction.CallbackContext context)
    Parameters
    Type Name Description
    InputAction.CallbackContext context

    FindFirstPairedToDevice(InputDevice)

    Find the first PlayerInput who the given device is paired to.

    Declaration
    public static PlayerInput FindFirstPairedToDevice(InputDevice device)
    Parameters
    Type Name Description
    InputDevice device

    An input device.

    Returns
    Type Description
    PlayerInput

    The player who is paired to the given device or null if no PlayerInput currently is paired to device.

    Remarks
    // Find the player paired to first gamepad.
    var player = PlayerInput.FindFirstPairedToDevice(Gamepad.all[0]);
    Exceptions
    Type Condition
    ArgumentNullException

    device is null.

    GetPlayerByIndex(Int32)

    Return the Nth player.

    Declaration
    public static PlayerInput GetPlayerByIndex(int playerIndex)
    Parameters
    Type Name Description
    Int32 playerIndex

    Index of the player to return.

    Returns
    Type Description
    PlayerInput

    The player with the given player index or null if no such player exists.

    See Also
    playerIndex

    Instantiate(GameObject, Int32, String, Int32, InputDevice)

    Instantiate a player object and set up and enable its inputs.

    Declaration
    public static PlayerInput Instantiate(GameObject prefab, int playerIndex = -1, string controlScheme = null, int splitScreenIndex = -1, InputDevice pairWithDevice = null)
    Parameters
    Type Name Description
    GameObject prefab

    Prefab to clone. Must contain a PlayerInput component somewhere in its hierarchy.

    Int32 playerIndex

    Player index to assign to the player. See playerIndex. By default will be assigned automatically based on how many players are in all.

    String controlScheme

    Control scheme to activate

    Int32 splitScreenIndex
    InputDevice pairWithDevice

    Device to pair to the user. By default, this is null which means that PlayerInput will automatically pair with available, unpaired devices based on the control schemes (if any) present in actions or on the bindings therein (if no control schemes are present).

    Returns
    Type Description
    PlayerInput
    Exceptions
    Type Condition
    ArgumentNullException

    prefab is null.

    Instantiate(GameObject, Int32, String, Int32, InputDevice[])

    A wrapper around Instantiate that allows instantiating a player prefab and automatically pair one or more specific devices to the newly created player.

    Declaration
    public static PlayerInput Instantiate(GameObject prefab, int playerIndex = -1, string controlScheme = null, int splitScreenIndex = -1, params InputDevice[] pairWithDevices)
    Parameters
    Type Name Description
    GameObject prefab

    A player prefab containing a PlayerInput component in its hierarchy.

    Int32 playerIndex
    String controlScheme
    Int32 splitScreenIndex
    InputDevice[] pairWithDevices
    Returns
    Type Description
    PlayerInput
    Remarks

    Note that unlike Instantiate, this method will always activate the resulting GameObject and its components.

    SwitchCurrentActionMap(String)

    Declaration
    public void SwitchCurrentActionMap(string mapNameOrId)
    Parameters
    Type Name Description
    String mapNameOrId

    SwitchCurrentControlScheme(String, InputDevice[])

    Declaration
    public void SwitchCurrentControlScheme(string controlScheme, params InputDevice[] devices)
    Parameters
    Type Name Description
    String controlScheme
    InputDevice[] devices

    SwitchCurrentControlScheme(InputDevice[])

    Declaration
    public bool SwitchCurrentControlScheme(params InputDevice[] devices)
    Parameters
    Type Name Description
    InputDevice[] devices
    Returns
    Type Description
    Boolean

    Events

    onActionTriggered

    If notificationBehavior is set to InvokeCSharpEvents, this event is triggered when an action fires.

    Declaration
    public event Action<InputAction.CallbackContext> onActionTriggered
    Event Type
    Type Description
    Action<InputAction.CallbackContext>

    Callbacks that get called when an action triggers.

    Remarks

    If notificationBehavior is not set to InvokeCSharpEvents, the value of this property is ignored.

    The callbacks are called in sync (and with the same argument) with started, performed, and canceled.

    See Also
    actionTriggered
    started
    performed
    canceled
    actions

    onControlsChanged

    If notificationBehavior is InvokeCSharpEvents, this event is triggered when the controls used by the players are changed.

    Declaration
    public event Action<PlayerInput> onControlsChanged
    Event Type
    Type Description
    Action<PlayerInput>
    Remarks

    The callback is invoked when the set of devices used by the player change, when the player switches to a different control scheme (see currentControlScheme), or when the bindings used by the player are changed (e.g. when rebinding them). Also, for Keyboard devices, the callback is invoked when the currently used keyboard layout (see keyboardLayout) changes.

    onDeviceLost

    If notificationBehavior is InvokeCSharpEvents, this event is triggered when a device paired to the player is disconnected.

    Declaration
    public event Action<PlayerInput> onDeviceLost
    Event Type
    Type Description
    Action<PlayerInput>

    Callbacks that get called when the player loses a device.

    Remarks

    If notificationBehavior is not InvokeCSharpEvents, the value of this property is ignored.

    The argument is the player that lost its device (i.e. the player on which the callback is installed).

    See Also
    onDeviceRegained
    DeviceLost

    onDeviceRegained

    If notificationBehavior is InvokeCSharpEvents, this event is triggered when the player previously lost a device and has now regained it or an equivalent device.

    Declaration
    public event Action<PlayerInput> onDeviceRegained
    Event Type
    Type Description
    Action<PlayerInput>

    Callbacks that get called when the player regains a device.

    Remarks

    If notificationBehavior is not InvokeCSharpEvents, the value of this property is ignored.

    The argument is the player that regained a device (i.e. the player on which the callback is installed).

    See Also
    onDeviceLost
    DeviceRegained

    See Also

    PlayerInputManager
    Back to top Copyright © 2020 Unity Technologies
    Generated by DocFX
    on 22 January 2021