Keyboard - stingray.Keyboard namespace reference - Stingray Lua API Reference

Description

A global singleton that represents the keyboard.

Keyboard button names

The following set of button names are available in all keyboards:

escape, enter, space, backspace, tab, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z, minus, equal, comma, period, open bracket, close bracket, semicolon, quote, slash, backslash, backtick left shift, left ctrl, left alt, left system, right shift, right ctrl, right alt, right system, f1, f2, f3, f4, f5, f6, f7, f8, f9, f10, f11, f12, f13, f14, f15, f16, f17, f18, f19, f20, f21, f22, f23, f24, insert, delete, home, end, page up, page down, up, down, left, right, numpad 0, numpad 1, numpad 2, numpad 3, numpad 4, numpad 5, numpad 6, numpad 7, numpad 8, numpad 9, numpad +, numpad -, numpad *, numpad /, numpad ., numpad enter, num lock, caps lock, scroll lock, print screen, break

For backward compatibility, the following set of alternate button names are available in all keyboards:

esc, num -, scrol lock, left win, right win, arrow up, arrow down, arrow left, arrow right, oem_minus (_ -), oem_plus (+ =), oem_comma (< ,), oem_period (> .), oem_1 (: ;), oem_2 (? /), oem_3 (~ `), oem_4 ({ [), oem_5 (| ), oem_6 (} ]), oem_7 (\" ')

The following set of button names are only available for Windows keyboards:

attn, clear, cr sel, er eof, execute, ex sel, icoclr, icohlp, noname, oem_102 (> <), oem_8 (?!), oem attn, auto, ax, back tab, oemclr, copy, cu sel, enlw, finish, loya, mashu, roya, touroku, jump, oempa1, oempa2, oempa3, reset, wsctrl, pa1, packet, play, process, select, separator, zoom, accept, context menu, convert, final, help, ico00 *, junja, kana, kanji, app1, app2, mail, media, left button **, middle button **, next track, play / pause, previous track, stop, mode change, non convert, jisho, pause, print, right button **, shift, sleep, volume down, volume mute, volume up, x button 1 **, x button 2 **

Keyboard axis names

none.

Keystroke interface

In addition to the common set of functions offered by all Stingray input controllers, Keyboards have an alternate way to read keystrokes used to input text, offered by the keystrokes() function. Using this interface, you do not read extended keys like Shift; instead, you retrieve the actual characters typed. Keystrokes are represented by strings for printable characters, and numbers for special keys that you want to detect for simple keyboard input applications.

Getting values from buttons and axes

All types of input controllers have built-in sets of named buttons and "axes" that represent the different ways users can provide input to the controller.

  • Each button can be pressed or released in any given frame. You can detect these events by calling pressed() and released(). The controller will also produce a value between 0 and 1 for that button, which you can retrieve by calling button().
  • Each axis can produce a Vector3 value. In some cases this value is normalized: typically when the axis indicates a variable value along some kind of scale, such as the direction a player is pushing a thumbstick. For example, a thumbstick on a game pad might be pushed fully to the left (1,0,0), fully up (0,1,0), diagonally left and up (0.707107, 0.707107, 0), etc. Alternatively, in some cases axes produce coordinate values in 3D space or in 2D screen space.

To check if the keyboard button k is pressed, you would use:

local k_key_id = stingray.Keyboard.button_id("k")      -- retrieve the button ID
local isPressed = stingray.Keyboard.button(k_key_id)   -- use the ID to access the value

Similarly, to get the current position of the Windows mouse cursor in 2D screen space, you would use:

local cursor_axis_id = stingray.Mouse.axis_id("cursor")    -- retrieve the axis ID
local value = stingray.Mouse.axis(cursor_axis_id)          -- use the ID to access to value

Or, to get the direction the player is pushing the right thumbstick on a game pad, you would use:

local right_axis_id = stingray.Pad1.axis_id("right")
local value = stingray.Pad1.axis(right_axis_id)

Getting all button and axis names

The names of the buttons and axes you can query are different for each kind of controller, and may be different on different platforms. If you need to check the available buttons for a device, you can retrieve a current list by running the following snippets of code in the Status Bar of the editor, or in your game project. Replace Mouse with the name of the controller whose values you want to check.

Functions

Parameters
This function does not accept any parameters.
Returns

boolean

Returns true if the controller is active, or false otherwise.

Parameters
This function does not accept any parameters.
Returns

string

One of the following values: gamepad, touch_panel, mouse or keyboard.

Parameters
This function does not accept any parameters.
Returns

boolean

Returns true if the controller was attached this frame, or false otherwise.

Parameters
This function does not accept any parameters.
Returns

boolean

Returns true if the controller was disconnected this frame, or false otherwise.

Parameters
This function does not accept any parameters.
Returns

any(string, integer)[]

Each entry in the returned table can be either a string or an integer. String values indicate that the player pressed the corresponding key. Integer values refer to the keystroke constant values.

The any(...) notation indicates that this item may be an instance of any of the types shown in the parentheses.
The [] notation indicates that this type is an array: a table in which the keys of the members are sequential integers, and the value of each element is an instance of the type shown.
Parameters
This function does not accept any parameters.
Returns

string

A string that contains a unique name for the controller.

In most cases this name will be a variant of the string returned by type(), with an additional counter added.

Parameters
This function does not accept any parameters.
Returns

string

A string that describes the type of the controller device.

This identifier will be the same for all controllers of the same model (with some exceptions): e.g. xbox_controller, logitech_mx518_mouse or generic_105_key_keyboard. Note that this value may be the same regardless of the input device model on some platforms.

Parameters
This function does not accept any parameters.
Returns

integer?

The Xbox Live or PSN ID of the user using the pad, or nil if there is no user connected to the pad.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

Only available in games running on PlayStation 4 and Xbox One, not on Windows.

Buttons and axes

The functions in this group relate to getting values from the buttons and axes tracked by this controller.

Parameters
This function does not accept any parameters.
Returns

integer?

The id of the first button that the player pressed this frame, or nil if the player did not press any buttons.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

If so, returns the id of the first button the player pressed.

Parameters
This function does not accept any parameters.
Returns

integer?

The id of the first button that the player released this frame, or nil if the player did not release any buttons.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

If so, returns the id of the first button the player released.

Parameters

id :

integer

The id of the axis whose value will be retrieved.

dead_zone_mode :

integer?

Specifies the kind of dead zone to be applied before returning the value read from the controller. This value may be any of the dead zone mode constants. If you specify this parameter, you must also specify the dead_zone_size. If omitted, the default dead zone values you set using [InputController.set_dead_zone()] are used.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

dead_zone_size :

number?

The size of the dead zone to apply to the value read from the controller.

The ? notation indicates that this type is optional: there may be zero or one instances of it.
Returns

stingray.Vector3

The input value of the controller for the axis with the specified id.

Note that the dead zone configuration controls are only available for non-touch interfaces.

Parameters

name :

string

The name of the axis whose id you want to retrieve.

Returns

integer

The id of the axis, or nil if no axis is found with a matching name.

Parameters

id :

integer

The id of the axis whose name you want to retrieve.

Returns

string

The name of the axis.

Parameters

id :

integer

The id of the button whose name you want to retrieve.

Returns

string

The name of the button in the locale set for the controller.

This is typically useful only for keyboard controllers.

Parameters

id :

integer

The id of the button whose name you want to retrieve.

Returns

string

The name of the button, or an empty string if no button is found with a matching id.

Parameters
This function does not accept any parameters.
Returns

integer

The number of axes on the controller.

Parameters
This function does not accept any parameters.
Returns

integer

The number of buttons on the controller.

Parameters

id :

integer

The id of the button you want to test.

Returns

boolean

Returns true if the player pressed the button during this frame, of false otherwise.

Parameters

id :

integer

The id of the button you want to test.

Returns

boolean

Returns true if the player released the button during this frame, of false otherwise.

Dead zones

A "dead zone" is a region in which the input values read by the controller are clamped to zero.

When a controller such as a thumbstick becomes old or loose, its "at-rest" position may cause a small input value to be sent to the game engine, even though the player is not actively pressing on the controller. This can cause visual artifacts such as characters or cameras that continually rotate or slide.

The dead zone mitigates this problem by applying minimum thresholds to the input values, below which the values are assumed to be noise rather than intentional input from the player.

Input values that fall inside the circle are ignored.

Input values that fall inside the square are ignored.

The engine provides the raw input values read from the controller.

Parameters

id :

integer

The id of the axis whose dead zone value will be retrieved.

Returns

integer

Specifies the kind of dead zone that will be applied when accessing the value read from the controller for the specified axis. This value may be any of the dead zone mode constants.

number

The size of the dead zone to apply to the value read from the controller.

Parameters

id :

integer

The id of the axis whose default dead zone will be set.

dead_zone_mode :

integer

Specifies the kind of dead zone to be applied before returning the values read from the controller. This value may be any of the dead zone mode constants.

dead_zone_size :

number

The size of the dead zone to apply to the values read from the controller.

Returns
This function does not return any values.

These default dead zone values will be called when you retrieve the controller's input value for an axis by calling axis() without specifying any dead zone settings in your function call.

Keystrokes

The constants in this group are used to represent non-character keys in the table returned by the keystrokes() function.

BACKSPACE : integer

Represents the Backspace key.

DELETE : integer

Represents the Delete key.

DOWN : integer

Represents the down arrow key.

END : integer

Represents the End key.

ENTER : integer

Represents the Enter key.

ESCAPE : integer

Represents the Esc key.

F1 : integer

Represents the F1 key.

F10 : integer

Represents the F10 key.

F11 : integer

Represents the F11 key.

F12 : integer

Represents the F12 key.

F2 : integer

Represents the F2 key.

F3 : integer

Represents the F3 key.

F4 : integer

Represents the F4 key.

F5 : integer

Represents the F5 key.

F6 : integer

Represents the F6 key.

F7 : integer

Represents the F7 key.

F8 : integer

Represents the F8 key.

F9 : integer

Represents the F9 key.

HOME : integer

Represents the Home key.

INSERT : integer

Represents the Insert key.

LEFT : integer

Represents the left arrow key.

PAGE_DOWN : integer

Represents the Page Down key.

PAGE_UP : integer

Represents the Page Up key.

RIGHT : integer

Represents the right arrow key.

TAB : integer

Represents the Tab key.

UP : integer

Represents the up arrow key.

Rumble

The engine has a built-in rumble effect system that lets you play rumble pulses with specific strength and duration on supporting devices.

When you use the rumble effect system, you only need to call rumble_effect() once to start a rumble effect. The engine will take care of modulating the rumble and fade it out at the end of its duration. If there are multiple rumble effects in play, their effects are added.

A rumble effect works analogously to a synthesizer note: it is a sine wave played within an ADSR-envelope (see http://en.wikipedia.org/wiki/Synthesizer#ADSR_envelope).

If you need more detailed control over the rumbling, you can use the set_rumble() method instead. That method allows you to directly set the rumble strength of each motor. Note that if you use this method, you are responsible for fading out the rumbles, and for applying any changes you want.

If you use both rumble_effect() and set_rumble(), the values are added.

The functions in this category are only useful for input controllers that contain rumble motors, like console gamepads.

Rumble motor names

The names of the rumble motors are:

Xbox One controllers:

  • left
  • right
  • left_trigger (only available when running on Xbox One, not on Windows.)
  • right_trigger (only available when running on Xbox One, not on Windows.)

PlayStation 4 controllers:

Rumble settings are only available for PlayStation 4 when running on a PlayStation 4, not when using a PlayStation 4 controller on Windows.

  • small
  • large
Parameters

motor_id :

integer

The id of the rumble motor you want to test.

ID :

integer

The ID of the rumble effect.

Returns

boolean

Returns true if a rumble event with the specified ID was created by a call to rumble_effect() and that effect is still playing, or false otherwise.

Parameters
This function does not accept any parameters.
Returns

integer

The number of rumble motors in the controller.

Parameters

motor_id :

integer

The id of the rumble motor you want to activate.

params :

input_rumble_params

A table that provides detailed settings for the new rumble effect.

Returns

integer

An ID for the newly created rumble effect.

Parameters

motor_name :

string

The name of the rumble motor whose id you want to retrieve.

Returns

integer?

The id of the rumble motor, or nil if no such motor exists.

The ? notation indicates that this type is optional: there may be zero or one instances of it.
Parameters

motor_id :

integer

The id of the rumble motor whose name you want to retrieve.

Returns

string

The name of the rumble motor.

Parameters

motor_id :

integer

The id of the rumble motor you want to activate.

value :

number

The strength of the rumble to set, expressed as a value between 0 (no rumble) and 1 (full strength).

Returns
This function does not return any values.

The rumble continues at the same strength until you change it either by calling set_rumble() again, or by calling rumble_effect().

Parameters

do_rumble :

boolean

Use true to enable the rumble engine for this controller, or false to disable rumbling.

Returns
This function does not return any values.
Parameters

motor_id :

integer

The id of the rumble motor you want to deactivate.

Returns
This function does not return any values.
Parameters

motor_id :

integer

The id of the rumble motor you want to deactivate.

ID :

integer

The ID of the rumble effect.

Returns
This function does not return any values.

Deprecated functions

Use the _id versions of these functions instead.

Parameters

name :

string

The name of the axis whose id you want to retrieve.

Returns

integer

The index of the axis, or nil if no axis is found with a matching name.

Axes must be referred to by IDs, not indices. Please use axis_id() instead.

Parameters

name :

string

The name of the button whose id you want to retrieve.

Returns

integer

The index of the button, or nil if no button is found with a matching name.

Buttons must be referred to by IDs, not indices. Please use button_id() instead.

Parameters

motor_name :

string

The name of the rumble motor whose id you want to retrieve.

Returns

integer?

The index of the rumble motor, or nil if no such motor exists.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

Rumble motors must be referred to by IDs, not indices. Please use rumble_motor_id() instead.

PlayStation 4 pads

The functions in this category are only available for PlayStation 4 pads.

Note that PlayStation 4, users can be logged in on pads. Unless your game is specified as a single player game, users can log in and log out at any time. Therefore you need to call user_id() in your main loop to poll for changes.

Parameters

color :

color

The new color for the light bar.

Returns
This function does not return any values.

Only available for PlayStation 4 pads in games running on the PlayStation 4.