com.sun.jna.platform.win32.Win32VK Maven / Gradle / Ivy
/*
* Copyright (c) 2019 Keve Müller
*
* The contents of this file is dual-licensed under 2
* alternative Open Source/Free licenses: LGPL 2.1 or later and
* Apache License 2.0.
*
* You can freely decide which license you want to apply to
* the project.
*
* You may obtain a copy of the LGPL License at:
*
* http://www.gnu.org/licenses/licenses.html
*
* A copy is also included in the downloadable source code package
* containing JNA, in file "LGPL2.1".
*
* You may obtain a copy of the Apache License at:
*
* http://www.apache.org/licenses/
*
* A copy is also included in the downloadable source code package
* containing JNA, in file "AL2.0".
*/
package com.sun.jna.platform.win32;
/**
* Windows API Virtual Key codes.
*/
public enum Win32VK {
VK_UNDEFINED(0x00),
/*
* Virtual Keys, Standard Set
*/
VK_LBUTTON(0x01),
VK_RBUTTON(0x02),
VK_CANCEL(0x03),
VK_MBUTTON(0x04), /* NOT contiguous with L & RBUTTON */
VK_XBUTTON1(0x05, 0x0500), /* NOT contiguous with L & RBUTTON */
VK_XBUTTON2(0x06, 0x0500), /* NOT contiguous with L & RBUTTON */
/*
* 0x07 : reserved
*/
VK_RESERVED_07(0x07),
VK_BACK(0x08),
VK_TAB(0x09),
/*
* 0x0A - 0x0B : reserved
*/
VK_RESERVED_0A(0x0A),
VK_RESERVED_0B(0x0B),
VK_CLEAR(0x0C),
VK_RETURN(0x0D),
/*
* 0x0E - 0x0F : unassigned
*/
VK_UNASSIGNED_0E(0x0E),
VK_UNASSIGNED_0F(0x0F),
VK_SHIFT(0x10),
VK_CONTROL(0x11),
VK_MENU(0x12),
VK_PAUSE(0x13),
VK_CAPITAL(0x14),
VK_KANA(0x15),
VK_HANGEUL(0x15), /* old name - should be here for compatibility */
VK_HANGUL(0x15),
/*
* 0x16 : unassigned
*/
VK_UNASSIGNED_16(0x16),
VK_JUNJA(0x17),
VK_FINAL(0x18),
VK_HANJA(0x19),
VK_KANJI(0x19),
/*
* 0x1A : unassigned
*/
VK_UNASSIGNED_1A(0x1A),
VK_ESCAPE(0x1B),
VK_CONVERT(0x1C),
VK_NONCONVERT(0x1D),
VK_ACCEPT(0x1E),
VK_MODECHANGE(0x1F),
VK_SPACE(0x20),
VK_PRIOR(0x21),
VK_NEXT(0x22),
VK_END(0x23),
VK_HOME(0x24),
VK_LEFT(0x25),
VK_UP(0x26),
VK_RIGHT(0x27),
VK_DOWN(0x28),
VK_SELECT(0x29),
VK_PRINT(0x2A),
VK_EXECUTE(0x2B),
VK_SNAPSHOT(0x2C),
VK_INSERT(0x2D),
VK_DELETE(0x2E),
VK_HELP(0x2F),
/*
* VK_0 - VK_9 are the same as ASCII '0' - '9' (0x30 - 0x39)
*/
VK_0(0x30),
VK_1(0x31),
VK_2(0x32),
VK_3(0x33),
VK_4(0x34),
VK_5(0x35),
VK_6(0x36),
VK_7(0x37),
VK_8(0x38),
VK_9(0x39),
/*
* 0x3A - 0x40 : unassigned
*/
VK_UNASSIGNED_3A(0x3A),
VK_UNASSIGNED_3B(0x3B),
VK_UNASSIGNED_3C(0x3C),
VK_UNASSIGNED_3D(0x3D),
VK_UNASSIGNED_3E(0x3E),
VK_UNASSIGNED_3F(0x3F),
VK_UNASSIGNED_40(0x40),
/*
* VK_A - VK_Z are the same as ASCII 'A' - 'Z' (0x41 - 0x5A)
*/
VK_A(0x41),
VK_B(0x42),
VK_C(0x43),
VK_D(0x44),
VK_E(0x45),
VK_F(0x46),
VK_G(0x47),
VK_H(0x48),
VK_I(0x49),
VK_J(0x4A),
VK_K(0x4B),
VK_L(0x4C),
VK_M(0x4D),
VK_N(0x4E),
VK_O(0x4F),
VK_P(0x50),
VK_Q(0x51),
VK_R(0x52),
VK_S(0x53),
VK_T(0x54),
VK_U(0x55),
VK_V(0x56),
VK_W(0x57),
VK_X(0x58),
VK_Y(0x59),
VK_Z(0x5A),
/** Left Windows */
VK_LWIN(0x5B),
/** Right Windows */
VK_RWIN(0x5C),
/** Application */
VK_APPS(0x5D),
/*
* 0x5E : reserved
*/
VK_RESERVED_5E(0x5E),
VK_SLEEP(0x5F),
VK_NUMPAD0(0x60),
VK_NUMPAD1(0x61),
VK_NUMPAD2(0x62),
VK_NUMPAD3(0x63),
VK_NUMPAD4(0x64),
VK_NUMPAD5(0x65),
VK_NUMPAD6(0x66),
VK_NUMPAD7(0x67),
VK_NUMPAD8(0x68),
VK_NUMPAD9(0x69),
VK_MULTIPLY(0x6A),
VK_ADD(0x6B),
VK_SEPARATOR(0x6C),
VK_SUBTRACT(0x6D),
VK_DECIMAL(0x6E),
VK_DIVIDE(0x6F),
VK_F1(0x70),
VK_F2(0x71),
VK_F3(0x72),
VK_F4(0x73),
VK_F5(0x74),
VK_F6(0x75),
VK_F7(0x76),
VK_F8(0x77),
VK_F9(0x78),
VK_F10(0x79),
VK_F11(0x7A),
VK_F12(0x7B),
VK_F13(0x7C),
VK_F14(0x7D),
VK_F15(0x7E),
VK_F16(0x7F),
VK_F17(0x80),
VK_F18(0x81),
VK_F19(0x82),
VK_F20(0x83),
VK_F21(0x84),
VK_F22(0x85),
VK_F23(0x86),
VK_F24(0x87),
/*
* 0x88 - 0x8F : UI navigation
*/
VK_NAVIGATION_VIEW(0x88, 0x0604), // reserved
VK_NAVIGATION_MENU(0x89, 0x0604), // reserved
VK_NAVIGATION_UP(0x8A, 0x0604), // reserved
VK_NAVIGATION_DOWN(0x8B, 0x0604), // reserved
VK_NAVIGATION_LEFT(0x8C, 0x0604), // reserved
VK_NAVIGATION_RIGHT(0x8D, 0x0604), // reserved
VK_NAVIGATION_ACCEPT(0x8E, 0x0604), // reserved
VK_NAVIGATION_CANCEL(0x8F, 0x0604), // reserved
VK_NUMLOCK(0x90),
VK_SCROLL(0x91),
/*
* NEC PC-9800 kbd definitions
*/
VK_OEM_NEC_EQUAL(0x92), // '=' key on numpad
/*
* Fujitsu/OASYS kbd definitions
*/
VK_OEM_FJ_JISHO(0x92), // 'Dictionary' key
VK_OEM_FJ_MASSHOU(0x93), // 'Unregister word' key
VK_OEM_FJ_TOUROKU(0x94), // 'Register word' key
VK_OEM_FJ_LOYA(0x95), // 'Left OYAYUBI' key
VK_OEM_FJ_ROYA(0x96), // 'Right OYAYUBI' key
/*
* 0x97 - 0x9F : unassigned
*/
VK_UNASSIGNED_97(0x97),
VK_UNASSIGNED_98(0x98),
VK_UNASSIGNED_99(0x99),
VK_UNASSIGNED_9A(0x9A),
VK_UNASSIGNED_9B(0x9B),
VK_UNASSIGNED_9C(0x9C),
VK_UNASSIGNED_9D(0x9D),
VK_UNASSIGNED_9E(0x9E),
VK_UNASSIGNED_9F(0x9F),
/*
* VK_L* & VK_R* - left and right Alt, Ctrl and Shift virtual keys. Used only as
* parameters to GetAsyncKeyState() and GetKeyState(). No other API or message
* will distinguish left and right keys in this way.
*/
VK_LSHIFT(0xA0),
VK_RSHIFT(0xA1),
VK_LCONTROL(0xA2),
VK_RCONTROL(0xA3),
VK_LMENU(0xA4),
VK_RMENU(0xA5),
VK_BROWSER_BACK(0xA6, 0x0500),
VK_BROWSER_FORWARD(0xA7, 0x0500),
VK_BROWSER_REFRESH(0xA8, 0x0500),
VK_BROWSER_STOP(0xA9, 0x0500),
VK_BROWSER_SEARCH(0xAA, 0x0500),
VK_BROWSER_FAVORITES(0xAB, 0x0500),
VK_BROWSER_HOME(0xAC, 0x0500),
VK_VOLUME_MUTE(0xAD, 0x0500),
VK_VOLUME_DOWN(0xAE, 0x0500),
VK_VOLUME_UP(0xAF, 0x0500),
VK_MEDIA_NEXT_TRACK(0xB0, 0x0500),
VK_MEDIA_PREV_TRACK(0xB1, 0x0500),
VK_MEDIA_STOP(0xB2, 0x0500),
VK_MEDIA_PLAY_PAUSE(0xB3, 0x0500),
VK_LAUNCH_MAIL(0xB4, 0x0500),
VK_LAUNCH_MEDIA_SELECT(0xB5, 0x0500),
VK_LAUNCH_APP1(0xB6, 0x0500),
VK_LAUNCH_APP2(0xB7, 0x0500),
/*
* 0xB8 - 0xB9 : reserved
*/
VK_RESERVED_B8(0xB8),
VK_RESERVED_B9(0xB9),
VK_OEM_1(0xBA), // ';:' for US
VK_OEM_PLUS(0xBB), // '+' any country
VK_OEM_COMMA(0xBC), // ',' any country
VK_OEM_MINUS(0xBD), // '-' any country
VK_OEM_PERIOD(0xBE), // '.' any country
VK_OEM_2(0xBF), // '/?' for US
VK_OEM_3(0xC0), // '`~' for US
/*
* 0xC1 - 0xC2 : reserved
*/
VK_RESERVED_C1(0xC1),
VK_RESERVED_C2(0xC2),
/*
* 0xC3 - 0xDA : Gamepad input
*/
VK_GAMEPAD_A(0xC3, 0x0604), // reserved
VK_GAMEPAD_B(0xC4, 0x0604), // reserved
VK_GAMEPAD_X(0xC5, 0x0604), // reserved
VK_GAMEPAD_Y(0xC6, 0x0604), // reserved
VK_GAMEPAD_RIGHT_SHOULDER(0xC7, 0x0604), // reserved
VK_GAMEPAD_LEFT_SHOULDER(0xC8, 0x0604), // reserved
VK_GAMEPAD_LEFT_TRIGGER(0xC9, 0x0604), // reserved
VK_GAMEPAD_RIGHT_TRIGGER(0xCA, 0x0604), // reserved
VK_GAMEPAD_DPAD_UP(0xCB, 0x0604), // reserved
VK_GAMEPAD_DPAD_DOWN(0xCC, 0x0604), // reserved
VK_GAMEPAD_DPAD_LEFT(0xCD, 0x0604), // reserved
VK_GAMEPAD_DPAD_RIGHT(0xCE, 0x0604), // reserved
VK_GAMEPAD_MENU(0xCF, 0x0604), // reserved
VK_GAMEPAD_VIEW(0xD0, 0x0604), // reserved
VK_GAMEPAD_LEFT_THUMBSTICK_BUTTON(0xD1, 0x0604), // reserved
VK_GAMEPAD_RIGHT_THUMBSTICK_BUTTON(0xD2, 0x0604), // reserved
VK_GAMEPAD_LEFT_THUMBSTICK_UP(0xD3, 0x0604), // reserved
VK_GAMEPAD_LEFT_THUMBSTICK_DOWN(0xD4, 0x0604), // reserved
VK_GAMEPAD_LEFT_THUMBSTICK_RIGHT(0xD5, 0x0604), // reserved
VK_GAMEPAD_LEFT_THUMBSTICK_LEFT(0xD6, 0x0604), // reserved
VK_GAMEPAD_RIGHT_THUMBSTICK_UP(0xD7, 0x0604), // reserved
VK_GAMEPAD_RIGHT_THUMBSTICK_DOWN(0xD8, 0x0604), // reserved
VK_GAMEPAD_RIGHT_THUMBSTICK_RIGHT(0xD9, 0x0604), // reserved
VK_GAMEPAD_RIGHT_THUMBSTICK_LEFT(0xDA, 0x0604), // reserved
VK_OEM_4(0xDB), // '[{' for US
VK_OEM_5(0xDC), // '\|' for US
VK_OEM_6(0xDD), // ']}' for US
VK_OEM_7(0xDE), // ''"' for US
VK_OEM_8(0xDF),
/*
* 0xE0 : reserved
*/
VK_RESERVED_E0(0xE0),
/*
* Various extended or enhanced keyboards
*/
VK_OEM_AX(0xE1), // 'AX' key on Japanese AX kbd
VK_OEM_102(0xE2), // "<>" or "\|" on RT 102-key kbd.
VK_ICO_HELP(0xE3), // Help key on ICO
VK_ICO_00(0xE4), // 00 key on ICO, produces "00"
VK_PROCESSKEY(0xE5, 0x0400),
VK_ICO_CLEAR(0xE6),
VK_PACKET(0xE7, 0x0500),
/*
* 0xE8 : unassigned
*/
VK_UNASSIGNED_E8(0xE8),
/*
* Nokia/Ericsson definitions
*/
VK_OEM_RESET(0xE9),
VK_OEM_JUMP(0xEA),
VK_OEM_PA1(0xEB),
VK_OEM_PA2(0xEC),
VK_OEM_PA3(0xED),
VK_OEM_WSCTRL(0xEE),
VK_OEM_CUSEL(0xEF),
VK_OEM_ATTN(0xF0),
VK_OEM_FINISH(0xF1),
VK_OEM_COPY(0xF2),
VK_OEM_AUTO(0xF3),
VK_OEM_ENLW(0xF4),
VK_OEM_BACKTAB(0xF5),
VK_ATTN(0xF6),
VK_CRSEL(0xF7),
VK_EXSEL(0xF8),
VK_EREOF(0xF9),
VK_PLAY(0xFA),
VK_ZOOM(0xFB),
VK_NONAME(0xFC),
VK_PA1(0xFD),
VK_OEM_CLEAR(0xFE),
/*
* 0xFF : reserved
*/
VK_RESERVED_FF(0xFF);
/**
* The code value.
*/
public final int code;
/**
* This VK constant was introduced in this WinNT version.
*/
public final int introducedVersion;
private Win32VK(int code, int introducedVersion) {
this.code = code;
this.introducedVersion = introducedVersion;
}
private Win32VK(int code) {
this(code, 0);
}
/**
* This will return the first of the multiple VK constants mapped to the same
* value. First as defined in the order of the header file listing the
* constants.
*
* @param code the code value.
* @return the VK enum instance.
*/
public static Win32VK fromValue(final int code) {
for (Win32VK vk : Win32VK.values()) {
if (vk.code == code) {
return vk;
}
}
throw new IllegalArgumentException(String.format("No mapping for %02x", code));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy