All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.glass.events.KeyEvent Maven / Gradle / Ivy

There is a newer version: 24-ea+15
Show newest version
/*
 * Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.  Oracle designates this
 * particular file as subject to the "Classpath" exception as provided
 * by Oracle in the LICENSE file that accompanied this code.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
 */
package com.sun.glass.events;

import java.lang.annotation.Native;

import com.sun.glass.ui.Application;

public class KeyEvent {

    /***************************************************************************
     *                                                                         *
     * Flags                                                                   *
     *                                                                         *
     **************************************************************************/

    /*
     * Key event type.
     */
    @Native public final static int PRESS   = 111;
    @Native public final static int RELEASE = 112;
    @Native public final static int TYPED   = 113; // synthetic

    /*
     * Key event modifier flags.
     *
     * CONTROL/WINDOWS and OPTION/ALT are equal, because they
     * are mapped to each other on Mac/Windows
     */
    @Native public final static int MODIFIER_NONE              = 0;
    @Native public final static int MODIFIER_SHIFT             = 1 << 0;
    @Native public final static int MODIFIER_FUNCTION          = 1 << 1;
    @Native public final static int MODIFIER_CONTROL           = 1 << 2;

    @Native public final static int MODIFIER_OPTION            = 1 << 3;
    @Native public final static int MODIFIER_ALT               = 1 << 3;

    // The following should be named Meta perhaps?
    @Native public final static int MODIFIER_COMMAND           = 1 << 4;
    @Native public final static int MODIFIER_WINDOWS           = 1 << 4;

    // Mouse buttons
    @Native public final static int MODIFIER_BUTTON_PRIMARY    = 1 << 5;
    @Native public final static int MODIFIER_BUTTON_SECONDARY  = 1 << 6;
    @Native public final static int MODIFIER_BUTTON_MIDDLE     = 1 << 7;
    @Native public final static int MODIFIER_BUTTON_BACK       = 1 << 8;
    @Native public final static int MODIFIER_BUTTON_FORWARD    = 1 << 9;

    /*
     * Key lock state
     */
    @Native public static final int KEY_LOCK_OFF = 0;
    @Native public static final int KEY_LOCK_ON = 1;
    @Native public static final int KEY_LOCK_UNKNOWN = -1;

    /*
     * Key event key codes.
     */
    @Native public final static int VK_UNDEFINED      = 0x0;
    // Misc
    @Native public final static int VK_ENTER              = '\n';
    @Native public final static int VK_BACKSPACE          = '\b';
    @Native public final static int VK_TAB                = '\t';
//    @Native public final static int VK_CANCEL             = 0x03;
    @Native public final static int VK_CLEAR              = 0x0C;
    @Native public final static int VK_PAUSE              = 0x13;
    @Native public final static int VK_ESCAPE             = 0x1B;
    @Native public final static int VK_SPACE              = 0x20;
    @Native public final static int VK_DELETE             = 0x7F;
    @Native public final static int VK_PRINTSCREEN        = 0x9A;
    @Native public final static int VK_INSERT             = 0x9B;
    @Native public final static int VK_HELP               = 0x9C;
    // Modifiers
    @Native public final static int VK_SHIFT              = 0x10;
    @Native public final static int VK_CONTROL            = 0x11;
    @Native public final static int VK_ALT                = 0x12;
    @Native public final static int VK_ALT_GRAPH          = 0xFF7E;
    @Native public final static int VK_WINDOWS            = 0x020C;
    @Native public static final int VK_CONTEXT_MENU       = 0x020D;
    @Native public final static int VK_CAPS_LOCK          = 0x14;
    @Native public final static int VK_NUM_LOCK           = 0x90;
    @Native public final static int VK_SCROLL_LOCK        = 0x91;
    @Native public final static int VK_COMMAND            = 0x0300;
    // Navigation keys
    @Native public final static int VK_PAGE_UP            = 0x21;
    @Native public final static int VK_PAGE_DOWN          = 0x22;
    @Native public final static int VK_END                = 0x23;
    @Native public final static int VK_HOME               = 0x24;
    @Native public final static int VK_LEFT               = 0x25;
    @Native public final static int VK_UP                 = 0x26;
    @Native public final static int VK_RIGHT              = 0x27;
    @Native public final static int VK_DOWN               = 0x28;

    // Misc 2
    @Native public final static int VK_COMMA              = 0x2C; // ','
    @Native public final static int VK_MINUS              = 0x2D; // '-'
    @Native public final static int VK_PERIOD             = 0x2E; // '.'
    @Native public final static int VK_SLASH              = 0x2F; // '/'
    @Native public final static int VK_SEMICOLON          = 0x3B; // ';'
    @Native public final static int VK_EQUALS             = 0x3D; // '='
    @Native public final static int VK_OPEN_BRACKET       = 0x5B; // '['
    @Native public final static int VK_BACK_SLASH         = 0x5C; // '\'
    @Native public final static int VK_CLOSE_BRACKET      = 0x5D; // ']'
    @Native public final static int VK_MULTIPLY           = 0x6A; // '*'
    @Native public final static int VK_ADD                = 0x6B; // '+'
    @Native public final static int VK_SEPARATOR          = 0x6C;
    @Native public final static int VK_SUBTRACT           = 0x6D;
    @Native public final static int VK_DECIMAL            = 0x6E;
    @Native public final static int VK_DIVIDE             = 0x6F;
    @Native public final static int VK_AMPERSAND          = 0x96;
    @Native public final static int VK_ASTERISK           = 0x97;
    @Native public final static int VK_DOUBLE_QUOTE       = 0x98; // '"'
    @Native public final static int VK_LESS               = 0x99; // '<'
    @Native public final static int VK_GREATER            = 0xa0; // '>'
    @Native public final static int VK_BRACELEFT          = 0xa1; // '{'
    @Native public final static int VK_BRACERIGHT         = 0xa2; // '}'
    @Native public final static int VK_BACK_QUOTE         = 0xC0; // '`'
    @Native public final static int VK_QUOTE              = 0xDE; // '''
    @Native public final static int VK_AT                 = 0x0200; // '@'
    @Native public final static int VK_COLON              = 0x0201; // ':'
    @Native public final static int VK_CIRCUMFLEX         = 0x0202; // '^'
    @Native public final static int VK_DOLLAR             = 0x0203; // '$'
    @Native public final static int VK_EURO_SIGN          = 0x0204;
    @Native public final static int VK_EXCLAMATION        = 0x0205; // '!'
    @Native public final static int VK_INV_EXCLAMATION    = 0x0206;
    @Native public final static int VK_LEFT_PARENTHESIS   = 0x0207; // '('
    @Native public final static int VK_NUMBER_SIGN        = 0x0208; // '#'
    @Native public final static int VK_PLUS               = 0x0209; // '+'
    @Native public final static int VK_RIGHT_PARENTHESIS  = 0x020A; // ')'
    @Native public final static int VK_UNDERSCORE         = 0x020B; // '_'
    // Numeric keys
    @Native public final static int VK_0                  = 0x30; // '0'
    @Native public final static int VK_1                  = 0x31; // '1'
    @Native public final static int VK_2                  = 0x32; // '2'
    @Native public final static int VK_3                  = 0x33; // '3'
    @Native public final static int VK_4                  = 0x34; // '4'
    @Native public final static int VK_5                  = 0x35; // '5'
    @Native public final static int VK_6                  = 0x36; // '6'
    @Native public final static int VK_7                  = 0x37; // '7'
    @Native public final static int VK_8                  = 0x38; // '8'
    @Native public final static int VK_9                  = 0x39; // '9'
    // Alpha keys
    @Native public final static int VK_A                  = 0x41; // 'A'
    @Native public final static int VK_B                  = 0x42; // 'B'
    @Native public final static int VK_C                  = 0x43; // 'C'
    @Native public final static int VK_D                  = 0x44; // 'D'
    @Native public final static int VK_E                  = 0x45; // 'E'
    @Native public final static int VK_F                  = 0x46; // 'F'
    @Native public final static int VK_G                  = 0x47; // 'G'
    @Native public final static int VK_H                  = 0x48; // 'H'
    @Native public final static int VK_I                  = 0x49; // 'I'
    @Native public final static int VK_J                  = 0x4A; // 'J'
    @Native public final static int VK_K                  = 0x4B; // 'K'
    @Native public final static int VK_L                  = 0x4C; // 'L'
    @Native public final static int VK_M                  = 0x4D; // 'M'
    @Native public final static int VK_N                  = 0x4E; // 'N'
    @Native public final static int VK_O                  = 0x4F; // 'O'
    @Native public final static int VK_P                  = 0x50; // 'P'
    @Native public final static int VK_Q                  = 0x51; // 'Q'
    @Native public final static int VK_R                  = 0x52; // 'R'
    @Native public final static int VK_S                  = 0x53; // 'S'
    @Native public final static int VK_T                  = 0x54; // 'T'
    @Native public final static int VK_U                  = 0x55; // 'U'
    @Native public final static int VK_V                  = 0x56; // 'V'
    @Native public final static int VK_W                  = 0x57; // 'W'
    @Native public final static int VK_X                  = 0x58; // 'X'
    @Native public final static int VK_Y                  = 0x59; // 'Y'
    @Native public final static int VK_Z                  = 0x5A; // 'Z'
    // Numpad keys
    @Native public final static int VK_NUMPAD0            = 0x60;
    @Native public final static int VK_NUMPAD1            = 0x61;
    @Native public final static int VK_NUMPAD2            = 0x62;
    @Native public final static int VK_NUMPAD3            = 0x63;
    @Native public final static int VK_NUMPAD4            = 0x64;
    @Native public final static int VK_NUMPAD5            = 0x65;
    @Native public final static int VK_NUMPAD6            = 0x66;
    @Native public final static int VK_NUMPAD7            = 0x67;
    @Native public final static int VK_NUMPAD8            = 0x68;
    @Native public final static int VK_NUMPAD9            = 0x69;
    // Function keys
    @Native public final static int VK_F1                 = 0x70;
    @Native public final static int VK_F2                 = 0x71;
    @Native public final static int VK_F3                 = 0x72;
    @Native public final static int VK_F4                 = 0x73;
    @Native public final static int VK_F5                 = 0x74;
    @Native public final static int VK_F6                 = 0x75;
    @Native public final static int VK_F7                 = 0x76;
    @Native public final static int VK_F8                 = 0x77;
    @Native public final static int VK_F9                 = 0x78;
    @Native public final static int VK_F10                = 0x79;
    @Native public final static int VK_F11                = 0x7A;
    @Native public final static int VK_F12                = 0x7B;
    @Native public final static int VK_F13                = 0xF000;
    @Native public final static int VK_F14                = 0xF001;
    @Native public final static int VK_F15                = 0xF002;
    @Native public final static int VK_F16                = 0xF003;
    @Native public final static int VK_F17                = 0xF004;
    @Native public final static int VK_F18                = 0xF005;
    @Native public final static int VK_F19                = 0xF006;
    @Native public final static int VK_F20                = 0xF007;
    @Native public final static int VK_F21                = 0xF008;
    @Native public final static int VK_F22                = 0xF009;
    @Native public final static int VK_F23                = 0xF00A;
    @Native public final static int VK_F24                = 0xF00B;

    @Native public final static int VK_DEAD_GRAVE               = 0x80;
    @Native public final static int VK_DEAD_ACUTE               = 0x81;
    @Native public final static int VK_DEAD_CIRCUMFLEX          = 0x82;
    @Native public final static int VK_DEAD_TILDE               = 0x83;
    @Native public final static int VK_DEAD_MACRON              = 0x84;
    @Native public final static int VK_DEAD_BREVE               = 0x85;
    @Native public final static int VK_DEAD_ABOVEDOT            = 0x86;
    @Native public final static int VK_DEAD_DIAERESIS           = 0x87;
    @Native public final static int VK_DEAD_ABOVERING           = 0x88;
    @Native public final static int VK_DEAD_DOUBLEACUTE         = 0x89;
    @Native public final static int VK_DEAD_CARON               = 0x8a;
    @Native public final static int VK_DEAD_CEDILLA             = 0x8b;
    @Native public final static int VK_DEAD_OGONEK              = 0x8c;
    @Native public final static int VK_DEAD_IOTA                = 0x8d;
    @Native public final static int VK_DEAD_VOICED_SOUND        = 0x8e;
    @Native public final static int VK_DEAD_SEMIVOICED_SOUND    = 0x8f;

    /***************************************************************************
     *                                                                         *
     * Static Methods                                                          *
     *                                                                         *
     **************************************************************************/

    /**
     * Returns a VK_ code of a key capable of producing the given unicode
     * character with respect to the currently active keyboard layout or
     * VK_UNDEFINED if the character isn't present in the current layout. The
     * hint is the VK_ code of the key the system is attempting to match
     * (which may be VK_UNDEFINED for a key on the main keyboard). It can be
     * used to optimize the search or to distinguish between the main
     * keyboard and the numeric keypad.
     *
     * @param c the character
     * @param hint the code of the key the system is attempting to match
     * @return integer code for the given char
     */
    public static int getKeyCodeForChar(char c, int hint) {
        return Application.getKeyCodeForChar(c, hint);
    }

    /**
     * Gets a string representation of the KeyEvent type (PRESS, RELEASE, TYPED,
     * or UNKNOWN).
     * @param type Should be one of PRESS, RELEASE, or TYPED.
     * @return A string representation of the key event type. This will be
     *           UNKNOWN if the type is something other than what was expected.
     */
    public final static String getTypeString(int type) {
        switch (type) {
            case PRESS:   return "PRESS";
            case RELEASE: return "RELEASE";
            case TYPED:   return "TYPED";
            default:      return "UNKNOWN";
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy