View Page Source

Revision (current)
Last Updated by feos on 8/4/2022 1:56 PM
Back to Page

----

The following table keys are used with joypad lib, stylus lib, or input lib Lua functions.

As an example, this script draws text on the screen when B is pressed:

%%SRC_EMBED lua
local table={}

while true do
  table=joypad.get(1)
  if table.B then
    gui.text(0,0, "B is pressed")
  end
  emu.frameadvance()
end
%%END_EMBED

!! Table keys

Table keys are case sensitive. Almost all keys are boolean, although ones related to position or analog are integers. The value {{nil}} or {{false}} means "not pressed", anything else means "pressed".

! Joypad lib

These keys are used with functions beginning with {{joypad}}. All keys are boolean.

Due to possible implementation differences with {{joypad.get}}, it is recommended to use boolean style 'if' ({{if table.right then}}) rather than equality comparison ({{if table.right==true then}})

Application of {{joypad.set}} only works for the following frame. It must be applied on each frame to hold down the keys.

BizHawk: We can't possibly document the possibilities here, use joypad.get() to get a list of the buttons for the current core + configuration you are using, and use those.  Also joypad.set(buttonName) is preferred over joypad.set(buttonName, controllerNumber).

FCEUX: {{A, B, select, start, up, down, left, right}}

Snes9x: {{R, L, X, A, right, left, down, up, start, select, Y, B}}

Gens: {{up, down, left, right, A, B, C, start, X, Y, Z, mode}}

VBA: {{A, B, select, start, right, left, up, down, R, L}}

PCSX:  {{select, l3, r3, start, up, right, down, left, l2, r2, l1, r1, triangle, circle, x, square}}

PCEjin/VBjin: {{I, II, Select, Run, Up, Right, Down, Left}}

DeSmuME (joypad lib): {{debug, R, L, X, Y, A, B, start, select, up, down, left, right, lid}}

For Final Burn Alpha, the keys are the names that the emulator uses, and are specific to each game. They are listed under input configuration.

! DeSmuME stylus lib

These keys are used with functions beginning with {{stylus}}. The key 'x' is an integer from 0 to 255, 'y' is an integer from 0 to 192, and 'touch' is a boolean.

Application of {{stylus.set}} only works for the following frame. It must be applied on each frame to hold down the stylus.

DeSmuME (stylus lib): {{x, y, touch}}

! Input lib

These keys are used with functions beginning with {{input}}.

The Lua function {{input.get}} returns a table of which keyboard buttons are pressed as well as PC mouse status. Labels refer to US keyboard layout.

All keyboard table keys are boolean.

"..." denotes an obvious sequence which has been omitted.

Keyboard: {{backspace, tab, enter, shift, control, alt, pause, capslock, escape, space, pageup, pagedown, end, home, left, up, right, down, insert, delete, 0, 1, ..., 9, A, B, ..., Z, numpad0, numpad1, ..., numpad9, numpad*, numpad+, numpad-, numpad., numpad/, F1, F2, ..., F24, numlock, scrolllock, semicolon, plus, comma, minus, period, slash, tilde, leftbracket, backslash, rightbracket, quote}}

Mouse position is returned in terms of game screen pixel coordinates. The key 'xmouse' is an integer from 0 to 255, 'ymouse' is an integer from 0 to 223, and 'leftclick', 'rightclick', and 'middleclick' are all boolean.

Mouse: {{xmouse, ymouse, leftclick, rightclick, middleclick}}