blob: 60db6a57d187c037b628506a42f8137cf195c612 [file] [log] [blame]
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2006 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.view;
18
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +010019import static android.view.Display.INVALID_DISPLAY;
20
Siarhei Vishniakoude1f9042018-05-09 09:54:43 -070021import android.annotation.NonNull;
Siarhei Vishniakou4c96a5e2018-04-24 17:57:44 -070022import android.annotation.TestApi;
Mathew Inwooda570dee2018-08-17 14:56:00 +010023import android.annotation.UnsupportedAppUsage;
Mathew Inwood8c854f82018-09-14 12:35:36 +010024import android.os.Build;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080025import android.os.Parcel;
26import android.os.Parcelable;
Jeff Brown6b53e8d2010-11-10 16:03:06 -080027import android.text.method.MetaKeyKeyListener;
Dianne Hackborn8d374262009-09-14 21:21:52 -070028import android.util.Log;
Dianne Hackborn83fe3f52009-09-12 23:38:30 -070029import android.util.SparseIntArray;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080030import android.view.KeyCharacterMap.KeyData;
31
32/**
Jeff Browndc1ab4b2010-09-14 18:03:38 -070033 * Object used to report key and button events.
34 * <p>
35 * Each key press is described by a sequence of key events. A key press
36 * starts with a key event with {@link #ACTION_DOWN}. If the key is held
37 * sufficiently long that it repeats, then the initial down is followed
38 * additional key events with {@link #ACTION_DOWN} and a non-zero value for
39 * {@link #getRepeatCount()}. The last key event is a {@link #ACTION_UP}
40 * for the key up. If the key press is canceled, the key up event will have the
41 * {@link #FLAG_CANCELED} flag set.
42 * </p><p>
43 * Key events are generally accompanied by a key code ({@link #getKeyCode()}),
44 * scan code ({@link #getScanCode()}) and meta state ({@link #getMetaState()}).
45 * Key code constants are defined in this class. Scan code constants are raw
46 * device-specific codes obtained from the OS and so are not generally meaningful
47 * to applications unless interpreted using the {@link KeyCharacterMap}.
48 * Meta states describe the pressed state of key modifiers
49 * such as {@link #META_SHIFT_ON} or {@link #META_ALT_ON}.
50 * </p><p>
Jeff Brown497a92c2010-09-12 17:55:08 -070051 * Key codes typically correspond one-to-one with individual keys on an input device.
52 * Many keys and key combinations serve quite different functions on different
53 * input devices so care must be taken when interpreting them. Always use the
54 * {@link KeyCharacterMap} associated with the input device when mapping keys
55 * to characters. Be aware that there may be multiple key input devices active
56 * at the same time and each will have its own key character map.
57 * </p><p>
Jean Chalard405bc512012-05-29 19:12:34 +090058 * As soft input methods can use multiple and inventive ways of inputting text,
59 * there is no guarantee that any key press on a soft keyboard will generate a key
60 * event: this is left to the IME's discretion, and in fact sending such events is
61 * discouraged. You should never rely on receiving KeyEvents for any key on a soft
62 * input method. In particular, the default software keyboard will never send any
63 * key event to any application targetting Jelly Bean or later, and will only send
64 * events for some presses of the delete and return keys to applications targetting
65 * Ice Cream Sandwich or earlier. Be aware that other software input methods may
66 * never send key events regardless of the version. Consider using editor actions
67 * like {@link android.view.inputmethod.EditorInfo#IME_ACTION_DONE} if you need
68 * specific interaction with the software keyboard, as it gives more visibility to
69 * the user as to how your application will react to key presses.
70 * </p><p>
Jeff Browndc1ab4b2010-09-14 18:03:38 -070071 * When interacting with an IME, the framework may deliver key events
72 * with the special action {@link #ACTION_MULTIPLE} that either specifies
73 * that single repeated key code or a sequence of characters to insert.
74 * </p><p>
Jeff Brownb6997262010-10-08 22:31:17 -070075 * In general, the framework cannot guarantee that the key events it delivers
76 * to a view always constitute complete key sequences since some events may be dropped
77 * or modified by containing views before they are delivered. The view implementation
78 * should be prepared to handle {@link #FLAG_CANCELED} and should tolerate anomalous
79 * situations such as receiving a new {@link #ACTION_DOWN} without first having
80 * received an {@link #ACTION_UP} for the prior key press.
Jeff Browndc1ab4b2010-09-14 18:03:38 -070081 * </p><p>
82 * Refer to {@link InputDevice} for more information about how different kinds of
83 * input devices and sources represent keys and buttons.
84 * </p>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080085 */
Jeff Brownc5ed5912010-07-14 18:48:53 -070086public class KeyEvent extends InputEvent implements Parcelable {
Jeff Browndc1ab4b2010-09-14 18:03:38 -070087 /** Key code constant: Unknown key code. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080088 public static final int KEYCODE_UNKNOWN = 0;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070089 /** Key code constant: Soft Left key.
90 * Usually situated below the display on phones and used as a multi-function
91 * feature key for selecting a software defined function shown on the bottom left
92 * of the display. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080093 public static final int KEYCODE_SOFT_LEFT = 1;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070094 /** Key code constant: Soft Right key.
95 * Usually situated below the display on phones and used as a multi-function
96 * feature key for selecting a software defined function shown on the bottom right
97 * of the display. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080098 public static final int KEYCODE_SOFT_RIGHT = 2;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070099 /** Key code constant: Home key.
100 * This key is handled by the framework and is never delivered to applications. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800101 public static final int KEYCODE_HOME = 3;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700102 /** Key code constant: Back key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800103 public static final int KEYCODE_BACK = 4;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700104 /** Key code constant: Call key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800105 public static final int KEYCODE_CALL = 5;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700106 /** Key code constant: End Call key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800107 public static final int KEYCODE_ENDCALL = 6;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700108 /** Key code constant: '0' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800109 public static final int KEYCODE_0 = 7;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700110 /** Key code constant: '1' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800111 public static final int KEYCODE_1 = 8;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700112 /** Key code constant: '2' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800113 public static final int KEYCODE_2 = 9;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700114 /** Key code constant: '3' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800115 public static final int KEYCODE_3 = 10;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700116 /** Key code constant: '4' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800117 public static final int KEYCODE_4 = 11;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700118 /** Key code constant: '5' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800119 public static final int KEYCODE_5 = 12;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700120 /** Key code constant: '6' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800121 public static final int KEYCODE_6 = 13;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700122 /** Key code constant: '7' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800123 public static final int KEYCODE_7 = 14;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700124 /** Key code constant: '8' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800125 public static final int KEYCODE_8 = 15;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700126 /** Key code constant: '9' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800127 public static final int KEYCODE_9 = 16;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700128 /** Key code constant: '*' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800129 public static final int KEYCODE_STAR = 17;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700130 /** Key code constant: '#' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800131 public static final int KEYCODE_POUND = 18;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700132 /** Key code constant: Directional Pad Up key.
133 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800134 public static final int KEYCODE_DPAD_UP = 19;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700135 /** Key code constant: Directional Pad Down key.
136 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800137 public static final int KEYCODE_DPAD_DOWN = 20;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700138 /** Key code constant: Directional Pad Left key.
139 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800140 public static final int KEYCODE_DPAD_LEFT = 21;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700141 /** Key code constant: Directional Pad Right key.
142 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800143 public static final int KEYCODE_DPAD_RIGHT = 22;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700144 /** Key code constant: Directional Pad Center key.
145 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800146 public static final int KEYCODE_DPAD_CENTER = 23;
Jeff Brownb0418da2010-11-01 15:24:01 -0700147 /** Key code constant: Volume Up key.
148 * Adjusts the speaker volume up. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800149 public static final int KEYCODE_VOLUME_UP = 24;
Jeff Brownb0418da2010-11-01 15:24:01 -0700150 /** Key code constant: Volume Down key.
151 * Adjusts the speaker volume down. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800152 public static final int KEYCODE_VOLUME_DOWN = 25;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700153 /** Key code constant: Power key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800154 public static final int KEYCODE_POWER = 26;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700155 /** Key code constant: Camera key.
156 * Used to launch a camera application or take pictures. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800157 public static final int KEYCODE_CAMERA = 27;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700158 /** Key code constant: Clear key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800159 public static final int KEYCODE_CLEAR = 28;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700160 /** Key code constant: 'A' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800161 public static final int KEYCODE_A = 29;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700162 /** Key code constant: 'B' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800163 public static final int KEYCODE_B = 30;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700164 /** Key code constant: 'C' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800165 public static final int KEYCODE_C = 31;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700166 /** Key code constant: 'D' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800167 public static final int KEYCODE_D = 32;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700168 /** Key code constant: 'E' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800169 public static final int KEYCODE_E = 33;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700170 /** Key code constant: 'F' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800171 public static final int KEYCODE_F = 34;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700172 /** Key code constant: 'G' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800173 public static final int KEYCODE_G = 35;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700174 /** Key code constant: 'H' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800175 public static final int KEYCODE_H = 36;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700176 /** Key code constant: 'I' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800177 public static final int KEYCODE_I = 37;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700178 /** Key code constant: 'J' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800179 public static final int KEYCODE_J = 38;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700180 /** Key code constant: 'K' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800181 public static final int KEYCODE_K = 39;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700182 /** Key code constant: 'L' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800183 public static final int KEYCODE_L = 40;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700184 /** Key code constant: 'M' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800185 public static final int KEYCODE_M = 41;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700186 /** Key code constant: 'N' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800187 public static final int KEYCODE_N = 42;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700188 /** Key code constant: 'O' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800189 public static final int KEYCODE_O = 43;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700190 /** Key code constant: 'P' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800191 public static final int KEYCODE_P = 44;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700192 /** Key code constant: 'Q' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800193 public static final int KEYCODE_Q = 45;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700194 /** Key code constant: 'R' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800195 public static final int KEYCODE_R = 46;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700196 /** Key code constant: 'S' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800197 public static final int KEYCODE_S = 47;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700198 /** Key code constant: 'T' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800199 public static final int KEYCODE_T = 48;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700200 /** Key code constant: 'U' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800201 public static final int KEYCODE_U = 49;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700202 /** Key code constant: 'V' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800203 public static final int KEYCODE_V = 50;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700204 /** Key code constant: 'W' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800205 public static final int KEYCODE_W = 51;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700206 /** Key code constant: 'X' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800207 public static final int KEYCODE_X = 52;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700208 /** Key code constant: 'Y' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800209 public static final int KEYCODE_Y = 53;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700210 /** Key code constant: 'Z' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800211 public static final int KEYCODE_Z = 54;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700212 /** Key code constant: ',' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800213 public static final int KEYCODE_COMMA = 55;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700214 /** Key code constant: '.' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800215 public static final int KEYCODE_PERIOD = 56;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700216 /** Key code constant: Left Alt modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800217 public static final int KEYCODE_ALT_LEFT = 57;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700218 /** Key code constant: Right Alt modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800219 public static final int KEYCODE_ALT_RIGHT = 58;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700220 /** Key code constant: Left Shift modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800221 public static final int KEYCODE_SHIFT_LEFT = 59;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700222 /** Key code constant: Right Shift modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800223 public static final int KEYCODE_SHIFT_RIGHT = 60;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700224 /** Key code constant: Tab key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800225 public static final int KEYCODE_TAB = 61;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700226 /** Key code constant: Space key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800227 public static final int KEYCODE_SPACE = 62;
Jeff Brown224d4a12010-10-07 20:28:53 -0700228 /** Key code constant: Symbol modifier key.
229 * Used to enter alternate symbols. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800230 public static final int KEYCODE_SYM = 63;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700231 /** Key code constant: Explorer special function key.
232 * Used to launch a browser application. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800233 public static final int KEYCODE_EXPLORER = 64;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700234 /** Key code constant: Envelope special function key.
235 * Used to launch a mail application. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800236 public static final int KEYCODE_ENVELOPE = 65;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700237 /** Key code constant: Enter key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800238 public static final int KEYCODE_ENTER = 66;
Jeff Brown224d4a12010-10-07 20:28:53 -0700239 /** Key code constant: Backspace key.
Jeff Brown497a92c2010-09-12 17:55:08 -0700240 * Deletes characters before the insertion point, unlike {@link #KEYCODE_FORWARD_DEL}. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800241 public static final int KEYCODE_DEL = 67;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700242 /** Key code constant: '`' (backtick) key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800243 public static final int KEYCODE_GRAVE = 68;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700244 /** Key code constant: '-'. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800245 public static final int KEYCODE_MINUS = 69;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700246 /** Key code constant: '=' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800247 public static final int KEYCODE_EQUALS = 70;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700248 /** Key code constant: '[' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800249 public static final int KEYCODE_LEFT_BRACKET = 71;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700250 /** Key code constant: ']' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800251 public static final int KEYCODE_RIGHT_BRACKET = 72;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700252 /** Key code constant: '\' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800253 public static final int KEYCODE_BACKSLASH = 73;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700254 /** Key code constant: ';' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800255 public static final int KEYCODE_SEMICOLON = 74;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700256 /** Key code constant: ''' (apostrophe) key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800257 public static final int KEYCODE_APOSTROPHE = 75;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700258 /** Key code constant: '/' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800259 public static final int KEYCODE_SLASH = 76;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700260 /** Key code constant: '@' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800261 public static final int KEYCODE_AT = 77;
Jeff Brown224d4a12010-10-07 20:28:53 -0700262 /** Key code constant: Number modifier key.
263 * Used to enter numeric symbols.
264 * This key is not Num Lock; it is more like {@link #KEYCODE_ALT_LEFT} and is
265 * interpreted as an ALT key by {@link android.text.method.MetaKeyKeyListener}. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800266 public static final int KEYCODE_NUM = 78;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700267 /** Key code constant: Headset Hook key.
268 * Used to hang up calls and stop media. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800269 public static final int KEYCODE_HEADSETHOOK = 79;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700270 /** Key code constant: Camera Focus key.
271 * Used to focus the camera. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800272 public static final int KEYCODE_FOCUS = 80; // *Camera* focus
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700273 /** Key code constant: '+' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800274 public static final int KEYCODE_PLUS = 81;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700275 /** Key code constant: Menu key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800276 public static final int KEYCODE_MENU = 82;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700277 /** Key code constant: Notification key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800278 public static final int KEYCODE_NOTIFICATION = 83;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700279 /** Key code constant: Search key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800280 public static final int KEYCODE_SEARCH = 84;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700281 /** Key code constant: Play/Pause media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700282 public static final int KEYCODE_MEDIA_PLAY_PAUSE= 85;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700283 /** Key code constant: Stop media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700284 public static final int KEYCODE_MEDIA_STOP = 86;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700285 /** Key code constant: Play Next media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700286 public static final int KEYCODE_MEDIA_NEXT = 87;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700287 /** Key code constant: Play Previous media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700288 public static final int KEYCODE_MEDIA_PREVIOUS = 88;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700289 /** Key code constant: Rewind media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700290 public static final int KEYCODE_MEDIA_REWIND = 89;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700291 /** Key code constant: Fast Forward media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700292 public static final int KEYCODE_MEDIA_FAST_FORWARD = 90;
Jeff Brownb0418da2010-11-01 15:24:01 -0700293 /** Key code constant: Mute key.
294 * Mutes the microphone, unlike {@link #KEYCODE_VOLUME_MUTE}. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800295 public static final int KEYCODE_MUTE = 91;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700296 /** Key code constant: Page Up key. */
Chih-Wei Huang4fedd802009-05-27 15:52:50 +0800297 public static final int KEYCODE_PAGE_UP = 92;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700298 /** Key code constant: Page Down key. */
Chih-Wei Huang4fedd802009-05-27 15:52:50 +0800299 public static final int KEYCODE_PAGE_DOWN = 93;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700300 /** Key code constant: Picture Symbols modifier key.
301 * Used to switch symbol sets (Emoji, Kao-moji). */
mogimob032bc02009-10-03 03:13:56 +0900302 public static final int KEYCODE_PICTSYMBOLS = 94; // switch symbol-sets (Emoji,Kao-moji)
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700303 /** Key code constant: Switch Charset modifier key.
304 * Used to switch character sets (Kanji, Katakana). */
mogimob032bc02009-10-03 03:13:56 +0900305 public static final int KEYCODE_SWITCH_CHARSET = 95; // switch char-sets (Kanji,Katakana)
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700306 /** Key code constant: A Button key.
307 * On a game controller, the A button should be either the button labeled A
Michael Wright6b57bde2013-01-28 20:35:58 -0800308 * or the first button on the bottom row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700309 public static final int KEYCODE_BUTTON_A = 96;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700310 /** Key code constant: B Button key.
311 * On a game controller, the B button should be either the button labeled B
Michael Wright6b57bde2013-01-28 20:35:58 -0800312 * or the second button on the bottom row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700313 public static final int KEYCODE_BUTTON_B = 97;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700314 /** Key code constant: C Button key.
315 * On a game controller, the C button should be either the button labeled C
Michael Wright6b57bde2013-01-28 20:35:58 -0800316 * or the third button on the bottom row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700317 public static final int KEYCODE_BUTTON_C = 98;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700318 /** Key code constant: X Button key.
319 * On a game controller, the X button should be either the button labeled X
Michael Wright6b57bde2013-01-28 20:35:58 -0800320 * or the first button on the upper row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700321 public static final int KEYCODE_BUTTON_X = 99;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700322 /** Key code constant: Y Button key.
323 * On a game controller, the Y button should be either the button labeled Y
Michael Wright6b57bde2013-01-28 20:35:58 -0800324 * or the second button on the upper row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700325 public static final int KEYCODE_BUTTON_Y = 100;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700326 /** Key code constant: Z Button key.
327 * On a game controller, the Z button should be either the button labeled Z
Michael Wright6b57bde2013-01-28 20:35:58 -0800328 * or the third button on the upper row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700329 public static final int KEYCODE_BUTTON_Z = 101;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700330 /** Key code constant: L1 Button key.
331 * On a game controller, the L1 button should be either the button labeled L1 (or L)
332 * or the top left trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700333 public static final int KEYCODE_BUTTON_L1 = 102;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700334 /** Key code constant: R1 Button key.
335 * On a game controller, the R1 button should be either the button labeled R1 (or R)
336 * or the top right trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700337 public static final int KEYCODE_BUTTON_R1 = 103;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700338 /** Key code constant: L2 Button key.
339 * On a game controller, the L2 button should be either the button labeled L2
340 * or the bottom left trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700341 public static final int KEYCODE_BUTTON_L2 = 104;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700342 /** Key code constant: R2 Button key.
343 * On a game controller, the R2 button should be either the button labeled R2
344 * or the bottom right trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700345 public static final int KEYCODE_BUTTON_R2 = 105;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700346 /** Key code constant: Left Thumb Button key.
347 * On a game controller, the left thumb button indicates that the left (or only)
348 * joystick is pressed. */
Jeff Brownfd035822010-06-30 16:10:35 -0700349 public static final int KEYCODE_BUTTON_THUMBL = 106;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700350 /** Key code constant: Right Thumb Button key.
351 * On a game controller, the right thumb button indicates that the right
352 * joystick is pressed. */
Jeff Brownfd035822010-06-30 16:10:35 -0700353 public static final int KEYCODE_BUTTON_THUMBR = 107;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700354 /** Key code constant: Start Button key.
355 * On a game controller, the button labeled Start. */
Jeff Brownfd035822010-06-30 16:10:35 -0700356 public static final int KEYCODE_BUTTON_START = 108;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700357 /** Key code constant: Select Button key.
358 * On a game controller, the button labeled Select. */
Jeff Brownfd035822010-06-30 16:10:35 -0700359 public static final int KEYCODE_BUTTON_SELECT = 109;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700360 /** Key code constant: Mode Button key.
361 * On a game controller, the button labeled Mode. */
Jeff Brownfd035822010-06-30 16:10:35 -0700362 public static final int KEYCODE_BUTTON_MODE = 110;
Jeff Brown497a92c2010-09-12 17:55:08 -0700363 /** Key code constant: Escape key. */
364 public static final int KEYCODE_ESCAPE = 111;
365 /** Key code constant: Forward Delete key.
366 * Deletes characters ahead of the insertion point, unlike {@link #KEYCODE_DEL}. */
367 public static final int KEYCODE_FORWARD_DEL = 112;
368 /** Key code constant: Left Control modifier key. */
369 public static final int KEYCODE_CTRL_LEFT = 113;
370 /** Key code constant: Right Control modifier key. */
371 public static final int KEYCODE_CTRL_RIGHT = 114;
Jeff Brown28cbf4b2010-12-13 10:33:20 -0800372 /** Key code constant: Caps Lock key. */
Jeff Brown497a92c2010-09-12 17:55:08 -0700373 public static final int KEYCODE_CAPS_LOCK = 115;
374 /** Key code constant: Scroll Lock key. */
375 public static final int KEYCODE_SCROLL_LOCK = 116;
376 /** Key code constant: Left Meta modifier key. */
377 public static final int KEYCODE_META_LEFT = 117;
378 /** Key code constant: Right Meta modifier key. */
379 public static final int KEYCODE_META_RIGHT = 118;
380 /** Key code constant: Function modifier key. */
381 public static final int KEYCODE_FUNCTION = 119;
382 /** Key code constant: System Request / Print Screen key. */
383 public static final int KEYCODE_SYSRQ = 120;
384 /** Key code constant: Break / Pause key. */
385 public static final int KEYCODE_BREAK = 121;
386 /** Key code constant: Home Movement key.
387 * Used for scrolling or moving the cursor around to the start of a line
388 * or to the top of a list. */
389 public static final int KEYCODE_MOVE_HOME = 122;
390 /** Key code constant: End Movement key.
391 * Used for scrolling or moving the cursor around to the end of a line
392 * or to the bottom of a list. */
393 public static final int KEYCODE_MOVE_END = 123;
394 /** Key code constant: Insert key.
395 * Toggles insert / overwrite edit mode. */
396 public static final int KEYCODE_INSERT = 124;
397 /** Key code constant: Forward key.
398 * Navigates forward in the history stack. Complement of {@link #KEYCODE_BACK}. */
399 public static final int KEYCODE_FORWARD = 125;
400 /** Key code constant: Play media key. */
401 public static final int KEYCODE_MEDIA_PLAY = 126;
402 /** Key code constant: Pause media key. */
403 public static final int KEYCODE_MEDIA_PAUSE = 127;
404 /** Key code constant: Close media key.
405 * May be used to close a CD tray, for example. */
406 public static final int KEYCODE_MEDIA_CLOSE = 128;
407 /** Key code constant: Eject media key.
408 * May be used to eject a CD tray, for example. */
409 public static final int KEYCODE_MEDIA_EJECT = 129;
410 /** Key code constant: Record media key. */
411 public static final int KEYCODE_MEDIA_RECORD = 130;
412 /** Key code constant: F1 key. */
413 public static final int KEYCODE_F1 = 131;
414 /** Key code constant: F2 key. */
415 public static final int KEYCODE_F2 = 132;
416 /** Key code constant: F3 key. */
417 public static final int KEYCODE_F3 = 133;
418 /** Key code constant: F4 key. */
419 public static final int KEYCODE_F4 = 134;
420 /** Key code constant: F5 key. */
421 public static final int KEYCODE_F5 = 135;
422 /** Key code constant: F6 key. */
423 public static final int KEYCODE_F6 = 136;
424 /** Key code constant: F7 key. */
425 public static final int KEYCODE_F7 = 137;
426 /** Key code constant: F8 key. */
427 public static final int KEYCODE_F8 = 138;
428 /** Key code constant: F9 key. */
429 public static final int KEYCODE_F9 = 139;
430 /** Key code constant: F10 key. */
431 public static final int KEYCODE_F10 = 140;
432 /** Key code constant: F11 key. */
433 public static final int KEYCODE_F11 = 141;
434 /** Key code constant: F12 key. */
435 public static final int KEYCODE_F12 = 142;
Jeff Brown28cbf4b2010-12-13 10:33:20 -0800436 /** Key code constant: Num Lock key.
Jeff Brown497a92c2010-09-12 17:55:08 -0700437 * This is the Num Lock key; it is different from {@link #KEYCODE_NUM}.
Jeff Brown28cbf4b2010-12-13 10:33:20 -0800438 * This key alters the behavior of other keys on the numeric keypad. */
Jeff Brown497a92c2010-09-12 17:55:08 -0700439 public static final int KEYCODE_NUM_LOCK = 143;
440 /** Key code constant: Numeric keypad '0' key. */
441 public static final int KEYCODE_NUMPAD_0 = 144;
442 /** Key code constant: Numeric keypad '1' key. */
443 public static final int KEYCODE_NUMPAD_1 = 145;
444 /** Key code constant: Numeric keypad '2' key. */
445 public static final int KEYCODE_NUMPAD_2 = 146;
446 /** Key code constant: Numeric keypad '3' key. */
447 public static final int KEYCODE_NUMPAD_3 = 147;
448 /** Key code constant: Numeric keypad '4' key. */
449 public static final int KEYCODE_NUMPAD_4 = 148;
450 /** Key code constant: Numeric keypad '5' key. */
451 public static final int KEYCODE_NUMPAD_5 = 149;
452 /** Key code constant: Numeric keypad '6' key. */
453 public static final int KEYCODE_NUMPAD_6 = 150;
454 /** Key code constant: Numeric keypad '7' key. */
455 public static final int KEYCODE_NUMPAD_7 = 151;
456 /** Key code constant: Numeric keypad '8' key. */
457 public static final int KEYCODE_NUMPAD_8 = 152;
458 /** Key code constant: Numeric keypad '9' key. */
459 public static final int KEYCODE_NUMPAD_9 = 153;
460 /** Key code constant: Numeric keypad '/' key (for division). */
461 public static final int KEYCODE_NUMPAD_DIVIDE = 154;
462 /** Key code constant: Numeric keypad '*' key (for multiplication). */
463 public static final int KEYCODE_NUMPAD_MULTIPLY = 155;
464 /** Key code constant: Numeric keypad '-' key (for subtraction). */
465 public static final int KEYCODE_NUMPAD_SUBTRACT = 156;
466 /** Key code constant: Numeric keypad '+' key (for addition). */
467 public static final int KEYCODE_NUMPAD_ADD = 157;
468 /** Key code constant: Numeric keypad '.' key (for decimals or digit grouping). */
469 public static final int KEYCODE_NUMPAD_DOT = 158;
470 /** Key code constant: Numeric keypad ',' key (for decimals or digit grouping). */
471 public static final int KEYCODE_NUMPAD_COMMA = 159;
472 /** Key code constant: Numeric keypad Enter key. */
473 public static final int KEYCODE_NUMPAD_ENTER = 160;
474 /** Key code constant: Numeric keypad '=' key. */
475 public static final int KEYCODE_NUMPAD_EQUALS = 161;
476 /** Key code constant: Numeric keypad '(' key. */
477 public static final int KEYCODE_NUMPAD_LEFT_PAREN = 162;
478 /** Key code constant: Numeric keypad ')' key. */
479 public static final int KEYCODE_NUMPAD_RIGHT_PAREN = 163;
Jeff Brownb0418da2010-11-01 15:24:01 -0700480 /** Key code constant: Volume Mute key.
481 * Mutes the speaker, unlike {@link #KEYCODE_MUTE}.
482 * This key should normally be implemented as a toggle such that the first press
483 * mutes the speaker and the second press restores the original volume. */
484 public static final int KEYCODE_VOLUME_MUTE = 164;
Jason Bayer3adf4902010-11-09 14:54:55 -0800485 /** Key code constant: Info key.
486 * Common on TV remotes to show additional information related to what is
487 * currently being viewed. */
488 public static final int KEYCODE_INFO = 165;
489 /** Key code constant: Channel up key.
490 * On TV remotes, increments the television channel. */
491 public static final int KEYCODE_CHANNEL_UP = 166;
492 /** Key code constant: Channel down key.
493 * On TV remotes, decrements the television channel. */
494 public static final int KEYCODE_CHANNEL_DOWN = 167;
495 /** Key code constant: Zoom in key. */
496 public static final int KEYCODE_ZOOM_IN = 168;
497 /** Key code constant: Zoom out key. */
498 public static final int KEYCODE_ZOOM_OUT = 169;
499 /** Key code constant: TV key.
500 * On TV remotes, switches to viewing live TV. */
501 public static final int KEYCODE_TV = 170;
502 /** Key code constant: Window key.
Julius D'souza03d4a652017-04-03 10:16:51 -0700503 * On TV remotes, toggles picture-in-picture mode or other windowing functions.
504 * On Android Wear devices, triggers a display offset. */
Jason Bayer3adf4902010-11-09 14:54:55 -0800505 public static final int KEYCODE_WINDOW = 171;
506 /** Key code constant: Guide key.
507 * On TV remotes, shows a programming guide. */
508 public static final int KEYCODE_GUIDE = 172;
509 /** Key code constant: DVR key.
510 * On some TV remotes, switches to a DVR mode for recorded shows. */
511 public static final int KEYCODE_DVR = 173;
512 /** Key code constant: Bookmark key.
513 * On some TV remotes, bookmarks content or web pages. */
514 public static final int KEYCODE_BOOKMARK = 174;
515 /** Key code constant: Toggle captions key.
516 * Switches the mode for closed-captioning text, for example during television shows. */
517 public static final int KEYCODE_CAPTIONS = 175;
518 /** Key code constant: Settings key.
519 * Starts the system settings activity. */
520 public static final int KEYCODE_SETTINGS = 176;
521 /** Key code constant: TV power key.
522 * On TV remotes, toggles the power on a television screen. */
523 public static final int KEYCODE_TV_POWER = 177;
524 /** Key code constant: TV input key.
525 * On TV remotes, switches the input on a television screen. */
526 public static final int KEYCODE_TV_INPUT = 178;
527 /** Key code constant: Set-top-box power key.
528 * On TV remotes, toggles the power on an external Set-top-box. */
529 public static final int KEYCODE_STB_POWER = 179;
530 /** Key code constant: Set-top-box input key.
531 * On TV remotes, switches the input mode on an external Set-top-box. */
532 public static final int KEYCODE_STB_INPUT = 180;
533 /** Key code constant: A/V Receiver power key.
534 * On TV remotes, toggles the power on an external A/V Receiver. */
535 public static final int KEYCODE_AVR_POWER = 181;
536 /** Key code constant: A/V Receiver input key.
537 * On TV remotes, switches the input mode on an external A/V Receiver. */
538 public static final int KEYCODE_AVR_INPUT = 182;
539 /** Key code constant: Red "programmable" key.
540 * On TV remotes, acts as a contextual/programmable key. */
541 public static final int KEYCODE_PROG_RED = 183;
542 /** Key code constant: Green "programmable" key.
543 * On TV remotes, actsas a contextual/programmable key. */
544 public static final int KEYCODE_PROG_GREEN = 184;
545 /** Key code constant: Yellow "programmable" key.
546 * On TV remotes, acts as a contextual/programmable key. */
547 public static final int KEYCODE_PROG_YELLOW = 185;
548 /** Key code constant: Blue "programmable" key.
549 * On TV remotes, acts as a contextual/programmable key. */
550 public static final int KEYCODE_PROG_BLUE = 186;
Jeff Brown49ed71d2010-12-06 17:13:33 -0800551 /** Key code constant: App switch key.
552 * Should bring up the application switcher dialog. */
553 public static final int KEYCODE_APP_SWITCH = 187;
Jeff Browncb1404e2011-01-15 18:14:15 -0800554 /** Key code constant: Generic Game Pad Button #1.*/
555 public static final int KEYCODE_BUTTON_1 = 188;
556 /** Key code constant: Generic Game Pad Button #2.*/
557 public static final int KEYCODE_BUTTON_2 = 189;
558 /** Key code constant: Generic Game Pad Button #3.*/
559 public static final int KEYCODE_BUTTON_3 = 190;
560 /** Key code constant: Generic Game Pad Button #4.*/
561 public static final int KEYCODE_BUTTON_4 = 191;
562 /** Key code constant: Generic Game Pad Button #5.*/
563 public static final int KEYCODE_BUTTON_5 = 192;
564 /** Key code constant: Generic Game Pad Button #6.*/
565 public static final int KEYCODE_BUTTON_6 = 193;
566 /** Key code constant: Generic Game Pad Button #7.*/
567 public static final int KEYCODE_BUTTON_7 = 194;
568 /** Key code constant: Generic Game Pad Button #8.*/
569 public static final int KEYCODE_BUTTON_8 = 195;
570 /** Key code constant: Generic Game Pad Button #9.*/
571 public static final int KEYCODE_BUTTON_9 = 196;
572 /** Key code constant: Generic Game Pad Button #10.*/
573 public static final int KEYCODE_BUTTON_10 = 197;
574 /** Key code constant: Generic Game Pad Button #11.*/
575 public static final int KEYCODE_BUTTON_11 = 198;
576 /** Key code constant: Generic Game Pad Button #12.*/
577 public static final int KEYCODE_BUTTON_12 = 199;
578 /** Key code constant: Generic Game Pad Button #13.*/
579 public static final int KEYCODE_BUTTON_13 = 200;
580 /** Key code constant: Generic Game Pad Button #14.*/
581 public static final int KEYCODE_BUTTON_14 = 201;
582 /** Key code constant: Generic Game Pad Button #15.*/
583 public static final int KEYCODE_BUTTON_15 = 202;
584 /** Key code constant: Generic Game Pad Button #16.*/
585 public static final int KEYCODE_BUTTON_16 = 203;
Jeff Brown9812aed2011-03-07 17:09:51 -0800586 /** Key code constant: Language Switch key.
587 * Toggles the current input language such as switching between English and Japanese on
588 * a QWERTY keyboard. On some devices, the same function may be performed by
589 * pressing Shift+Spacebar. */
590 public static final int KEYCODE_LANGUAGE_SWITCH = 204;
591 /** Key code constant: Manner Mode key.
592 * Toggles silent or vibrate mode on and off to make the device behave more politely
593 * in certain settings such as on a crowded train. On some devices, the key may only
594 * operate when long-pressed. */
595 public static final int KEYCODE_MANNER_MODE = 205;
596 /** Key code constant: 3D Mode key.
597 * Toggles the display between 2D and 3D mode. */
598 public static final int KEYCODE_3D_MODE = 206;
Jeff Brown6651a632011-11-28 12:59:11 -0800599 /** Key code constant: Contacts special function key.
600 * Used to launch an address book application. */
601 public static final int KEYCODE_CONTACTS = 207;
602 /** Key code constant: Calendar special function key.
603 * Used to launch a calendar application. */
604 public static final int KEYCODE_CALENDAR = 208;
605 /** Key code constant: Music special function key.
606 * Used to launch a music player application. */
607 public static final int KEYCODE_MUSIC = 209;
608 /** Key code constant: Calculator special function key.
609 * Used to launch a calculator application. */
610 public static final int KEYCODE_CALCULATOR = 210;
Yang Chuang7511f9c2012-02-10 15:18:26 +0800611 /** Key code constant: Japanese full-width / half-width key. */
612 public static final int KEYCODE_ZENKAKU_HANKAKU = 211;
613 /** Key code constant: Japanese alphanumeric key. */
614 public static final int KEYCODE_EISU = 212;
615 /** Key code constant: Japanese non-conversion key. */
616 public static final int KEYCODE_MUHENKAN = 213;
617 /** Key code constant: Japanese conversion key. */
618 public static final int KEYCODE_HENKAN = 214;
619 /** Key code constant: Japanese katakana / hiragana key. */
620 public static final int KEYCODE_KATAKANA_HIRAGANA = 215;
621 /** Key code constant: Japanese Yen key. */
622 public static final int KEYCODE_YEN = 216;
623 /** Key code constant: Japanese Ro key. */
624 public static final int KEYCODE_RO = 217;
625 /** Key code constant: Japanese kana key. */
626 public static final int KEYCODE_KANA = 218;
Jeff Brownde7a8ea2012-06-13 18:28:57 -0700627 /** Key code constant: Assist key.
628 * Launches the global assist activity. Not delivered to applications. */
629 public static final int KEYCODE_ASSIST = 219;
Michael Wright1df477a2013-01-31 16:19:18 -0800630 /** Key code constant: Brightness Down key.
631 * Adjusts the screen brightness down. */
632 public static final int KEYCODE_BRIGHTNESS_DOWN = 220;
633 /** Key code constant: Brightness Up key.
634 * Adjusts the screen brightness up. */
635 public static final int KEYCODE_BRIGHTNESS_UP = 221;
Jeff Brown6212a492014-03-07 13:58:47 -0800636 /** Key code constant: Audio Track key.
Jaekyun Seokbfdad8e2013-07-08 13:53:21 +0900637 * Switches the audio tracks. */
638 public static final int KEYCODE_MEDIA_AUDIO_TRACK = 222;
Jeff Brown6212a492014-03-07 13:58:47 -0800639 /** Key code constant: Sleep key.
640 * Puts the device to sleep. Behaves somewhat like {@link #KEYCODE_POWER} but it
641 * has no effect if the device is already asleep. */
642 public static final int KEYCODE_SLEEP = 223;
643 /** Key code constant: Wakeup key.
644 * Wakes up the device. Behaves somewhat like {@link #KEYCODE_POWER} but it
645 * has no effect if the device is already awake. */
646 public static final int KEYCODE_WAKEUP = 224;
Tim Kilbourn87cd0dc2014-04-14 15:37:51 -0700647 /** Key code constant: Pairing key.
648 * Initiates peripheral pairing mode. Useful for pairing remote control
649 * devices or game controllers, especially if no other input mode is
650 * available. */
651 public static final int KEYCODE_PAIRING = 225;
Jinsuk Kim96658f72014-05-14 15:33:43 +0900652 /** Key code constant: Media Top Menu key.
653 * Goes to the top of media menu. */
654 public static final int KEYCODE_MEDIA_TOP_MENU = 226;
655 /** Key code constant: '11' key. */
656 public static final int KEYCODE_11 = 227;
657 /** Key code constant: '12' key. */
658 public static final int KEYCODE_12 = 228;
659 /** Key code constant: Last Channel key.
660 * Goes to the last viewed channel. */
661 public static final int KEYCODE_LAST_CHANNEL = 229;
662 /** Key code constant: TV data service key.
663 * Displays data services like weather, sports. */
664 public static final int KEYCODE_TV_DATA_SERVICE = 230;
Michael Wrightdc63f7b2014-08-21 19:05:21 -0700665 /** Key code constant: Voice Assist key.
666 * Launches the global voice assist activity. Not delivered to applications. */
667 public static final int KEYCODE_VOICE_ASSIST = 231;
ASAZU, Hidekidbd6aba2014-08-27 18:03:30 +0900668 /** Key code constant: Radio key.
669 * Toggles TV service / Radio service. */
670 public static final int KEYCODE_TV_RADIO_SERVICE = 232;
671 /** Key code constant: Teletext key.
672 * Displays Teletext service. */
673 public static final int KEYCODE_TV_TELETEXT = 233;
674 /** Key code constant: Number entry key.
675 * Initiates to enter multi-digit channel nubmber when each digit key is assigned
676 * for selecting separate channel. Corresponds to Number Entry Mode (0x1D) of CEC
677 * User Control Code. */
678 public static final int KEYCODE_TV_NUMBER_ENTRY = 234;
679 /** Key code constant: Analog Terrestrial key.
680 * Switches to analog terrestrial broadcast service. */
681 public static final int KEYCODE_TV_TERRESTRIAL_ANALOG = 235;
682 /** Key code constant: Digital Terrestrial key.
683 * Switches to digital terrestrial broadcast service. */
684 public static final int KEYCODE_TV_TERRESTRIAL_DIGITAL = 236;
685 /** Key code constant: Satellite key.
686 * Switches to digital satellite broadcast service. */
687 public static final int KEYCODE_TV_SATELLITE = 237;
688 /** Key code constant: BS key.
689 * Switches to BS digital satellite broadcasting service available in Japan. */
690 public static final int KEYCODE_TV_SATELLITE_BS = 238;
691 /** Key code constant: CS key.
692 * Switches to CS digital satellite broadcasting service available in Japan. */
693 public static final int KEYCODE_TV_SATELLITE_CS = 239;
694 /** Key code constant: BS/CS key.
695 * Toggles between BS and CS digital satellite services. */
696 public static final int KEYCODE_TV_SATELLITE_SERVICE = 240;
697 /** Key code constant: Toggle Network key.
698 * Toggles selecting broacast services. */
699 public static final int KEYCODE_TV_NETWORK = 241;
700 /** Key code constant: Antenna/Cable key.
701 * Toggles broadcast input source between antenna and cable. */
702 public static final int KEYCODE_TV_ANTENNA_CABLE = 242;
703 /** Key code constant: HDMI #1 key.
704 * Switches to HDMI input #1. */
705 public static final int KEYCODE_TV_INPUT_HDMI_1 = 243;
706 /** Key code constant: HDMI #2 key.
707 * Switches to HDMI input #2. */
708 public static final int KEYCODE_TV_INPUT_HDMI_2 = 244;
709 /** Key code constant: HDMI #3 key.
710 * Switches to HDMI input #3. */
711 public static final int KEYCODE_TV_INPUT_HDMI_3 = 245;
712 /** Key code constant: HDMI #4 key.
713 * Switches to HDMI input #4. */
714 public static final int KEYCODE_TV_INPUT_HDMI_4 = 246;
715 /** Key code constant: Composite #1 key.
716 * Switches to composite video input #1. */
717 public static final int KEYCODE_TV_INPUT_COMPOSITE_1 = 247;
718 /** Key code constant: Composite #2 key.
719 * Switches to composite video input #2. */
720 public static final int KEYCODE_TV_INPUT_COMPOSITE_2 = 248;
721 /** Key code constant: Component #1 key.
722 * Switches to component video input #1. */
723 public static final int KEYCODE_TV_INPUT_COMPONENT_1 = 249;
724 /** Key code constant: Component #2 key.
725 * Switches to component video input #2. */
726 public static final int KEYCODE_TV_INPUT_COMPONENT_2 = 250;
727 /** Key code constant: VGA #1 key.
728 * Switches to VGA (analog RGB) input #1. */
729 public static final int KEYCODE_TV_INPUT_VGA_1 = 251;
730 /** Key code constant: Audio description key.
731 * Toggles audio description off / on. */
732 public static final int KEYCODE_TV_AUDIO_DESCRIPTION = 252;
733 /** Key code constant: Audio description mixing volume up key.
734 * Louden audio description volume as compared with normal audio volume. */
735 public static final int KEYCODE_TV_AUDIO_DESCRIPTION_MIX_UP = 253;
736 /** Key code constant: Audio description mixing volume down key.
737 * Lessen audio description volume as compared with normal audio volume. */
738 public static final int KEYCODE_TV_AUDIO_DESCRIPTION_MIX_DOWN = 254;
739 /** Key code constant: Zoom mode key.
740 * Changes Zoom mode (Normal, Full, Zoom, Wide-zoom, etc.) */
741 public static final int KEYCODE_TV_ZOOM_MODE = 255;
742 /** Key code constant: Contents menu key.
743 * Goes to the title list. Corresponds to Contents Menu (0x0B) of CEC User Control
744 * Code */
745 public static final int KEYCODE_TV_CONTENTS_MENU = 256;
746 /** Key code constant: Media context menu key.
747 * Goes to the context menu of media contents. Corresponds to Media Context-sensitive
748 * Menu (0x11) of CEC User Control Code. */
749 public static final int KEYCODE_TV_MEDIA_CONTEXT_MENU = 257;
750 /** Key code constant: Timer programming key.
751 * Goes to the timer recording menu. Corresponds to Timer Programming (0x54) of
752 * CEC User Control Code. */
753 public static final int KEYCODE_TV_TIMER_PROGRAMMING = 258;
754 /** Key code constant: Help key. */
755 public static final int KEYCODE_HELP = 259;
Michael Wright962c9532015-08-06 15:16:22 +0100756 /** Key code constant: Navigate to previous key.
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700757 * Goes backward by one item in an ordered collection of items. */
758 public static final int KEYCODE_NAVIGATE_PREVIOUS = 260;
Michael Wright962c9532015-08-06 15:16:22 +0100759 /** Key code constant: Navigate to next key.
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700760 * Advances to the next item in an ordered collection of items. */
761 public static final int KEYCODE_NAVIGATE_NEXT = 261;
762 /** Key code constant: Navigate in key.
Michael Wright962c9532015-08-06 15:16:22 +0100763 * Activates the item that currently has focus or expands to the next level of a navigation
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700764 * hierarchy. */
765 public static final int KEYCODE_NAVIGATE_IN = 262;
766 /** Key code constant: Navigate out key.
Michael Wright962c9532015-08-06 15:16:22 +0100767 * Backs out one level of a navigation hierarchy or collapses the item that currently has
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700768 * focus. */
769 public static final int KEYCODE_NAVIGATE_OUT = 263;
Anthony Hugh9d826682015-06-23 10:44:17 -0700770 /** Key code constant: Primary stem key for Wear
771 * Main power/reset button on watch. */
772 public static final int KEYCODE_STEM_PRIMARY = 264;
773 /** Key code constant: Generic stem key 1 for Wear */
774 public static final int KEYCODE_STEM_1 = 265;
775 /** Key code constant: Generic stem key 2 for Wear */
776 public static final int KEYCODE_STEM_2 = 266;
777 /** Key code constant: Generic stem key 3 for Wear */
778 public static final int KEYCODE_STEM_3 = 267;
David Stevensa487f0c2015-07-31 11:00:50 -0700779 /** Key code constant: Directional Pad Up-Left */
780 public static final int KEYCODE_DPAD_UP_LEFT = 268;
781 /** Key code constant: Directional Pad Down-Left */
782 public static final int KEYCODE_DPAD_DOWN_LEFT = 269;
783 /** Key code constant: Directional Pad Up-Right */
784 public static final int KEYCODE_DPAD_UP_RIGHT = 270;
785 /** Key code constant: Directional Pad Down-Right */
786 public static final int KEYCODE_DPAD_DOWN_RIGHT = 271;
Michael Wright962c9532015-08-06 15:16:22 +0100787 /** Key code constant: Skip forward media key. */
788 public static final int KEYCODE_MEDIA_SKIP_FORWARD = 272;
789 /** Key code constant: Skip backward media key. */
790 public static final int KEYCODE_MEDIA_SKIP_BACKWARD = 273;
791 /** Key code constant: Step forward media key.
792 * Steps media forward, one frame at a time. */
793 public static final int KEYCODE_MEDIA_STEP_FORWARD = 274;
794 /** Key code constant: Step backward media key.
795 * Steps media backward, one frame at a time. */
796 public static final int KEYCODE_MEDIA_STEP_BACKWARD = 275;
Nick Armstrong-Crews3a5a8c72015-09-09 09:25:03 -0700797 /** Key code constant: put device to sleep unless a wakelock is held. */
Nick Armstrong-Crews56ecfcc2015-09-07 21:46:50 -0700798 public static final int KEYCODE_SOFT_SLEEP = 276;
Michael Wrightea84cff2015-10-21 18:08:30 +0100799 /** Key code constant: Cut key. */
800 public static final int KEYCODE_CUT = 277;
801 /** Key code constant: Copy key. */
802 public static final int KEYCODE_COPY = 278;
803 /** Key code constant: Paste key. */
804 public static final int KEYCODE_PASTE = 279;
Jim Miller07e03842016-06-22 15:18:13 -0700805 /** Key code constant: Consumed by the system for navigation up */
806 public static final int KEYCODE_SYSTEM_NAVIGATION_UP = 280;
807 /** Key code constant: Consumed by the system for navigation down */
808 public static final int KEYCODE_SYSTEM_NAVIGATION_DOWN = 281;
809 /** Key code constant: Consumed by the system for navigation left*/
810 public static final int KEYCODE_SYSTEM_NAVIGATION_LEFT = 282;
811 /** Key code constant: Consumed by the system for navigation right */
812 public static final int KEYCODE_SYSTEM_NAVIGATION_RIGHT = 283;
Sujith Ramakrishnand2c9bc82017-11-02 09:54:16 -0700813 /** Key code constant: Show all apps */
Sujith Ramakrishnanf8942c02017-07-18 18:35:14 -0700814 public static final int KEYCODE_ALL_APPS = 284;
Yuichiro Hanadac1415f32018-01-15 22:36:00 +0900815 /** Key code constant: Refresh key. */
816 public static final int KEYCODE_REFRESH = 285;
Oleg Kibirevcdd17b52018-11-07 12:02:21 -0800817 /** Key code constant: Thumbs up key. Apps can use this to let user upvote content. */
818 public static final int KEYCODE_THUMBS_UP = 286;
819 /** Key code constant: Thumbs down key. Apps can use this to let user downvote content. */
820 public static final int KEYCODE_THUMBS_DOWN = 287;
Oleg Kibirev6ad1ff12019-01-03 15:05:11 -0800821 /**
822 * Key code constant: Used to switch current {@link android.accounts.Account} that is
823 * consuming content. May be consumed by system to set account globally.
824 */
Oleg Kibirevcdd17b52018-11-07 12:02:21 -0800825 public static final int KEYCODE_PROFILE_SWITCH = 288;
Jeff Brown497a92c2010-09-12 17:55:08 -0700826
Siarhei Vishniakoude1f9042018-05-09 09:54:43 -0700827 /**
828 * Integer value of the last KEYCODE. Increases as new keycodes are added to KeyEvent.
829 * @hide
830 */
831 @TestApi
Oleg Kibirevcdd17b52018-11-07 12:02:21 -0800832 public static final int LAST_KEYCODE = KEYCODE_PROFILE_SWITCH;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800833
834 // NOTE: If you add a new keycode here you must also add it to:
835 // isSystem()
Michael Wrightdc63f7b2014-08-21 19:05:21 -0700836 // isWakeKey()
Chirayu Desai61c37ae2013-04-15 20:11:37 +0530837 // frameworks/native/include/android/keycodes.h
Jinsuk Kim96658f72014-05-14 15:33:43 +0900838 // frameworks/native/include/input/InputEventLabels.h
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800839 // frameworks/base/core/res/res/values/attrs.xml
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800840 // emulator?
Jeff Brown6651a632011-11-28 12:59:11 -0800841 // LAST_KEYCODE
Dianne Hackborn935ae462009-04-13 16:11:55 -0700842 //
843 // Also Android currently does not reserve code ranges for vendor-
844 // specific key codes. If you have new key codes to have, you
845 // MUST contribute a patch to the open source project to define
846 // those new codes. This is intended to maintain a consistent
847 // set of key code definitions across all Android devices.
Jeff Brown497a92c2010-09-12 17:55:08 -0700848
Jeff Brown497a92c2010-09-12 17:55:08 -0700849 // Symbolic names of all metakeys in bit order from least significant to most significant.
850 // Accordingly there are exactly 32 values in this table.
Mathew Inwooda570dee2018-08-17 14:56:00 +0100851 @UnsupportedAppUsage
Jeff Brown497a92c2010-09-12 17:55:08 -0700852 private static final String[] META_SYMBOLIC_NAMES = new String[] {
853 "META_SHIFT_ON",
854 "META_ALT_ON",
855 "META_SYM_ON",
856 "META_FUNCTION_ON",
857 "META_ALT_LEFT_ON",
858 "META_ALT_RIGHT_ON",
859 "META_SHIFT_LEFT_ON",
860 "META_SHIFT_RIGHT_ON",
861 "META_CAP_LOCKED",
862 "META_ALT_LOCKED",
863 "META_SYM_LOCKED",
864 "0x00000800",
865 "META_CTRL_ON",
866 "META_CTRL_LEFT_ON",
867 "META_CTRL_RIGHT_ON",
868 "0x00008000",
869 "META_META_ON",
870 "META_META_LEFT_ON",
871 "META_META_RIGHT_ON",
872 "0x00080000",
Jeff Brown51e7fe72010-10-29 22:19:53 -0700873 "META_CAPS_LOCK_ON",
874 "META_NUM_LOCK_ON",
875 "META_SCROLL_LOCK_ON",
Jeff Brown497a92c2010-09-12 17:55:08 -0700876 "0x00800000",
877 "0x01000000",
878 "0x02000000",
879 "0x04000000",
880 "0x08000000",
881 "0x10000000",
882 "0x20000000",
883 "0x40000000",
884 "0x80000000",
885 };
886
Michael Wright337d9d22014-04-22 15:03:48 -0700887 private static final String LABEL_PREFIX = "KEYCODE_";
888
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800889 /**
890 * @deprecated There are now more than MAX_KEYCODE keycodes.
891 * Use {@link #getMaxKeyCode()} instead.
892 */
893 @Deprecated
894 public static final int MAX_KEYCODE = 84;
895
896 /**
897 * {@link #getAction} value: the key has been pressed down.
898 */
899 public static final int ACTION_DOWN = 0;
900 /**
901 * {@link #getAction} value: the key has been released.
902 */
903 public static final int ACTION_UP = 1;
904 /**
Siarhei Vishniakoue481d332018-07-18 14:46:00 +0100905 * @deprecated No longer used by the input system.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800906 * {@link #getAction} value: multiple duplicate key events have
907 * occurred in a row, or a complex string is being delivered. If the
Andrew Solovay5c05ded2018-10-02 14:14:42 -0700908 * key code is not {@link #KEYCODE_UNKNOWN} then the
909 * {@link #getRepeatCount()} method returns the number of times
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800910 * the given key code should be executed.
Jeff Brown46b9ac02010-04-22 18:58:52 -0700911 * Otherwise, if the key code is {@link #KEYCODE_UNKNOWN}, then
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800912 * this is a sequence of characters as returned by {@link #getCharacters}.
913 */
Siarhei Vishniakoue481d332018-07-18 14:46:00 +0100914 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800915 public static final int ACTION_MULTIPLE = 2;
916
917 /**
Jeff Brown497a92c2010-09-12 17:55:08 -0700918 * SHIFT key locked in CAPS mode.
919 * Reserved for use by {@link MetaKeyKeyListener} for a published constant in its API.
920 * @hide
921 */
Mathew Inwooda570dee2018-08-17 14:56:00 +0100922 @UnsupportedAppUsage
Jeff Brown497a92c2010-09-12 17:55:08 -0700923 public static final int META_CAP_LOCKED = 0x100;
924
925 /**
926 * ALT key locked.
927 * Reserved for use by {@link MetaKeyKeyListener} for a published constant in its API.
928 * @hide
929 */
Mathew Inwooda570dee2018-08-17 14:56:00 +0100930 @UnsupportedAppUsage
Jeff Brown497a92c2010-09-12 17:55:08 -0700931 public static final int META_ALT_LOCKED = 0x200;
932
933 /**
934 * SYM key locked.
935 * Reserved for use by {@link MetaKeyKeyListener} for a published constant in its API.
936 * @hide
937 */
Mathew Inwooda570dee2018-08-17 14:56:00 +0100938 @UnsupportedAppUsage
Jeff Brown497a92c2010-09-12 17:55:08 -0700939 public static final int META_SYM_LOCKED = 0x400;
940
941 /**
942 * Text is in selection mode.
943 * Reserved for use by {@link MetaKeyKeyListener} for a private unpublished constant
944 * in its API that is currently being retained for legacy reasons.
945 * @hide
946 */
Mathew Inwooda570dee2018-08-17 14:56:00 +0100947 @UnsupportedAppUsage
Jeff Brown497a92c2010-09-12 17:55:08 -0700948 public static final int META_SELECTING = 0x800;
949
950 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800951 * <p>This mask is used to check whether one of the ALT meta keys is pressed.</p>
952 *
953 * @see #isAltPressed()
954 * @see #getMetaState()
955 * @see #KEYCODE_ALT_LEFT
956 * @see #KEYCODE_ALT_RIGHT
957 */
958 public static final int META_ALT_ON = 0x02;
959
960 /**
961 * <p>This mask is used to check whether the left ALT meta key is pressed.</p>
962 *
963 * @see #isAltPressed()
964 * @see #getMetaState()
965 * @see #KEYCODE_ALT_LEFT
966 */
967 public static final int META_ALT_LEFT_ON = 0x10;
968
969 /**
970 * <p>This mask is used to check whether the right the ALT meta key is pressed.</p>
971 *
972 * @see #isAltPressed()
973 * @see #getMetaState()
974 * @see #KEYCODE_ALT_RIGHT
975 */
976 public static final int META_ALT_RIGHT_ON = 0x20;
977
978 /**
979 * <p>This mask is used to check whether one of the SHIFT meta keys is pressed.</p>
980 *
981 * @see #isShiftPressed()
982 * @see #getMetaState()
983 * @see #KEYCODE_SHIFT_LEFT
984 * @see #KEYCODE_SHIFT_RIGHT
985 */
986 public static final int META_SHIFT_ON = 0x1;
987
988 /**
989 * <p>This mask is used to check whether the left SHIFT meta key is pressed.</p>
990 *
991 * @see #isShiftPressed()
992 * @see #getMetaState()
993 * @see #KEYCODE_SHIFT_LEFT
994 */
995 public static final int META_SHIFT_LEFT_ON = 0x40;
996
997 /**
998 * <p>This mask is used to check whether the right SHIFT meta key is pressed.</p>
999 *
1000 * @see #isShiftPressed()
1001 * @see #getMetaState()
1002 * @see #KEYCODE_SHIFT_RIGHT
1003 */
1004 public static final int META_SHIFT_RIGHT_ON = 0x80;
1005
1006 /**
1007 * <p>This mask is used to check whether the SYM meta key is pressed.</p>
1008 *
1009 * @see #isSymPressed()
1010 * @see #getMetaState()
1011 */
1012 public static final int META_SYM_ON = 0x4;
1013
1014 /**
Jeff Brown497a92c2010-09-12 17:55:08 -07001015 * <p>This mask is used to check whether the FUNCTION meta key is pressed.</p>
1016 *
1017 * @see #isFunctionPressed()
1018 * @see #getMetaState()
1019 */
1020 public static final int META_FUNCTION_ON = 0x8;
1021
1022 /**
1023 * <p>This mask is used to check whether one of the CTRL meta keys is pressed.</p>
1024 *
1025 * @see #isCtrlPressed()
1026 * @see #getMetaState()
1027 * @see #KEYCODE_CTRL_LEFT
1028 * @see #KEYCODE_CTRL_RIGHT
1029 */
1030 public static final int META_CTRL_ON = 0x1000;
1031
1032 /**
1033 * <p>This mask is used to check whether the left CTRL meta key is pressed.</p>
1034 *
1035 * @see #isCtrlPressed()
1036 * @see #getMetaState()
1037 * @see #KEYCODE_CTRL_LEFT
1038 */
1039 public static final int META_CTRL_LEFT_ON = 0x2000;
1040
1041 /**
1042 * <p>This mask is used to check whether the right CTRL meta key is pressed.</p>
1043 *
1044 * @see #isCtrlPressed()
1045 * @see #getMetaState()
1046 * @see #KEYCODE_CTRL_RIGHT
1047 */
1048 public static final int META_CTRL_RIGHT_ON = 0x4000;
1049
1050 /**
1051 * <p>This mask is used to check whether one of the META meta keys is pressed.</p>
1052 *
1053 * @see #isMetaPressed()
1054 * @see #getMetaState()
1055 * @see #KEYCODE_META_LEFT
1056 * @see #KEYCODE_META_RIGHT
1057 */
1058 public static final int META_META_ON = 0x10000;
1059
1060 /**
1061 * <p>This mask is used to check whether the left META meta key is pressed.</p>
1062 *
1063 * @see #isMetaPressed()
1064 * @see #getMetaState()
1065 * @see #KEYCODE_META_LEFT
1066 */
1067 public static final int META_META_LEFT_ON = 0x20000;
1068
1069 /**
1070 * <p>This mask is used to check whether the right META meta key is pressed.</p>
1071 *
1072 * @see #isMetaPressed()
1073 * @see #getMetaState()
1074 * @see #KEYCODE_META_RIGHT
1075 */
1076 public static final int META_META_RIGHT_ON = 0x40000;
1077
1078 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07001079 * <p>This mask is used to check whether the CAPS LOCK meta key is on.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07001080 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07001081 * @see #isCapsLockOn()
Jeff Brown497a92c2010-09-12 17:55:08 -07001082 * @see #getMetaState()
1083 * @see #KEYCODE_CAPS_LOCK
1084 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07001085 public static final int META_CAPS_LOCK_ON = 0x100000;
Jeff Brown497a92c2010-09-12 17:55:08 -07001086
1087 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07001088 * <p>This mask is used to check whether the NUM LOCK meta key is on.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07001089 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07001090 * @see #isNumLockOn()
Jeff Brown497a92c2010-09-12 17:55:08 -07001091 * @see #getMetaState()
1092 * @see #KEYCODE_NUM_LOCK
1093 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07001094 public static final int META_NUM_LOCK_ON = 0x200000;
Jeff Brown497a92c2010-09-12 17:55:08 -07001095
1096 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07001097 * <p>This mask is used to check whether the SCROLL LOCK meta key is on.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07001098 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07001099 * @see #isScrollLockOn()
Jeff Brown497a92c2010-09-12 17:55:08 -07001100 * @see #getMetaState()
1101 * @see #KEYCODE_SCROLL_LOCK
1102 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07001103 public static final int META_SCROLL_LOCK_ON = 0x400000;
Jeff Brown497a92c2010-09-12 17:55:08 -07001104
Jeff Brown64da12a2011-01-04 19:57:47 -08001105 /**
1106 * This mask is a combination of {@link #META_SHIFT_ON}, {@link #META_SHIFT_LEFT_ON}
1107 * and {@link #META_SHIFT_RIGHT_ON}.
1108 */
Jeff Brownc1df9072010-12-21 16:38:50 -08001109 public static final int META_SHIFT_MASK = META_SHIFT_ON
1110 | META_SHIFT_LEFT_ON | META_SHIFT_RIGHT_ON;
1111
Jeff Brown64da12a2011-01-04 19:57:47 -08001112 /**
1113 * This mask is a combination of {@link #META_ALT_ON}, {@link #META_ALT_LEFT_ON}
1114 * and {@link #META_ALT_RIGHT_ON}.
1115 */
Jeff Brownc1df9072010-12-21 16:38:50 -08001116 public static final int META_ALT_MASK = META_ALT_ON
1117 | META_ALT_LEFT_ON | META_ALT_RIGHT_ON;
1118
Jeff Brown64da12a2011-01-04 19:57:47 -08001119 /**
1120 * This mask is a combination of {@link #META_CTRL_ON}, {@link #META_CTRL_LEFT_ON}
1121 * and {@link #META_CTRL_RIGHT_ON}.
1122 */
Jeff Brownc1df9072010-12-21 16:38:50 -08001123 public static final int META_CTRL_MASK = META_CTRL_ON
1124 | META_CTRL_LEFT_ON | META_CTRL_RIGHT_ON;
1125
Jeff Brown64da12a2011-01-04 19:57:47 -08001126 /**
1127 * This mask is a combination of {@link #META_META_ON}, {@link #META_META_LEFT_ON}
1128 * and {@link #META_META_RIGHT_ON}.
1129 */
1130 public static final int META_META_MASK = META_META_ON
Jeff Brownc1df9072010-12-21 16:38:50 -08001131 | META_META_LEFT_ON | META_META_RIGHT_ON;
1132
Jeff Brown497a92c2010-09-12 17:55:08 -07001133 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001134 * This mask is set if the device woke because of this key event.
Jeff Brown037c33e2014-04-09 00:31:55 -07001135 *
1136 * @deprecated This flag will never be set by the system since the system
1137 * consumes all wake keys itself.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001138 */
Jeff Brown037c33e2014-04-09 00:31:55 -07001139 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001140 public static final int FLAG_WOKE_HERE = 0x1;
RoboErik01fe6612014-02-13 14:19:04 -08001141
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001142 /**
1143 * This mask is set if the key event was generated by a software keyboard.
1144 */
1145 public static final int FLAG_SOFT_KEYBOARD = 0x2;
RoboErik01fe6612014-02-13 14:19:04 -08001146
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001147 /**
1148 * This mask is set if we don't want the key event to cause us to leave
1149 * touch mode.
1150 */
1151 public static final int FLAG_KEEP_TOUCH_MODE = 0x4;
RoboErik01fe6612014-02-13 14:19:04 -08001152
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001153 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001154 * This mask is set if an event was known to come from a trusted part
1155 * of the system. That is, the event is known to come from the user,
1156 * and could not have been spoofed by a third party component.
1157 */
1158 public static final int FLAG_FROM_SYSTEM = 0x8;
RoboErik01fe6612014-02-13 14:19:04 -08001159
The Android Open Source Project10592532009-03-18 17:39:46 -07001160 /**
1161 * This mask is used for compatibility, to identify enter keys that are
1162 * coming from an IME whose enter key has been auto-labelled "next" or
1163 * "done". This allows TextView to dispatch these as normal enter keys
1164 * for old applications, but still do the appropriate action when
1165 * receiving them.
1166 */
1167 public static final int FLAG_EDITOR_ACTION = 0x10;
RoboErik01fe6612014-02-13 14:19:04 -08001168
The Android Open Source Project10592532009-03-18 17:39:46 -07001169 /**
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001170 * When associated with up key events, this indicates that the key press
1171 * has been canceled. Typically this is used with virtual touch screen
1172 * keys, where the user can slide from the virtual key area on to the
1173 * display: in that case, the application will receive a canceled up
1174 * event and should not perform the action normally associated with the
1175 * key. Note that for this to work, the application can not perform an
1176 * action for a key until it receives an up or the long press timeout has
RoboErik01fe6612014-02-13 14:19:04 -08001177 * expired.
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001178 */
1179 public static final int FLAG_CANCELED = 0x20;
RoboErik01fe6612014-02-13 14:19:04 -08001180
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001181 /**
1182 * This key event was generated by a virtual (on-screen) hard key area.
1183 * Typically this is an area of the touchscreen, outside of the regular
1184 * display, dedicated to "hardware" buttons.
1185 */
1186 public static final int FLAG_VIRTUAL_HARD_KEY = 0x40;
RoboErik01fe6612014-02-13 14:19:04 -08001187
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001188 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001189 * This flag is set for the first key repeat that occurs after the
1190 * long press timeout.
1191 */
1192 public static final int FLAG_LONG_PRESS = 0x80;
RoboErik01fe6612014-02-13 14:19:04 -08001193
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001194 /**
1195 * Set when a key event has {@link #FLAG_CANCELED} set because a long
RoboErik01fe6612014-02-13 14:19:04 -08001196 * press action was executed while it was down.
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001197 */
1198 public static final int FLAG_CANCELED_LONG_PRESS = 0x100;
RoboErik01fe6612014-02-13 14:19:04 -08001199
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001200 /**
1201 * Set for {@link #ACTION_UP} when this event's key code is still being
1202 * tracked from its initial down. That is, somebody requested that tracking
1203 * started on the key down and a long press has not caused
1204 * the tracking to be canceled.
1205 */
1206 public static final int FLAG_TRACKING = 0x200;
Jeff Brown49ed71d2010-12-06 17:13:33 -08001207
1208 /**
1209 * Set when a key event has been synthesized to implement default behavior
1210 * for an event that the application did not handle.
1211 * Fallback key events are generated by unhandled trackball motions
1212 * (to emulate a directional keypad) and by certain unhandled key presses
1213 * that are declared in the key map (such as special function numeric keypad
1214 * keys when numlock is off).
1215 */
1216 public static final int FLAG_FALLBACK = 0x400;
1217
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001218 /**
Michael Wrighta44dd262013-04-10 21:12:00 -07001219 * Signifies that the key is being predispatched.
1220 * @hide
1221 */
1222 public static final int FLAG_PREDISPATCH = 0x20000000;
1223
1224 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001225 * Private control to determine when an app is tracking a key sequence.
1226 * @hide
1227 */
1228 public static final int FLAG_START_TRACKING = 0x40000000;
Jeff Brown21bc5c92011-02-28 18:27:14 -08001229
1230 /**
1231 * Private flag that indicates when the system has detected that this key event
1232 * may be inconsistent with respect to the sequence of previously delivered key events,
1233 * such as when a key up event is sent but the key was not down.
1234 *
1235 * @hide
1236 * @see #isTainted
1237 * @see #setTainted
1238 */
1239 public static final int FLAG_TAINTED = 0x80000000;
1240
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001241 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001242 * Returns the maximum keycode.
1243 */
1244 public static int getMaxKeyCode() {
1245 return LAST_KEYCODE;
1246 }
1247
1248 /**
1249 * Get the character that is produced by putting accent on the character
1250 * c.
1251 * For example, getDeadChar('`', 'e') returns &egrave;.
1252 */
1253 public static int getDeadChar(int accent, int c) {
1254 return KeyCharacterMap.getDeadChar(accent, c);
1255 }
RoboErik01fe6612014-02-13 14:19:04 -08001256
Dianne Hackborn8d374262009-09-14 21:21:52 -07001257 static final boolean DEBUG = false;
1258 static final String TAG = "KeyEvent";
Jeff Brown1f245102010-11-18 20:53:46 -08001259
1260 private static final int MAX_RECYCLED = 10;
1261 private static final Object gRecyclerLock = new Object();
1262 private static int gRecyclerUsed;
1263 private static KeyEvent gRecyclerTop;
1264
1265 private KeyEvent mNext;
Jeff Brown1f245102010-11-18 20:53:46 -08001266
Mathew Inwooda570dee2018-08-17 14:56:00 +01001267 @UnsupportedAppUsage
Jeff Brown91c69ab2011-02-14 17:03:18 -08001268 private int mDeviceId;
Mathew Inwood8c854f82018-09-14 12:35:36 +01001269 @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023)
Jeff Brown91c69ab2011-02-14 17:03:18 -08001270 private int mSource;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001271 private int mDisplayId;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001272 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001273 private int mMetaState;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001274 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001275 private int mAction;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001276 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001277 private int mKeyCode;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001278 @UnsupportedAppUsage
Jeff Brown46b9ac02010-04-22 18:58:52 -07001279 private int mScanCode;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001280 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001281 private int mRepeatCount;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001282 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001283 private int mFlags;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001284 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001285 private long mDownTime;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001286 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001287 private long mEventTime;
Mathew Inwooda570dee2018-08-17 14:56:00 +01001288 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001289 private String mCharacters;
1290
1291 public interface Callback {
1292 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001293 * Called when a key down event has occurred. If you return true,
1294 * you can first call {@link KeyEvent#startTracking()
1295 * KeyEvent.startTracking()} to have the framework track the event
1296 * through its {@link #onKeyUp(int, KeyEvent)} and also call your
1297 * {@link #onKeyLongPress(int, KeyEvent)} if it occurs.
RoboErik01fe6612014-02-13 14:19:04 -08001298 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001299 * @param keyCode The value in event.getKeyCode().
1300 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001301 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001302 * @return If you handled the event, return true. If you want to allow
1303 * the event to be handled by the next receiver, return false.
1304 */
1305 boolean onKeyDown(int keyCode, KeyEvent event);
1306
1307 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001308 * Called when a long press has occurred. If you return true,
1309 * the final key up will have {@link KeyEvent#FLAG_CANCELED} and
1310 * {@link KeyEvent#FLAG_CANCELED_LONG_PRESS} set. Note that in
1311 * order to receive this callback, someone in the event change
1312 * <em>must</em> return true from {@link #onKeyDown} <em>and</em>
1313 * call {@link KeyEvent#startTracking()} on the event.
RoboErik01fe6612014-02-13 14:19:04 -08001314 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001315 * @param keyCode The value in event.getKeyCode().
1316 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001317 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001318 * @return If you handled the event, return true. If you want to allow
1319 * the event to be handled by the next receiver, return false.
1320 */
1321 boolean onKeyLongPress(int keyCode, KeyEvent event);
1322
1323 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001324 * Called when a key up event has occurred.
RoboErik01fe6612014-02-13 14:19:04 -08001325 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001326 * @param keyCode The value in event.getKeyCode().
1327 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001328 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001329 * @return If you handled the event, return true. If you want to allow
1330 * the event to be handled by the next receiver, return false.
1331 */
1332 boolean onKeyUp(int keyCode, KeyEvent event);
1333
1334 /**
Kevin Hufnagleb248b1f2016-09-13 19:36:20 -07001335 * Called when a user's interaction with an analog control, such as
1336 * flinging a trackball, generates simulated down/up events for the same
1337 * key multiple times in quick succession.
RoboErik01fe6612014-02-13 14:19:04 -08001338 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001339 * @param keyCode The value in event.getKeyCode().
1340 * @param count Number of pairs as returned by event.getRepeatCount().
1341 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001342 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001343 * @return If you handled the event, return true. If you want to allow
1344 * the event to be handled by the next receiver, return false.
1345 */
1346 boolean onKeyMultiple(int keyCode, int count, KeyEvent event);
1347 }
1348
Michael Wright337d9d22014-04-22 15:03:48 -07001349 private static native String nativeKeyCodeToString(int keyCode);
1350 private static native int nativeKeyCodeFromString(String keyCode);
Jeff Brown497a92c2010-09-12 17:55:08 -07001351
Jeff Brown1f245102010-11-18 20:53:46 -08001352 private KeyEvent() {
1353 }
1354
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001355 /**
1356 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001357 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001358 * @param action Action code: either {@link #ACTION_DOWN},
1359 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1360 * @param code The key code.
1361 */
1362 public KeyEvent(int action, int code) {
1363 mAction = action;
1364 mKeyCode = code;
1365 mRepeatCount = 0;
Jeff Brown6b53e8d2010-11-10 16:03:06 -08001366 mDeviceId = KeyCharacterMap.VIRTUAL_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001367 }
1368
1369 /**
1370 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001371 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001372 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1373 * at which this key code originally went down.
1374 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1375 * at which this event happened.
1376 * @param action Action code: either {@link #ACTION_DOWN},
1377 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1378 * @param code The key code.
1379 * @param repeat A repeat count for down events (> 0 if this is after the
1380 * initial down) or event count for multiple events.
1381 */
1382 public KeyEvent(long downTime, long eventTime, int action,
1383 int code, int repeat) {
1384 mDownTime = downTime;
1385 mEventTime = eventTime;
1386 mAction = action;
1387 mKeyCode = code;
1388 mRepeatCount = repeat;
Jeff Brown6b53e8d2010-11-10 16:03:06 -08001389 mDeviceId = KeyCharacterMap.VIRTUAL_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001390 }
1391
1392 /**
1393 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001394 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001395 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1396 * at which this key code originally went down.
1397 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1398 * at which this event happened.
1399 * @param action Action code: either {@link #ACTION_DOWN},
1400 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1401 * @param code The key code.
1402 * @param repeat A repeat count for down events (> 0 if this is after the
1403 * initial down) or event count for multiple events.
1404 * @param metaState Flags indicating which meta keys are currently pressed.
1405 */
1406 public KeyEvent(long downTime, long eventTime, int action,
1407 int code, int repeat, int metaState) {
1408 mDownTime = downTime;
1409 mEventTime = eventTime;
1410 mAction = action;
1411 mKeyCode = code;
1412 mRepeatCount = repeat;
1413 mMetaState = metaState;
Jeff Brown6b53e8d2010-11-10 16:03:06 -08001414 mDeviceId = KeyCharacterMap.VIRTUAL_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001415 }
1416
1417 /**
1418 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001419 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001420 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1421 * at which this key code originally went down.
1422 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1423 * at which this event happened.
1424 * @param action Action code: either {@link #ACTION_DOWN},
1425 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1426 * @param code The key code.
1427 * @param repeat A repeat count for down events (> 0 if this is after the
1428 * initial down) or event count for multiple events.
1429 * @param metaState Flags indicating which meta keys are currently pressed.
Jeff Brownc5ed5912010-07-14 18:48:53 -07001430 * @param deviceId The device ID that generated the key event.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001431 * @param scancode Raw device scan code of the event.
1432 */
1433 public KeyEvent(long downTime, long eventTime, int action,
1434 int code, int repeat, int metaState,
Jeff Brownc5ed5912010-07-14 18:48:53 -07001435 int deviceId, int scancode) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001436 mDownTime = downTime;
1437 mEventTime = eventTime;
1438 mAction = action;
1439 mKeyCode = code;
1440 mRepeatCount = repeat;
1441 mMetaState = metaState;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001442 mDeviceId = deviceId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001443 mScanCode = scancode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001444 }
1445
1446 /**
1447 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001448 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001449 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1450 * at which this key code originally went down.
1451 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1452 * at which this event happened.
1453 * @param action Action code: either {@link #ACTION_DOWN},
1454 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1455 * @param code The key code.
1456 * @param repeat A repeat count for down events (> 0 if this is after the
1457 * initial down) or event count for multiple events.
1458 * @param metaState Flags indicating which meta keys are currently pressed.
Jeff Brownc5ed5912010-07-14 18:48:53 -07001459 * @param deviceId The device ID that generated the key event.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001460 * @param scancode Raw device scan code of the event.
1461 * @param flags The flags for this key event
1462 */
1463 public KeyEvent(long downTime, long eventTime, int action,
1464 int code, int repeat, int metaState,
Jeff Brownc5ed5912010-07-14 18:48:53 -07001465 int deviceId, int scancode, int flags) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001466 mDownTime = downTime;
1467 mEventTime = eventTime;
1468 mAction = action;
1469 mKeyCode = code;
1470 mRepeatCount = repeat;
1471 mMetaState = metaState;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001472 mDeviceId = deviceId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001473 mScanCode = scancode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001474 mFlags = flags;
1475 }
1476
1477 /**
Jeff Brownc5ed5912010-07-14 18:48:53 -07001478 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001479 *
Jeff Brownc5ed5912010-07-14 18:48:53 -07001480 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1481 * at which this key code originally went down.
1482 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1483 * at which this event happened.
1484 * @param action Action code: either {@link #ACTION_DOWN},
1485 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1486 * @param code The key code.
1487 * @param repeat A repeat count for down events (> 0 if this is after the
1488 * initial down) or event count for multiple events.
1489 * @param metaState Flags indicating which meta keys are currently pressed.
1490 * @param deviceId The device ID that generated the key event.
1491 * @param scancode Raw device scan code of the event.
1492 * @param flags The flags for this key event
1493 * @param source The input source such as {@link InputDevice#SOURCE_KEYBOARD}.
1494 */
1495 public KeyEvent(long downTime, long eventTime, int action,
1496 int code, int repeat, int metaState,
1497 int deviceId, int scancode, int flags, int source) {
1498 mDownTime = downTime;
1499 mEventTime = eventTime;
1500 mAction = action;
1501 mKeyCode = code;
1502 mRepeatCount = repeat;
1503 mMetaState = metaState;
1504 mDeviceId = deviceId;
1505 mScanCode = scancode;
1506 mFlags = flags;
1507 mSource = source;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001508 mDisplayId = INVALID_DISPLAY;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001509 }
1510
1511 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001512 * Create a new key event for a string of characters. The key code,
Jeff Brownc5ed5912010-07-14 18:48:53 -07001513 * action, repeat count and source will automatically be set to
1514 * {@link #KEYCODE_UNKNOWN}, {@link #ACTION_MULTIPLE}, 0, and
1515 * {@link InputDevice#SOURCE_KEYBOARD} for you.
RoboErik01fe6612014-02-13 14:19:04 -08001516 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001517 * @param time The time (in {@link android.os.SystemClock#uptimeMillis})
1518 * at which this event occured.
1519 * @param characters The string of characters.
Jeff Brownc5ed5912010-07-14 18:48:53 -07001520 * @param deviceId The device ID that generated the key event.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001521 * @param flags The flags for this key event
1522 */
Jeff Brownc5ed5912010-07-14 18:48:53 -07001523 public KeyEvent(long time, String characters, int deviceId, int flags) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001524 mDownTime = time;
1525 mEventTime = time;
1526 mCharacters = characters;
1527 mAction = ACTION_MULTIPLE;
1528 mKeyCode = KEYCODE_UNKNOWN;
1529 mRepeatCount = 0;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001530 mDeviceId = deviceId;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001531 mFlags = flags;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001532 mSource = InputDevice.SOURCE_KEYBOARD;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001533 mDisplayId = INVALID_DISPLAY;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001534 }
1535
1536 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001537 * Make an exact copy of an existing key event.
1538 */
1539 public KeyEvent(KeyEvent origEvent) {
1540 mDownTime = origEvent.mDownTime;
1541 mEventTime = origEvent.mEventTime;
1542 mAction = origEvent.mAction;
1543 mKeyCode = origEvent.mKeyCode;
1544 mRepeatCount = origEvent.mRepeatCount;
1545 mMetaState = origEvent.mMetaState;
1546 mDeviceId = origEvent.mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001547 mSource = origEvent.mSource;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001548 mDisplayId = origEvent.mDisplayId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001549 mScanCode = origEvent.mScanCode;
The Android Open Source Project10592532009-03-18 17:39:46 -07001550 mFlags = origEvent.mFlags;
1551 mCharacters = origEvent.mCharacters;
1552 }
1553
1554 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001555 * Copy an existing key event, modifying its time and repeat count.
RoboErik01fe6612014-02-13 14:19:04 -08001556 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001557 * @deprecated Use {@link #changeTimeRepeat(KeyEvent, long, int)}
1558 * instead.
RoboErik01fe6612014-02-13 14:19:04 -08001559 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001560 * @param origEvent The existing event to be copied.
1561 * @param eventTime The new event time
1562 * (in {@link android.os.SystemClock#uptimeMillis}) of the event.
1563 * @param newRepeat The new repeat count of the event.
1564 */
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001565 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001566 public KeyEvent(KeyEvent origEvent, long eventTime, int newRepeat) {
1567 mDownTime = origEvent.mDownTime;
1568 mEventTime = eventTime;
1569 mAction = origEvent.mAction;
1570 mKeyCode = origEvent.mKeyCode;
1571 mRepeatCount = newRepeat;
1572 mMetaState = origEvent.mMetaState;
1573 mDeviceId = origEvent.mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001574 mSource = origEvent.mSource;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001575 mDisplayId = origEvent.mDisplayId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001576 mScanCode = origEvent.mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001577 mFlags = origEvent.mFlags;
1578 mCharacters = origEvent.mCharacters;
1579 }
1580
Jeff Brown1f245102010-11-18 20:53:46 -08001581 private static KeyEvent obtain() {
1582 final KeyEvent ev;
1583 synchronized (gRecyclerLock) {
1584 ev = gRecyclerTop;
1585 if (ev == null) {
1586 return new KeyEvent();
1587 }
1588 gRecyclerTop = ev.mNext;
1589 gRecyclerUsed -= 1;
1590 }
Jeff Brown1f245102010-11-18 20:53:46 -08001591 ev.mNext = null;
Jeff Brown32cbc38552011-12-01 14:01:49 -08001592 ev.prepareForReuse();
Jeff Brown1f245102010-11-18 20:53:46 -08001593 return ev;
1594 }
1595
1596 /**
1597 * Obtains a (potentially recycled) key event.
1598 *
1599 * @hide
1600 */
1601 public static KeyEvent obtain(long downTime, long eventTime, int action,
Siarhei Vishniakou85ddfff2018-01-31 16:49:36 -08001602 int code, int repeat, int metaState,
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001603 int deviceId, int scancode, int flags, int source, int displayId, String characters) {
Jeff Brown1f245102010-11-18 20:53:46 -08001604 KeyEvent ev = obtain();
1605 ev.mDownTime = downTime;
1606 ev.mEventTime = eventTime;
1607 ev.mAction = action;
1608 ev.mKeyCode = code;
1609 ev.mRepeatCount = repeat;
1610 ev.mMetaState = metaState;
1611 ev.mDeviceId = deviceId;
1612 ev.mScanCode = scancode;
1613 ev.mFlags = flags;
1614 ev.mSource = source;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001615 ev.mDisplayId = displayId;
Jeff Brown1f245102010-11-18 20:53:46 -08001616 ev.mCharacters = characters;
1617 return ev;
1618 }
1619
1620 /**
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001621 * Obtains a (potentially recycled) key event.
1622 *
1623 * @hide
1624 */
Mathew Inwooda570dee2018-08-17 14:56:00 +01001625 @UnsupportedAppUsage
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001626 public static KeyEvent obtain(long downTime, long eventTime, int action,
1627 int code, int repeat, int metaState,
1628 int deviceId, int scancode, int flags, int source, String characters) {
1629 return obtain(downTime, eventTime, action, code, repeat, metaState, deviceId, scancode,
1630 flags, source, INVALID_DISPLAY, characters);
1631 }
1632
1633 /**
1634
1635 /**
Jeff Brown21bc5c92011-02-28 18:27:14 -08001636 * Obtains a (potentially recycled) copy of another key event.
1637 *
1638 * @hide
1639 */
1640 public static KeyEvent obtain(KeyEvent other) {
1641 KeyEvent ev = obtain();
1642 ev.mDownTime = other.mDownTime;
1643 ev.mEventTime = other.mEventTime;
1644 ev.mAction = other.mAction;
1645 ev.mKeyCode = other.mKeyCode;
1646 ev.mRepeatCount = other.mRepeatCount;
1647 ev.mMetaState = other.mMetaState;
1648 ev.mDeviceId = other.mDeviceId;
1649 ev.mScanCode = other.mScanCode;
1650 ev.mFlags = other.mFlags;
1651 ev.mSource = other.mSource;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001652 ev.mDisplayId = other.mDisplayId;
Jeff Brown21bc5c92011-02-28 18:27:14 -08001653 ev.mCharacters = other.mCharacters;
1654 return ev;
1655 }
1656
1657 /** @hide */
1658 @Override
1659 public KeyEvent copy() {
1660 return obtain(this);
1661 }
1662
1663 /**
Jeff Brown1f245102010-11-18 20:53:46 -08001664 * Recycles a key event.
1665 * Key events should only be recycled if they are owned by the system since user
1666 * code expects them to be essentially immutable, "tracking" notwithstanding.
1667 *
1668 * @hide
1669 */
Jeff Brown92cc2d82011-12-02 01:19:47 -08001670 @Override
Mathew Inwood8c854f82018-09-14 12:35:36 +01001671 @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023)
Jeff Brown1f245102010-11-18 20:53:46 -08001672 public final void recycle() {
Jeff Brown32cbc38552011-12-01 14:01:49 -08001673 super.recycle();
Jeff Brown1f245102010-11-18 20:53:46 -08001674 mCharacters = null;
1675
1676 synchronized (gRecyclerLock) {
1677 if (gRecyclerUsed < MAX_RECYCLED) {
1678 gRecyclerUsed++;
1679 mNext = gRecyclerTop;
1680 gRecyclerTop = this;
1681 }
1682 }
1683 }
1684
Jeff Brown92cc2d82011-12-02 01:19:47 -08001685 /** @hide */
1686 @Override
1687 public final void recycleIfNeededAfterDispatch() {
1688 // Do nothing.
1689 }
1690
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001691 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001692 * Create a new key event that is the same as the given one, but whose
1693 * event time and repeat count are replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001694 *
The Android Open Source Project10592532009-03-18 17:39:46 -07001695 * @param event The existing event to be copied. This is not modified.
1696 * @param eventTime The new event time
1697 * (in {@link android.os.SystemClock#uptimeMillis}) of the event.
1698 * @param newRepeat The new repeat count of the event.
1699 */
1700 public static KeyEvent changeTimeRepeat(KeyEvent event, long eventTime,
1701 int newRepeat) {
1702 return new KeyEvent(event, eventTime, newRepeat);
1703 }
RoboErik01fe6612014-02-13 14:19:04 -08001704
The Android Open Source Project10592532009-03-18 17:39:46 -07001705 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001706 * Create a new key event that is the same as the given one, but whose
1707 * event time and repeat count are replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001708 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001709 * @param event The existing event to be copied. This is not modified.
1710 * @param eventTime The new event time
1711 * (in {@link android.os.SystemClock#uptimeMillis}) of the event.
1712 * @param newRepeat The new repeat count of the event.
1713 * @param newFlags New flags for the event, replacing the entire value
1714 * in the original event.
1715 */
1716 public static KeyEvent changeTimeRepeat(KeyEvent event, long eventTime,
1717 int newRepeat, int newFlags) {
1718 KeyEvent ret = new KeyEvent(event);
1719 ret.mEventTime = eventTime;
1720 ret.mRepeatCount = newRepeat;
1721 ret.mFlags = newFlags;
1722 return ret;
1723 }
RoboErik01fe6612014-02-13 14:19:04 -08001724
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001725 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001726 * Copy an existing key event, modifying its action.
RoboErik01fe6612014-02-13 14:19:04 -08001727 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001728 * @param origEvent The existing event to be copied.
1729 * @param action The new action code of the event.
1730 */
The Android Open Source Project10592532009-03-18 17:39:46 -07001731 private KeyEvent(KeyEvent origEvent, int action) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001732 mDownTime = origEvent.mDownTime;
1733 mEventTime = origEvent.mEventTime;
1734 mAction = action;
1735 mKeyCode = origEvent.mKeyCode;
1736 mRepeatCount = origEvent.mRepeatCount;
1737 mMetaState = origEvent.mMetaState;
1738 mDeviceId = origEvent.mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001739 mSource = origEvent.mSource;
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001740 mDisplayId = origEvent.mDisplayId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001741 mScanCode = origEvent.mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001742 mFlags = origEvent.mFlags;
1743 // Don't copy mCharacters, since one way or the other we'll lose it
1744 // when changing the action.
1745 }
1746
1747 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001748 * Create a new key event that is the same as the given one, but whose
1749 * action is replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001750 *
The Android Open Source Project10592532009-03-18 17:39:46 -07001751 * @param event The existing event to be copied. This is not modified.
1752 * @param action The new action code of the event.
1753 */
1754 public static KeyEvent changeAction(KeyEvent event, int action) {
1755 return new KeyEvent(event, action);
1756 }
RoboErik01fe6612014-02-13 14:19:04 -08001757
The Android Open Source Project10592532009-03-18 17:39:46 -07001758 /**
1759 * Create a new key event that is the same as the given one, but whose
1760 * flags are replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001761 *
The Android Open Source Project10592532009-03-18 17:39:46 -07001762 * @param event The existing event to be copied. This is not modified.
1763 * @param flags The new flags constant.
1764 */
1765 public static KeyEvent changeFlags(KeyEvent event, int flags) {
1766 event = new KeyEvent(event);
1767 event.mFlags = flags;
1768 return event;
1769 }
Jeff Brown21bc5c92011-02-28 18:27:14 -08001770
1771 /** @hide */
1772 @Override
1773 public final boolean isTainted() {
1774 return (mFlags & FLAG_TAINTED) != 0;
1775 }
1776
1777 /** @hide */
1778 @Override
1779 public final void setTainted(boolean tainted) {
1780 mFlags = tainted ? mFlags | FLAG_TAINTED : mFlags & ~FLAG_TAINTED;
1781 }
1782
The Android Open Source Project10592532009-03-18 17:39:46 -07001783 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001784 * Don't use in new code, instead explicitly check
1785 * {@link #getAction()}.
RoboErik01fe6612014-02-13 14:19:04 -08001786 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001787 * @return If the action is ACTION_DOWN, returns true; else false.
1788 *
1789 * @deprecated
1790 * @hide
1791 */
Mathew Inwooda570dee2018-08-17 14:56:00 +01001792 @UnsupportedAppUsage
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001793 @Deprecated public final boolean isDown() {
1794 return mAction == ACTION_DOWN;
1795 }
1796
Michael Wright337d9d22014-04-22 15:03:48 -07001797 /** Is this a system key? System keys can not be used for menu shortcuts.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001798 */
1799 public final boolean isSystem() {
Michael Wright337d9d22014-04-22 15:03:48 -07001800 return isSystemKey(mKeyCode);
Dianne Hackborn3c80a4a2010-06-29 19:20:40 -07001801 }
1802
1803 /** @hide */
Michael Wright337d9d22014-04-22 15:03:48 -07001804 public final boolean isWakeKey() {
1805 return isWakeKey(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001806 }
1807
Jeff Brown6f2fba42011-02-19 01:08:02 -08001808 /**
1809 * Returns true if the specified keycode is a gamepad button.
1810 * @return True if the keycode is a gamepad button, such as {@link #KEYCODE_BUTTON_A}.
1811 */
1812 public static final boolean isGamepadButton(int keyCode) {
1813 switch (keyCode) {
1814 case KeyEvent.KEYCODE_BUTTON_A:
1815 case KeyEvent.KEYCODE_BUTTON_B:
1816 case KeyEvent.KEYCODE_BUTTON_C:
1817 case KeyEvent.KEYCODE_BUTTON_X:
1818 case KeyEvent.KEYCODE_BUTTON_Y:
1819 case KeyEvent.KEYCODE_BUTTON_Z:
1820 case KeyEvent.KEYCODE_BUTTON_L1:
1821 case KeyEvent.KEYCODE_BUTTON_R1:
1822 case KeyEvent.KEYCODE_BUTTON_L2:
1823 case KeyEvent.KEYCODE_BUTTON_R2:
1824 case KeyEvent.KEYCODE_BUTTON_THUMBL:
1825 case KeyEvent.KEYCODE_BUTTON_THUMBR:
1826 case KeyEvent.KEYCODE_BUTTON_START:
1827 case KeyEvent.KEYCODE_BUTTON_SELECT:
1828 case KeyEvent.KEYCODE_BUTTON_MODE:
1829 case KeyEvent.KEYCODE_BUTTON_1:
1830 case KeyEvent.KEYCODE_BUTTON_2:
1831 case KeyEvent.KEYCODE_BUTTON_3:
1832 case KeyEvent.KEYCODE_BUTTON_4:
1833 case KeyEvent.KEYCODE_BUTTON_5:
1834 case KeyEvent.KEYCODE_BUTTON_6:
1835 case KeyEvent.KEYCODE_BUTTON_7:
1836 case KeyEvent.KEYCODE_BUTTON_8:
1837 case KeyEvent.KEYCODE_BUTTON_9:
1838 case KeyEvent.KEYCODE_BUTTON_10:
1839 case KeyEvent.KEYCODE_BUTTON_11:
1840 case KeyEvent.KEYCODE_BUTTON_12:
1841 case KeyEvent.KEYCODE_BUTTON_13:
1842 case KeyEvent.KEYCODE_BUTTON_14:
1843 case KeyEvent.KEYCODE_BUTTON_15:
1844 case KeyEvent.KEYCODE_BUTTON_16:
1845 return true;
1846 default:
1847 return false;
1848 }
1849 }
1850
Michael Wright25b0c302013-07-10 12:54:06 -07001851 /** Whether key will, by default, trigger a click on the focused view.
1852 * @hide
1853 */
Mathew Inwooda570dee2018-08-17 14:56:00 +01001854 @UnsupportedAppUsage
Michael Wright25b0c302013-07-10 12:54:06 -07001855 public static final boolean isConfirmKey(int keyCode) {
1856 switch (keyCode) {
1857 case KeyEvent.KEYCODE_DPAD_CENTER:
1858 case KeyEvent.KEYCODE_ENTER:
Michael Wrightaa1a94d2015-11-26 16:04:54 +00001859 case KeyEvent.KEYCODE_SPACE:
Selim Cinekce2bd0f2016-02-19 16:16:54 -08001860 case KeyEvent.KEYCODE_NUMPAD_ENTER:
Michael Wright25b0c302013-07-10 12:54:06 -07001861 return true;
1862 default:
1863 return false;
1864 }
1865 }
1866
Hyundo Moonc3ce09e2019-03-11 20:00:00 +09001867 /**
1868 * Returns whether this key will be sent to the
1869 * {@link android.media.session.MediaSession.Callback} if not handled.
1870 *
1871 * @hide
1872 */
1873 public static final boolean isMediaSessionKey(int keyCode) {
1874 switch (keyCode) {
1875 case KeyEvent.KEYCODE_MEDIA_PLAY:
1876 case KeyEvent.KEYCODE_MEDIA_PAUSE:
1877 case KeyEvent.KEYCODE_MEDIA_PLAY_PAUSE:
1878 case KeyEvent.KEYCODE_MUTE:
1879 case KeyEvent.KEYCODE_HEADSETHOOK:
1880 case KeyEvent.KEYCODE_MEDIA_STOP:
1881 case KeyEvent.KEYCODE_MEDIA_NEXT:
1882 case KeyEvent.KEYCODE_MEDIA_PREVIOUS:
1883 case KeyEvent.KEYCODE_MEDIA_REWIND:
1884 case KeyEvent.KEYCODE_MEDIA_RECORD:
1885 case KeyEvent.KEYCODE_MEDIA_FAST_FORWARD:
1886 return true;
1887 }
1888 return false;
1889 }
1890
Michael Wright337d9d22014-04-22 15:03:48 -07001891 /** Is this a system key? System keys can not be used for menu shortcuts.
1892 * @hide
1893 */
1894 public static final boolean isSystemKey(int keyCode) {
1895 switch (keyCode) {
1896 case KeyEvent.KEYCODE_MENU:
1897 case KeyEvent.KEYCODE_SOFT_RIGHT:
1898 case KeyEvent.KEYCODE_HOME:
1899 case KeyEvent.KEYCODE_BACK:
1900 case KeyEvent.KEYCODE_CALL:
1901 case KeyEvent.KEYCODE_ENDCALL:
1902 case KeyEvent.KEYCODE_VOLUME_UP:
1903 case KeyEvent.KEYCODE_VOLUME_DOWN:
1904 case KeyEvent.KEYCODE_VOLUME_MUTE:
1905 case KeyEvent.KEYCODE_MUTE:
1906 case KeyEvent.KEYCODE_POWER:
1907 case KeyEvent.KEYCODE_HEADSETHOOK:
1908 case KeyEvent.KEYCODE_MEDIA_PLAY:
1909 case KeyEvent.KEYCODE_MEDIA_PAUSE:
1910 case KeyEvent.KEYCODE_MEDIA_PLAY_PAUSE:
1911 case KeyEvent.KEYCODE_MEDIA_STOP:
1912 case KeyEvent.KEYCODE_MEDIA_NEXT:
1913 case KeyEvent.KEYCODE_MEDIA_PREVIOUS:
1914 case KeyEvent.KEYCODE_MEDIA_REWIND:
1915 case KeyEvent.KEYCODE_MEDIA_RECORD:
1916 case KeyEvent.KEYCODE_MEDIA_FAST_FORWARD:
1917 case KeyEvent.KEYCODE_CAMERA:
1918 case KeyEvent.KEYCODE_FOCUS:
1919 case KeyEvent.KEYCODE_SEARCH:
1920 case KeyEvent.KEYCODE_BRIGHTNESS_DOWN:
1921 case KeyEvent.KEYCODE_BRIGHTNESS_UP:
1922 case KeyEvent.KEYCODE_MEDIA_AUDIO_TRACK:
Jim Miller07e03842016-06-22 15:18:13 -07001923 case KeyEvent.KEYCODE_SYSTEM_NAVIGATION_UP:
1924 case KeyEvent.KEYCODE_SYSTEM_NAVIGATION_DOWN:
1925 case KeyEvent.KEYCODE_SYSTEM_NAVIGATION_LEFT:
1926 case KeyEvent.KEYCODE_SYSTEM_NAVIGATION_RIGHT:
Michael Wright337d9d22014-04-22 15:03:48 -07001927 return true;
1928 }
1929
1930 return false;
1931 }
1932
1933 /** @hide */
1934 public static final boolean isWakeKey(int keyCode) {
1935 switch (keyCode) {
1936 case KeyEvent.KEYCODE_BACK:
Felix2deb9b52019-06-25 06:34:39 +02001937 case KeyEvent.KEYCODE_CAMERA:
Michael Wright337d9d22014-04-22 15:03:48 -07001938 case KeyEvent.KEYCODE_MENU:
Michael Wright8ac485a2014-06-04 12:38:18 -07001939 case KeyEvent.KEYCODE_PAIRING:
Chenjie Luobad498f2016-01-13 11:01:59 -08001940 case KeyEvent.KEYCODE_STEM_1:
1941 case KeyEvent.KEYCODE_STEM_2:
1942 case KeyEvent.KEYCODE_STEM_3:
Felix2deb9b52019-06-25 06:34:39 +02001943 case KeyEvent.KEYCODE_WAKEUP:
Michael Wright337d9d22014-04-22 15:03:48 -07001944 return true;
1945 }
1946 return false;
1947 }
1948
Michael Wrightce0c13a2014-07-30 10:49:21 -07001949 /** @hide */
1950 public static final boolean isMetaKey(int keyCode) {
1951 return keyCode == KeyEvent.KEYCODE_META_LEFT || keyCode == KeyEvent.KEYCODE_META_RIGHT;
1952 }
1953
Andrii Kulian112d0562016-03-08 10:44:22 -08001954 /** @hide */
1955 public static final boolean isAltKey(int keyCode) {
1956 return keyCode == KeyEvent.KEYCODE_ALT_LEFT || keyCode == KeyEvent.KEYCODE_ALT_RIGHT;
1957 }
1958
Jeff Brown91c69ab2011-02-14 17:03:18 -08001959 /** {@inheritDoc} */
1960 @Override
1961 public final int getDeviceId() {
1962 return mDeviceId;
1963 }
1964
1965 /** {@inheritDoc} */
1966 @Override
1967 public final int getSource() {
1968 return mSource;
1969 }
1970
1971 /** {@inheritDoc} */
1972 @Override
1973 public final void setSource(int source) {
1974 mSource = source;
1975 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001976
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001977 /** @hide */
1978 @Override
1979 public final int getDisplayId() {
1980 return mDisplayId;
1981 }
1982
1983 /** @hide */
Tiger Huangfc218452018-09-27 00:38:50 +08001984 @TestApi
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01001985 @Override
1986 public final void setDisplayId(int displayId) {
1987 mDisplayId = displayId;
1988 }
1989
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001990 /**
1991 * <p>Returns the state of the meta keys.</p>
1992 *
1993 * @return an integer in which each bit set to 1 represents a pressed
1994 * meta key
1995 *
1996 * @see #isAltPressed()
1997 * @see #isShiftPressed()
1998 * @see #isSymPressed()
Jeff Brown497a92c2010-09-12 17:55:08 -07001999 * @see #isCtrlPressed()
2000 * @see #isMetaPressed()
2001 * @see #isFunctionPressed()
Jeff Brown51e7fe72010-10-29 22:19:53 -07002002 * @see #isCapsLockOn()
2003 * @see #isNumLockOn()
2004 * @see #isScrollLockOn()
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002005 * @see #META_ALT_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002006 * @see #META_ALT_LEFT_ON
2007 * @see #META_ALT_RIGHT_ON
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002008 * @see #META_SHIFT_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002009 * @see #META_SHIFT_LEFT_ON
2010 * @see #META_SHIFT_RIGHT_ON
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002011 * @see #META_SYM_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002012 * @see #META_FUNCTION_ON
2013 * @see #META_CTRL_ON
2014 * @see #META_CTRL_LEFT_ON
2015 * @see #META_CTRL_RIGHT_ON
2016 * @see #META_META_ON
2017 * @see #META_META_LEFT_ON
2018 * @see #META_META_RIGHT_ON
Jeff Brown51e7fe72010-10-29 22:19:53 -07002019 * @see #META_CAPS_LOCK_ON
2020 * @see #META_NUM_LOCK_ON
2021 * @see #META_SCROLL_LOCK_ON
Jeff Brown54875002011-04-06 15:33:01 -07002022 * @see #getModifiers
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002023 */
2024 public final int getMetaState() {
2025 return mMetaState;
2026 }
2027
2028 /**
Jeff Brown54875002011-04-06 15:33:01 -07002029 * Returns the state of the modifier keys.
2030 * <p>
2031 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2032 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2033 * not considered modifier keys. Consequently, this function specifically masks out
2034 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2035 * </p><p>
2036 * The value returned consists of the meta state (from {@link #getMetaState})
2037 * normalized using {@link #normalizeMetaState(int)} and then masked with
2038 * {@link #getModifierMetaStateMask} so that only valid modifier bits are retained.
2039 * </p>
2040 *
2041 * @return An integer in which each bit set to 1 represents a pressed modifier key.
2042 * @see #getMetaState
2043 */
2044 public final int getModifiers() {
2045 return normalizeMetaState(mMetaState) & META_MODIFIER_MASK;
2046 }
2047
2048 /**
Tiger Huangfc218452018-09-27 00:38:50 +08002049 * Modifies the flags of the event.
2050 *
2051 * @param newFlags New flags for the event, replacing the entire value.
2052 * @hide
2053 */
2054 public final void setFlags(int newFlags) {
2055 mFlags = newFlags;
2056 }
2057
2058 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002059 * Returns the flags for this key event.
2060 *
2061 * @see #FLAG_WOKE_HERE
2062 */
2063 public final int getFlags() {
2064 return mFlags;
2065 }
2066
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002067 // Mask of all modifier key meta states. Specifically excludes locked keys like caps lock.
Mathew Inwooda570dee2018-08-17 14:56:00 +01002068 @UnsupportedAppUsage
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002069 private static final int META_MODIFIER_MASK =
2070 META_SHIFT_ON | META_SHIFT_LEFT_ON | META_SHIFT_RIGHT_ON
2071 | META_ALT_ON | META_ALT_LEFT_ON | META_ALT_RIGHT_ON
2072 | META_CTRL_ON | META_CTRL_LEFT_ON | META_CTRL_RIGHT_ON
2073 | META_META_ON | META_META_LEFT_ON | META_META_RIGHT_ON
2074 | META_SYM_ON | META_FUNCTION_ON;
2075
2076 // Mask of all lock key meta states.
Mathew Inwooda570dee2018-08-17 14:56:00 +01002077 @UnsupportedAppUsage
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002078 private static final int META_LOCK_MASK =
2079 META_CAPS_LOCK_ON | META_NUM_LOCK_ON | META_SCROLL_LOCK_ON;
2080
2081 // Mask of all valid meta states.
Mathew Inwooda570dee2018-08-17 14:56:00 +01002082 @UnsupportedAppUsage
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002083 private static final int META_ALL_MASK = META_MODIFIER_MASK | META_LOCK_MASK;
2084
2085 // Mask of all synthetic meta states that are reserved for API compatibility with
2086 // historical uses in MetaKeyKeyListener.
Mathew Inwooda570dee2018-08-17 14:56:00 +01002087 @UnsupportedAppUsage
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002088 private static final int META_SYNTHETIC_MASK =
2089 META_CAP_LOCKED | META_ALT_LOCKED | META_SYM_LOCKED | META_SELECTING;
2090
2091 // Mask of all meta states that are not valid use in specifying a modifier key.
2092 // These bits are known to be used for purposes other than specifying modifiers.
Mathew Inwooda570dee2018-08-17 14:56:00 +01002093 @UnsupportedAppUsage
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002094 private static final int META_INVALID_MODIFIER_MASK =
2095 META_LOCK_MASK | META_SYNTHETIC_MASK;
2096
2097 /**
2098 * Gets a mask that includes all valid modifier key meta state bits.
2099 * <p>
2100 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2101 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2102 * not considered modifier keys. Consequently, the mask specifically excludes
2103 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2104 * </p>
2105 *
2106 * @return The modifier meta state mask which is a combination of
2107 * {@link #META_SHIFT_ON}, {@link #META_SHIFT_LEFT_ON}, {@link #META_SHIFT_RIGHT_ON},
2108 * {@link #META_ALT_ON}, {@link #META_ALT_LEFT_ON}, {@link #META_ALT_RIGHT_ON},
2109 * {@link #META_CTRL_ON}, {@link #META_CTRL_LEFT_ON}, {@link #META_CTRL_RIGHT_ON},
2110 * {@link #META_META_ON}, {@link #META_META_LEFT_ON}, {@link #META_META_RIGHT_ON},
2111 * {@link #META_SYM_ON}, {@link #META_FUNCTION_ON}.
2112 */
2113 public static int getModifierMetaStateMask() {
2114 return META_MODIFIER_MASK;
2115 }
2116
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002117 /**
2118 * Returns true if this key code is a modifier key.
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002119 * <p>
2120 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2121 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2122 * not considered modifier keys. Consequently, this function return false
2123 * for those keys.
2124 * </p>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002125 *
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002126 * @return True if the key code is one of
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002127 * {@link #KEYCODE_SHIFT_LEFT} {@link #KEYCODE_SHIFT_RIGHT},
Jeff Brown497a92c2010-09-12 17:55:08 -07002128 * {@link #KEYCODE_ALT_LEFT}, {@link #KEYCODE_ALT_RIGHT},
Jeff Brown497a92c2010-09-12 17:55:08 -07002129 * {@link #KEYCODE_CTRL_LEFT}, {@link #KEYCODE_CTRL_RIGHT},
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002130 * {@link #KEYCODE_META_LEFT}, or {@link #KEYCODE_META_RIGHT},
2131 * {@link #KEYCODE_SYM}, {@link #KEYCODE_NUM}, {@link #KEYCODE_FUNCTION}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002132 */
2133 public static boolean isModifierKey(int keyCode) {
Jeff Brown497a92c2010-09-12 17:55:08 -07002134 switch (keyCode) {
2135 case KEYCODE_SHIFT_LEFT:
2136 case KEYCODE_SHIFT_RIGHT:
2137 case KEYCODE_ALT_LEFT:
2138 case KEYCODE_ALT_RIGHT:
Jeff Brown497a92c2010-09-12 17:55:08 -07002139 case KEYCODE_CTRL_LEFT:
2140 case KEYCODE_CTRL_RIGHT:
2141 case KEYCODE_META_LEFT:
2142 case KEYCODE_META_RIGHT:
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002143 case KEYCODE_SYM:
2144 case KEYCODE_NUM:
2145 case KEYCODE_FUNCTION:
Jeff Brown497a92c2010-09-12 17:55:08 -07002146 return true;
2147 default:
2148 return false;
2149 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002150 }
2151
2152 /**
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002153 * Normalizes the specified meta state.
2154 * <p>
2155 * The meta state is normalized such that if either the left or right modifier meta state
2156 * bits are set then the result will also include the universal bit for that modifier.
2157 * </p><p>
2158 * If the specified meta state contains {@link #META_ALT_LEFT_ON} then
2159 * the result will also contain {@link #META_ALT_ON} in addition to {@link #META_ALT_LEFT_ON}
2160 * and the other bits that were specified in the input. The same is process is
2161 * performed for shift, control and meta.
2162 * </p><p>
2163 * If the specified meta state contains synthetic meta states defined by
2164 * {@link MetaKeyKeyListener}, then those states are translated here and the original
2165 * synthetic meta states are removed from the result.
2166 * {@link MetaKeyKeyListener#META_CAP_LOCKED} is translated to {@link #META_CAPS_LOCK_ON}.
2167 * {@link MetaKeyKeyListener#META_ALT_LOCKED} is translated to {@link #META_ALT_ON}.
2168 * {@link MetaKeyKeyListener#META_SYM_LOCKED} is translated to {@link #META_SYM_ON}.
2169 * </p><p>
2170 * Undefined meta state bits are removed.
2171 * </p>
2172 *
2173 * @param metaState The meta state.
2174 * @return The normalized meta state.
2175 */
2176 public static int normalizeMetaState(int metaState) {
2177 if ((metaState & (META_SHIFT_LEFT_ON | META_SHIFT_RIGHT_ON)) != 0) {
2178 metaState |= META_SHIFT_ON;
2179 }
2180 if ((metaState & (META_ALT_LEFT_ON | META_ALT_RIGHT_ON)) != 0) {
2181 metaState |= META_ALT_ON;
2182 }
2183 if ((metaState & (META_CTRL_LEFT_ON | META_CTRL_RIGHT_ON)) != 0) {
2184 metaState |= META_CTRL_ON;
2185 }
2186 if ((metaState & (META_META_LEFT_ON | META_META_RIGHT_ON)) != 0) {
2187 metaState |= META_META_ON;
2188 }
2189 if ((metaState & MetaKeyKeyListener.META_CAP_LOCKED) != 0) {
2190 metaState |= META_CAPS_LOCK_ON;
2191 }
2192 if ((metaState & MetaKeyKeyListener.META_ALT_LOCKED) != 0) {
2193 metaState |= META_ALT_ON;
2194 }
2195 if ((metaState & MetaKeyKeyListener.META_SYM_LOCKED) != 0) {
2196 metaState |= META_SYM_ON;
2197 }
2198 return metaState & META_ALL_MASK;
2199 }
2200
2201 /**
2202 * Returns true if no modifiers keys are pressed according to the specified meta state.
2203 * <p>
2204 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2205 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2206 * not considered modifier keys. Consequently, this function ignores
2207 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2208 * </p><p>
2209 * The meta state is normalized prior to comparison using {@link #normalizeMetaState(int)}.
2210 * </p>
2211 *
2212 * @param metaState The meta state to consider.
2213 * @return True if no modifier keys are pressed.
2214 * @see #hasNoModifiers()
2215 */
2216 public static boolean metaStateHasNoModifiers(int metaState) {
2217 return (normalizeMetaState(metaState) & META_MODIFIER_MASK) == 0;
2218 }
2219
2220 /**
2221 * Returns true if only the specified modifier keys are pressed according to
2222 * the specified meta state. Returns false if a different combination of modifier
2223 * keys are pressed.
2224 * <p>
2225 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2226 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2227 * not considered modifier keys. Consequently, this function ignores
2228 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2229 * </p><p>
2230 * If the specified modifier mask includes directional modifiers, such as
2231 * {@link #META_SHIFT_LEFT_ON}, then this method ensures that the
2232 * modifier is pressed on that side.
2233 * If the specified modifier mask includes non-directional modifiers, such as
2234 * {@link #META_SHIFT_ON}, then this method ensures that the modifier
2235 * is pressed on either side.
2236 * If the specified modifier mask includes both directional and non-directional modifiers
2237 * for the same type of key, such as {@link #META_SHIFT_ON} and {@link #META_SHIFT_LEFT_ON},
2238 * then this method throws an illegal argument exception.
2239 * </p>
2240 *
2241 * @param metaState The meta state to consider.
2242 * @param modifiers The meta state of the modifier keys to check. May be a combination
2243 * of modifier meta states as defined by {@link #getModifierMetaStateMask()}. May be 0 to
2244 * ensure that no modifier keys are pressed.
2245 * @return True if only the specified modifier keys are pressed.
2246 * @throws IllegalArgumentException if the modifiers parameter contains invalid modifiers
2247 * @see #hasModifiers
2248 */
2249 public static boolean metaStateHasModifiers(int metaState, int modifiers) {
2250 // Note: For forward compatibility, we allow the parameter to contain meta states
2251 // that we do not recognize but we explicitly disallow meta states that
2252 // are not valid modifiers.
2253 if ((modifiers & META_INVALID_MODIFIER_MASK) != 0) {
2254 throw new IllegalArgumentException("modifiers must not contain "
2255 + "META_CAPS_LOCK_ON, META_NUM_LOCK_ON, META_SCROLL_LOCK_ON, "
2256 + "META_CAP_LOCKED, META_ALT_LOCKED, META_SYM_LOCKED, "
2257 + "or META_SELECTING");
2258 }
2259
2260 metaState = normalizeMetaState(metaState) & META_MODIFIER_MASK;
2261 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2262 META_SHIFT_ON, META_SHIFT_LEFT_ON, META_SHIFT_RIGHT_ON);
2263 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2264 META_ALT_ON, META_ALT_LEFT_ON, META_ALT_RIGHT_ON);
2265 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2266 META_CTRL_ON, META_CTRL_LEFT_ON, META_CTRL_RIGHT_ON);
2267 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2268 META_META_ON, META_META_LEFT_ON, META_META_RIGHT_ON);
2269 return metaState == modifiers;
2270 }
2271
2272 private static int metaStateFilterDirectionalModifiers(int metaState,
2273 int modifiers, int basic, int left, int right) {
2274 final boolean wantBasic = (modifiers & basic) != 0;
2275 final int directional = left | right;
2276 final boolean wantLeftOrRight = (modifiers & directional) != 0;
2277
2278 if (wantBasic) {
2279 if (wantLeftOrRight) {
2280 throw new IllegalArgumentException("modifiers must not contain "
2281 + metaStateToString(basic) + " combined with "
2282 + metaStateToString(left) + " or " + metaStateToString(right));
2283 }
2284 return metaState & ~directional;
2285 } else if (wantLeftOrRight) {
2286 return metaState & ~basic;
2287 } else {
2288 return metaState;
2289 }
2290 }
2291
2292 /**
2293 * Returns true if no modifier keys are pressed.
2294 * <p>
2295 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2296 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2297 * not considered modifier keys. Consequently, this function ignores
2298 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2299 * </p><p>
2300 * The meta state is normalized prior to comparison using {@link #normalizeMetaState(int)}.
2301 * </p>
2302 *
2303 * @return True if no modifier keys are pressed.
2304 * @see #metaStateHasNoModifiers
2305 */
2306 public final boolean hasNoModifiers() {
2307 return metaStateHasNoModifiers(mMetaState);
2308 }
2309
2310 /**
2311 * Returns true if only the specified modifiers keys are pressed.
2312 * Returns false if a different combination of modifier keys are pressed.
2313 * <p>
2314 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2315 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2316 * not considered modifier keys. Consequently, this function ignores
2317 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2318 * </p><p>
2319 * If the specified modifier mask includes directional modifiers, such as
2320 * {@link #META_SHIFT_LEFT_ON}, then this method ensures that the
2321 * modifier is pressed on that side.
2322 * If the specified modifier mask includes non-directional modifiers, such as
2323 * {@link #META_SHIFT_ON}, then this method ensures that the modifier
2324 * is pressed on either side.
2325 * If the specified modifier mask includes both directional and non-directional modifiers
2326 * for the same type of key, such as {@link #META_SHIFT_ON} and {@link #META_SHIFT_LEFT_ON},
2327 * then this method throws an illegal argument exception.
2328 * </p>
2329 *
2330 * @param modifiers The meta state of the modifier keys to check. May be a combination
2331 * of modifier meta states as defined by {@link #getModifierMetaStateMask()}. May be 0 to
2332 * ensure that no modifier keys are pressed.
2333 * @return True if only the specified modifier keys are pressed.
2334 * @throws IllegalArgumentException if the modifiers parameter contains invalid modifiers
2335 * @see #metaStateHasModifiers
2336 */
2337 public final boolean hasModifiers(int modifiers) {
2338 return metaStateHasModifiers(mMetaState, modifiers);
2339 }
2340
2341 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002342 * <p>Returns the pressed state of the ALT meta key.</p>
2343 *
2344 * @return true if the ALT key is pressed, false otherwise
2345 *
2346 * @see #KEYCODE_ALT_LEFT
2347 * @see #KEYCODE_ALT_RIGHT
2348 * @see #META_ALT_ON
2349 */
2350 public final boolean isAltPressed() {
2351 return (mMetaState & META_ALT_ON) != 0;
2352 }
2353
2354 /**
2355 * <p>Returns the pressed state of the SHIFT meta key.</p>
2356 *
2357 * @return true if the SHIFT key is pressed, false otherwise
2358 *
2359 * @see #KEYCODE_SHIFT_LEFT
2360 * @see #KEYCODE_SHIFT_RIGHT
2361 * @see #META_SHIFT_ON
2362 */
2363 public final boolean isShiftPressed() {
2364 return (mMetaState & META_SHIFT_ON) != 0;
2365 }
2366
2367 /**
2368 * <p>Returns the pressed state of the SYM meta key.</p>
2369 *
2370 * @return true if the SYM key is pressed, false otherwise
2371 *
2372 * @see #KEYCODE_SYM
2373 * @see #META_SYM_ON
2374 */
2375 public final boolean isSymPressed() {
2376 return (mMetaState & META_SYM_ON) != 0;
2377 }
2378
2379 /**
Jeff Brown497a92c2010-09-12 17:55:08 -07002380 * <p>Returns the pressed state of the CTRL meta key.</p>
2381 *
2382 * @return true if the CTRL key is pressed, false otherwise
2383 *
2384 * @see #KEYCODE_CTRL_LEFT
2385 * @see #KEYCODE_CTRL_RIGHT
2386 * @see #META_CTRL_ON
2387 */
2388 public final boolean isCtrlPressed() {
2389 return (mMetaState & META_CTRL_ON) != 0;
2390 }
2391
2392 /**
2393 * <p>Returns the pressed state of the META meta key.</p>
2394 *
2395 * @return true if the META key is pressed, false otherwise
2396 *
2397 * @see #KEYCODE_META_LEFT
2398 * @see #KEYCODE_META_RIGHT
2399 * @see #META_META_ON
2400 */
2401 public final boolean isMetaPressed() {
2402 return (mMetaState & META_META_ON) != 0;
2403 }
2404
2405 /**
2406 * <p>Returns the pressed state of the FUNCTION meta key.</p>
2407 *
2408 * @return true if the FUNCTION key is pressed, false otherwise
2409 *
2410 * @see #KEYCODE_FUNCTION
2411 * @see #META_FUNCTION_ON
2412 */
2413 public final boolean isFunctionPressed() {
2414 return (mMetaState & META_FUNCTION_ON) != 0;
2415 }
2416
2417 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07002418 * <p>Returns the locked state of the CAPS LOCK meta key.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07002419 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07002420 * @return true if the CAPS LOCK key is on, false otherwise
Jeff Brown497a92c2010-09-12 17:55:08 -07002421 *
2422 * @see #KEYCODE_CAPS_LOCK
Jeff Brown51e7fe72010-10-29 22:19:53 -07002423 * @see #META_CAPS_LOCK_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002424 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07002425 public final boolean isCapsLockOn() {
2426 return (mMetaState & META_CAPS_LOCK_ON) != 0;
Jeff Brown497a92c2010-09-12 17:55:08 -07002427 }
2428
2429 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07002430 * <p>Returns the locked state of the NUM LOCK meta key.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07002431 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07002432 * @return true if the NUM LOCK key is on, false otherwise
Jeff Brown497a92c2010-09-12 17:55:08 -07002433 *
2434 * @see #KEYCODE_NUM_LOCK
Jeff Brown51e7fe72010-10-29 22:19:53 -07002435 * @see #META_NUM_LOCK_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002436 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07002437 public final boolean isNumLockOn() {
2438 return (mMetaState & META_NUM_LOCK_ON) != 0;
Jeff Brown497a92c2010-09-12 17:55:08 -07002439 }
2440
2441 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07002442 * <p>Returns the locked state of the SCROLL LOCK meta key.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07002443 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07002444 * @return true if the SCROLL LOCK key is on, false otherwise
Jeff Brown497a92c2010-09-12 17:55:08 -07002445 *
2446 * @see #KEYCODE_SCROLL_LOCK
Jeff Brown51e7fe72010-10-29 22:19:53 -07002447 * @see #META_SCROLL_LOCK_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002448 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07002449 public final boolean isScrollLockOn() {
2450 return (mMetaState & META_SCROLL_LOCK_ON) != 0;
Jeff Brown497a92c2010-09-12 17:55:08 -07002451 }
2452
2453 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002454 * Retrieve the action of this key event. May be either
2455 * {@link #ACTION_DOWN}, {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
RoboErik01fe6612014-02-13 14:19:04 -08002456 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002457 * @return The event action: ACTION_DOWN, ACTION_UP, or ACTION_MULTIPLE.
2458 */
2459 public final int getAction() {
2460 return mAction;
2461 }
2462
2463 /**
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07002464 * For {@link #ACTION_UP} events, indicates that the event has been
2465 * canceled as per {@link #FLAG_CANCELED}.
2466 */
2467 public final boolean isCanceled() {
2468 return (mFlags&FLAG_CANCELED) != 0;
2469 }
RoboErik01fe6612014-02-13 14:19:04 -08002470
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07002471 /**
Wale Ogunwalec3672cd2014-11-05 15:17:35 -08002472 * Set {@link #FLAG_CANCELED} flag for the key event.
2473 *
2474 * @hide
2475 */
2476 @Override
2477 public final void cancel() {
2478 mFlags |= FLAG_CANCELED;
2479 }
2480
2481 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002482 * Call this during {@link Callback#onKeyDown} to have the system track
2483 * the key through its final up (possibly including a long press). Note
2484 * that only one key can be tracked at a time -- if another key down
2485 * event is received while a previous one is being tracked, tracking is
2486 * stopped on the previous event.
2487 */
2488 public final void startTracking() {
2489 mFlags |= FLAG_START_TRACKING;
2490 }
RoboErik01fe6612014-02-13 14:19:04 -08002491
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002492 /**
2493 * For {@link #ACTION_UP} events, indicates that the event is still being
2494 * tracked from its initial down event as per
2495 * {@link #FLAG_TRACKING}.
2496 */
2497 public final boolean isTracking() {
2498 return (mFlags&FLAG_TRACKING) != 0;
2499 }
RoboErik01fe6612014-02-13 14:19:04 -08002500
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002501 /**
2502 * For {@link #ACTION_DOWN} events, indicates that the event has been
2503 * canceled as per {@link #FLAG_LONG_PRESS}.
2504 */
2505 public final boolean isLongPress() {
2506 return (mFlags&FLAG_LONG_PRESS) != 0;
2507 }
RoboErik01fe6612014-02-13 14:19:04 -08002508
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002509 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002510 * Retrieve the key code of the key event. This is the physical key that
2511 * was pressed, <em>not</em> the Unicode character.
RoboErik01fe6612014-02-13 14:19:04 -08002512 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002513 * @return The key code of the event.
2514 */
2515 public final int getKeyCode() {
2516 return mKeyCode;
2517 }
2518
2519 /**
2520 * For the special case of a {@link #ACTION_MULTIPLE} event with key
2521 * code of {@link #KEYCODE_UNKNOWN}, this is a raw string of characters
2522 * associated with the event. In all other cases it is null.
RoboErik01fe6612014-02-13 14:19:04 -08002523 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002524 * @return Returns a String of 1 or more characters associated with
2525 * the event.
Siarhei Vishniakoue481d332018-07-18 14:46:00 +01002526 *
2527 * @deprecated no longer used by the input system.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002528 */
Siarhei Vishniakoue481d332018-07-18 14:46:00 +01002529 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002530 public final String getCharacters() {
2531 return mCharacters;
2532 }
RoboErik01fe6612014-02-13 14:19:04 -08002533
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002534 /**
2535 * Retrieve the hardware key id of this key event. These values are not
2536 * reliable and vary from device to device.
2537 *
2538 * {@more}
2539 * Mostly this is here for debugging purposes.
2540 */
2541 public final int getScanCode() {
Jeff Brown46b9ac02010-04-22 18:58:52 -07002542 return mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002543 }
2544
2545 /**
Siarhei Vishniakou4fddffc2018-11-07 17:02:29 -08002546 * Retrieve the repeat count of the event. For key down events,
2547 * this is the number of times the key has repeated with the first
2548 * down starting at 0 and counting up from there. For key up events,
2549 * this is always equal to zero. For multiple key events,
2550 * this is the number of down/up pairs that have occurred.
RoboErik01fe6612014-02-13 14:19:04 -08002551 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002552 * @return The number of times the key has repeated.
2553 */
2554 public final int getRepeatCount() {
2555 return mRepeatCount;
2556 }
2557
2558 /**
Tiger Huangfc218452018-09-27 00:38:50 +08002559 * Modifies the down time and the event time of the event.
2560 *
2561 * @param downTime The new down time (in {@link android.os.SystemClock#uptimeMillis}) of the
2562 * event.
2563 * @param eventTime The new event time (in {@link android.os.SystemClock#uptimeMillis}) of the
2564 * event.
2565 * @hide
2566 */
2567 public final void setTime(long downTime, long eventTime) {
2568 mDownTime = downTime;
2569 mEventTime = eventTime;
2570 }
2571
2572 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002573 * Retrieve the time of the most recent key down event,
2574 * in the {@link android.os.SystemClock#uptimeMillis} time base. If this
2575 * is a down event, this will be the same as {@link #getEventTime()}.
2576 * Note that when chording keys, this value is the down time of the
2577 * most recently pressed key, which may <em>not</em> be the same physical
2578 * key of this event.
RoboErik01fe6612014-02-13 14:19:04 -08002579 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002580 * @return Returns the most recent key down time, in the
2581 * {@link android.os.SystemClock#uptimeMillis} time base
2582 */
2583 public final long getDownTime() {
2584 return mDownTime;
2585 }
2586
2587 /**
Jeff Brownb11499d2012-04-20 19:54:22 -07002588 * Retrieve the time this event occurred,
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002589 * in the {@link android.os.SystemClock#uptimeMillis} time base.
Jeff Brownb11499d2012-04-20 19:54:22 -07002590 *
RoboErik01fe6612014-02-13 14:19:04 -08002591 * @return Returns the time this event occurred,
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002592 * in the {@link android.os.SystemClock#uptimeMillis} time base.
2593 */
Jeff Brownb11499d2012-04-20 19:54:22 -07002594 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002595 public final long getEventTime() {
2596 return mEventTime;
2597 }
2598
Jeff Brownb11499d2012-04-20 19:54:22 -07002599 /**
2600 * Retrieve the time this event occurred,
2601 * in the {@link android.os.SystemClock#uptimeMillis} time base but with
2602 * nanosecond (instead of millisecond) precision.
2603 * <p>
2604 * The value is in nanosecond precision but it may not have nanosecond accuracy.
2605 * </p>
2606 *
2607 * @return Returns the time this event occurred,
2608 * in the {@link android.os.SystemClock#uptimeMillis} time base but with
2609 * nanosecond (instead of millisecond) precision.
2610 *
2611 * @hide
2612 */
Jeff Brown4e91a182011-04-07 11:38:09 -07002613 @Override
2614 public final long getEventTimeNano() {
2615 return mEventTime * 1000000L;
2616 }
2617
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002618 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002619 * Renamed to {@link #getDeviceId}.
RoboErik01fe6612014-02-13 14:19:04 -08002620 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002621 * @hide
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002622 * @deprecated use {@link #getDeviceId()} instead.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002623 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002624 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002625 public final int getKeyboardDevice() {
2626 return mDeviceId;
2627 }
2628
2629 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002630 * Gets the {@link KeyCharacterMap} associated with the keyboard device.
2631 *
2632 * @return The associated key character map.
Andrew Sapperstein8ab3dc72011-06-23 18:56:44 -07002633 * @throws {@link KeyCharacterMap.UnavailableException} if the key character map
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002634 * could not be loaded because it was malformed or the default key character map
2635 * is missing from the system.
2636 *
Andrew Sapperstein8ab3dc72011-06-23 18:56:44 -07002637 * @see KeyCharacterMap#load
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002638 */
2639 public final KeyCharacterMap getKeyCharacterMap() {
2640 return KeyCharacterMap.load(mDeviceId);
2641 }
2642
2643 /**
2644 * Gets the primary character for this key.
2645 * In other words, the label that is physically printed on it.
2646 *
2647 * @return The display label character, or 0 if none (eg. for non-printing keys).
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002648 */
2649 public char getDisplayLabel() {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002650 return getKeyCharacterMap().getDisplayLabel(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002651 }
RoboErik01fe6612014-02-13 14:19:04 -08002652
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002653 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002654 * Gets the Unicode character generated by the specified key and meta
2655 * key state combination.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002656 * <p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002657 * Returns the Unicode character that the specified key would produce
2658 * when the specified meta bits (see {@link MetaKeyKeyListener})
2659 * were active.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002660 * </p><p>
2661 * Returns 0 if the key is not one that is used to type Unicode
2662 * characters.
2663 * </p><p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002664 * If the return value has bit {@link KeyCharacterMap#COMBINING_ACCENT} set, the
2665 * key is a "dead key" that should be combined with another to
2666 * actually produce a character -- see {@link KeyCharacterMap#getDeadChar} --
2667 * after masking with {@link KeyCharacterMap#COMBINING_ACCENT_MASK}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002668 * </p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002669 *
2670 * @return The associated character or combining accent, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002671 */
2672 public int getUnicodeChar() {
2673 return getUnicodeChar(mMetaState);
2674 }
RoboErik01fe6612014-02-13 14:19:04 -08002675
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002676 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002677 * Gets the Unicode character generated by the specified key and meta
2678 * key state combination.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002679 * <p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002680 * Returns the Unicode character that the specified key would produce
2681 * when the specified meta bits (see {@link MetaKeyKeyListener})
2682 * were active.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002683 * </p><p>
2684 * Returns 0 if the key is not one that is used to type Unicode
2685 * characters.
2686 * </p><p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002687 * If the return value has bit {@link KeyCharacterMap#COMBINING_ACCENT} set, the
2688 * key is a "dead key" that should be combined with another to
2689 * actually produce a character -- see {@link KeyCharacterMap#getDeadChar} --
2690 * after masking with {@link KeyCharacterMap#COMBINING_ACCENT_MASK}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002691 * </p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002692 *
2693 * @param metaState The meta key modifier state.
2694 * @return The associated character or combining accent, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002695 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002696 public int getUnicodeChar(int metaState) {
2697 return getKeyCharacterMap().get(mKeyCode, metaState);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002698 }
RoboErik01fe6612014-02-13 14:19:04 -08002699
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002700 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002701 * Get the character conversion data for a given key code.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002702 *
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002703 * @param results A {@link KeyCharacterMap.KeyData} instance that will be
2704 * filled with the results.
2705 * @return True if the key was mapped. If the key was not mapped, results is not modified.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002706 *
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002707 * @deprecated instead use {@link #getDisplayLabel()},
2708 * {@link #getNumber()} or {@link #getUnicodeChar(int)}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002709 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002710 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002711 public boolean getKeyData(KeyData results) {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002712 return getKeyCharacterMap().getKeyData(mKeyCode, results);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002713 }
RoboErik01fe6612014-02-13 14:19:04 -08002714
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002715 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002716 * Gets the first character in the character array that can be generated
2717 * by the specified key code.
2718 * <p>
2719 * This is a convenience function that returns the same value as
2720 * {@link #getMatch(char[],int) getMatch(chars, 0)}.
2721 * </p>
2722 *
2723 * @param chars The array of matching characters to consider.
2724 * @return The matching associated character, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002725 */
2726 public char getMatch(char[] chars) {
2727 return getMatch(chars, 0);
2728 }
RoboErik01fe6612014-02-13 14:19:04 -08002729
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002730 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002731 * Gets the first character in the character array that can be generated
2732 * by the specified key code. If there are multiple choices, prefers
2733 * the one that would be generated with the specified meta key modifier state.
2734 *
2735 * @param chars The array of matching characters to consider.
2736 * @param metaState The preferred meta key modifier state.
2737 * @return The matching associated character, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002738 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002739 public char getMatch(char[] chars, int metaState) {
2740 return getKeyCharacterMap().getMatch(mKeyCode, chars, metaState);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002741 }
RoboErik01fe6612014-02-13 14:19:04 -08002742
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002743 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002744 * Gets the number or symbol associated with the key.
2745 * <p>
2746 * The character value is returned, not the numeric value.
2747 * If the key is not a number, but is a symbol, the symbol is retuned.
2748 * </p><p>
2749 * This method is intended to to support dial pads and other numeric or
2750 * symbolic entry on keyboards where certain keys serve dual function
2751 * as alphabetic and symbolic keys. This method returns the number
2752 * or symbol associated with the key independent of whether the user
2753 * has pressed the required modifier.
2754 * </p><p>
2755 * For example, on one particular keyboard the keys on the top QWERTY row generate
2756 * numbers when ALT is pressed such that ALT-Q maps to '1'. So for that keyboard
2757 * when {@link #getNumber} is called with {@link KeyEvent#KEYCODE_Q} it returns '1'
2758 * so that the user can type numbers without pressing ALT when it makes sense.
2759 * </p>
2760 *
2761 * @return The associated numeric or symbolic character, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002762 */
2763 public char getNumber() {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002764 return getKeyCharacterMap().getNumber(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002765 }
RoboErik01fe6612014-02-13 14:19:04 -08002766
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002767 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002768 * Returns true if this key produces a glyph.
2769 *
2770 * @return True if the key is a printing key.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002771 */
2772 public boolean isPrintingKey() {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002773 return getKeyCharacterMap().isPrintingKey(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002774 }
RoboErik01fe6612014-02-13 14:19:04 -08002775
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002776 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002777 * @deprecated Use {@link #dispatch(Callback, DispatcherState, Object)} instead.
2778 */
2779 @Deprecated
2780 public final boolean dispatch(Callback receiver) {
2781 return dispatch(receiver, null, null);
2782 }
RoboErik01fe6612014-02-13 14:19:04 -08002783
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002784 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002785 * Deliver this key event to a {@link Callback} interface. If this is
2786 * an ACTION_MULTIPLE event and it is not handled, then an attempt will
2787 * be made to deliver a single normal event.
RoboErik01fe6612014-02-13 14:19:04 -08002788 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002789 * @param receiver The Callback that will be given the event.
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002790 * @param state State information retained across events.
2791 * @param target The target of the dispatch, for use in tracking.
RoboErik01fe6612014-02-13 14:19:04 -08002792 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002793 * @return The return value from the Callback method that was called.
2794 */
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002795 public final boolean dispatch(Callback receiver, DispatcherState state,
2796 Object target) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002797 switch (mAction) {
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002798 case ACTION_DOWN: {
2799 mFlags &= ~FLAG_START_TRACKING;
Dianne Hackborn8d374262009-09-14 21:21:52 -07002800 if (DEBUG) Log.v(TAG, "Key down to " + target + " in " + state
2801 + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002802 boolean res = receiver.onKeyDown(mKeyCode, this);
2803 if (state != null) {
2804 if (res && mRepeatCount == 0 && (mFlags&FLAG_START_TRACKING) != 0) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002805 if (DEBUG) Log.v(TAG, " Start tracking!");
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002806 state.startTracking(this, target);
2807 } else if (isLongPress() && state.isTracking(this)) {
2808 try {
2809 if (receiver.onKeyLongPress(mKeyCode, this)) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002810 if (DEBUG) Log.v(TAG, " Clear from long press!");
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002811 state.performedLongPress(this);
2812 res = true;
2813 }
2814 } catch (AbstractMethodError e) {
2815 }
2816 }
2817 }
2818 return res;
2819 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002820 case ACTION_UP:
Dianne Hackborn8d374262009-09-14 21:21:52 -07002821 if (DEBUG) Log.v(TAG, "Key up to " + target + " in " + state
2822 + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002823 if (state != null) {
2824 state.handleUpEvent(this);
2825 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002826 return receiver.onKeyUp(mKeyCode, this);
2827 case ACTION_MULTIPLE:
2828 final int count = mRepeatCount;
2829 final int code = mKeyCode;
2830 if (receiver.onKeyMultiple(code, count, this)) {
2831 return true;
2832 }
2833 if (code != KeyEvent.KEYCODE_UNKNOWN) {
2834 mAction = ACTION_DOWN;
2835 mRepeatCount = 0;
2836 boolean handled = receiver.onKeyDown(code, this);
2837 if (handled) {
2838 mAction = ACTION_UP;
2839 receiver.onKeyUp(code, this);
2840 }
2841 mAction = ACTION_MULTIPLE;
2842 mRepeatCount = count;
2843 return handled;
2844 }
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002845 return false;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002846 }
2847 return false;
2848 }
2849
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002850 /**
2851 * Use with {@link KeyEvent#dispatch(Callback, DispatcherState, Object)}
2852 * for more advanced key dispatching, such as long presses.
2853 */
2854 public static class DispatcherState {
2855 int mDownKeyCode;
2856 Object mDownTarget;
2857 SparseIntArray mActiveLongPresses = new SparseIntArray();
RoboErik01fe6612014-02-13 14:19:04 -08002858
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002859 /**
2860 * Reset back to initial state.
2861 */
2862 public void reset() {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002863 if (DEBUG) Log.v(TAG, "Reset: " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002864 mDownKeyCode = 0;
2865 mDownTarget = null;
2866 mActiveLongPresses.clear();
2867 }
RoboErik01fe6612014-02-13 14:19:04 -08002868
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002869 /**
2870 * Stop any tracking associated with this target.
2871 */
2872 public void reset(Object target) {
2873 if (mDownTarget == target) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002874 if (DEBUG) Log.v(TAG, "Reset in " + target + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002875 mDownKeyCode = 0;
2876 mDownTarget = null;
2877 }
2878 }
RoboErik01fe6612014-02-13 14:19:04 -08002879
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002880 /**
2881 * Start tracking the key code associated with the given event. This
2882 * can only be called on a key down. It will allow you to see any
2883 * long press associated with the key, and will result in
2884 * {@link KeyEvent#isTracking} return true on the long press and up
2885 * events.
RoboErik01fe6612014-02-13 14:19:04 -08002886 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002887 * <p>This is only needed if you are directly dispatching events, rather
2888 * than handling them in {@link Callback#onKeyDown}.
2889 */
2890 public void startTracking(KeyEvent event, Object target) {
2891 if (event.getAction() != ACTION_DOWN) {
2892 throw new IllegalArgumentException(
2893 "Can only start tracking on a down event");
2894 }
Dianne Hackborn8d374262009-09-14 21:21:52 -07002895 if (DEBUG) Log.v(TAG, "Start trackingt in " + target + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002896 mDownKeyCode = event.getKeyCode();
2897 mDownTarget = target;
2898 }
RoboErik01fe6612014-02-13 14:19:04 -08002899
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002900 /**
2901 * Return true if the key event is for a key code that is currently
2902 * being tracked by the dispatcher.
2903 */
2904 public boolean isTracking(KeyEvent event) {
2905 return mDownKeyCode == event.getKeyCode();
2906 }
RoboErik01fe6612014-02-13 14:19:04 -08002907
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002908 /**
2909 * Keep track of the given event's key code as having performed an
2910 * action with a long press, so no action should occur on the up.
2911 * <p>This is only needed if you are directly dispatching events, rather
2912 * than handling them in {@link Callback#onKeyLongPress}.
2913 */
2914 public void performedLongPress(KeyEvent event) {
2915 mActiveLongPresses.put(event.getKeyCode(), 1);
2916 }
RoboErik01fe6612014-02-13 14:19:04 -08002917
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002918 /**
2919 * Handle key up event to stop tracking. This resets the dispatcher state,
2920 * and updates the key event state based on it.
2921 * <p>This is only needed if you are directly dispatching events, rather
2922 * than handling them in {@link Callback#onKeyUp}.
2923 */
2924 public void handleUpEvent(KeyEvent event) {
2925 final int keyCode = event.getKeyCode();
Dianne Hackborn8d374262009-09-14 21:21:52 -07002926 if (DEBUG) Log.v(TAG, "Handle key up " + event + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002927 int index = mActiveLongPresses.indexOfKey(keyCode);
2928 if (index >= 0) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002929 if (DEBUG) Log.v(TAG, " Index: " + index);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002930 event.mFlags |= FLAG_CANCELED | FLAG_CANCELED_LONG_PRESS;
2931 mActiveLongPresses.removeAt(index);
2932 }
2933 if (mDownKeyCode == keyCode) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002934 if (DEBUG) Log.v(TAG, " Tracking!");
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002935 event.mFlags |= FLAG_TRACKING;
2936 mDownKeyCode = 0;
2937 mDownTarget = null;
2938 }
2939 }
2940 }
Jeff Brown497a92c2010-09-12 17:55:08 -07002941
2942 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002943 public String toString() {
Jeff Brownfe9f8ab2011-05-06 18:20:01 -07002944 StringBuilder msg = new StringBuilder();
2945 msg.append("KeyEvent { action=").append(actionToString(mAction));
2946 msg.append(", keyCode=").append(keyCodeToString(mKeyCode));
2947 msg.append(", scanCode=").append(mScanCode);
2948 if (mCharacters != null) {
2949 msg.append(", characters=\"").append(mCharacters).append("\"");
2950 }
2951 msg.append(", metaState=").append(metaStateToString(mMetaState));
2952 msg.append(", flags=0x").append(Integer.toHexString(mFlags));
2953 msg.append(", repeatCount=").append(mRepeatCount);
2954 msg.append(", eventTime=").append(mEventTime);
2955 msg.append(", downTime=").append(mDownTime);
2956 msg.append(", deviceId=").append(mDeviceId);
2957 msg.append(", source=0x").append(Integer.toHexString(mSource));
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01002958 msg.append(", displayId=").append(mDisplayId);
Jeff Brownfe9f8ab2011-05-06 18:20:01 -07002959 msg.append(" }");
2960 return msg.toString();
Jeff Brown497a92c2010-09-12 17:55:08 -07002961 }
2962
2963 /**
2964 * Returns a string that represents the symbolic name of the specified action
Jeff Brown6f2fba42011-02-19 01:08:02 -08002965 * such as "ACTION_DOWN", or an equivalent numeric constant such as "35" if unknown.
Jeff Brown497a92c2010-09-12 17:55:08 -07002966 *
2967 * @param action The action.
2968 * @return The symbolic name of the specified action.
2969 * @hide
2970 */
Siarhei Vishniakou4c96a5e2018-04-24 17:57:44 -07002971 @TestApi
Jeff Brown497a92c2010-09-12 17:55:08 -07002972 public static String actionToString(int action) {
2973 switch (action) {
2974 case ACTION_DOWN:
2975 return "ACTION_DOWN";
2976 case ACTION_UP:
2977 return "ACTION_UP";
2978 case ACTION_MULTIPLE:
2979 return "ACTION_MULTIPLE";
2980 default:
2981 return Integer.toString(action);
2982 }
2983 }
2984
2985 /**
2986 * Returns a string that represents the symbolic name of the specified keycode
Jeff Brown6f2fba42011-02-19 01:08:02 -08002987 * such as "KEYCODE_A", "KEYCODE_DPAD_UP", or an equivalent numeric constant
2988 * such as "1001" if unknown.
Jeff Brown497a92c2010-09-12 17:55:08 -07002989 *
Siarhei Vishniakou6ace3f22018-07-17 17:10:00 +01002990 * This function is intended to be used mostly for debugging, logging, and testing. It is not
2991 * locale-specific and is not intended to be used in a user-facing manner.
2992 *
Jeff Brown497a92c2010-09-12 17:55:08 -07002993 * @param keyCode The key code.
2994 * @return The symbolic name of the specified keycode.
2995 *
2996 * @see KeyCharacterMap#getDisplayLabel
Jeff Brown497a92c2010-09-12 17:55:08 -07002997 */
2998 public static String keyCodeToString(int keyCode) {
Michael Wright337d9d22014-04-22 15:03:48 -07002999 String symbolicName = nativeKeyCodeToString(keyCode);
3000 return symbolicName != null ? LABEL_PREFIX + symbolicName : Integer.toString(keyCode);
Jeff Brown497a92c2010-09-12 17:55:08 -07003001 }
3002
3003 /**
Jeff Brown6f2fba42011-02-19 01:08:02 -08003004 * Gets a keycode by its symbolic name such as "KEYCODE_A" or an equivalent
Siarhei Vishniakoude1f9042018-05-09 09:54:43 -07003005 * numeric constant such as "29". For symbolic names,
3006 * starting in {@link android.os.Build.VERSION_CODES#Q} the prefix "KEYCODE_" is optional.
Jeff Brown497a92c2010-09-12 17:55:08 -07003007 *
3008 * @param symbolicName The symbolic name of the keycode.
Jeff Brown6f2fba42011-02-19 01:08:02 -08003009 * @return The keycode or {@link #KEYCODE_UNKNOWN} if not found.
Aurimas Liutikase701dc12018-06-01 16:04:37 -07003010 * @see #keyCodeToString(int)
Jeff Brown497a92c2010-09-12 17:55:08 -07003011 */
Siarhei Vishniakoude1f9042018-05-09 09:54:43 -07003012 public static int keyCodeFromString(@NonNull String symbolicName) {
3013 try {
3014 int keyCode = Integer.parseInt(symbolicName);
3015 if (keyCodeIsValid(keyCode)) {
Michael Wright973efa02014-05-13 15:38:56 -07003016 return keyCode;
3017 }
Jeff Brown497a92c2010-09-12 17:55:08 -07003018 } catch (NumberFormatException ex) {
Jeff Brown497a92c2010-09-12 17:55:08 -07003019 }
Siarhei Vishniakoude1f9042018-05-09 09:54:43 -07003020
3021 if (symbolicName.startsWith(LABEL_PREFIX)) {
3022 symbolicName = symbolicName.substring(LABEL_PREFIX.length());
3023 }
3024 int keyCode = nativeKeyCodeFromString(symbolicName);
3025 if (keyCodeIsValid(keyCode)) {
3026 return keyCode;
3027 }
3028 return KEYCODE_UNKNOWN;
3029 }
3030
3031 private static boolean keyCodeIsValid(int keyCode) {
3032 return keyCode >= KEYCODE_UNKNOWN && keyCode <= LAST_KEYCODE;
Jeff Brown497a92c2010-09-12 17:55:08 -07003033 }
3034
3035 /**
3036 * Returns a string that represents the symbolic name of the specified combined meta
3037 * key modifier state flags such as "0", "META_SHIFT_ON",
Jeff Brown6f2fba42011-02-19 01:08:02 -08003038 * "META_ALT_ON|META_SHIFT_ON" or an equivalent numeric constant such as "0x10000000"
3039 * if unknown.
Jeff Brown497a92c2010-09-12 17:55:08 -07003040 *
3041 * @param metaState The meta state.
3042 * @return The symbolic name of the specified combined meta state flags.
3043 * @hide
3044 */
3045 public static String metaStateToString(int metaState) {
3046 if (metaState == 0) {
3047 return "0";
3048 }
3049 StringBuilder result = null;
3050 int i = 0;
3051 while (metaState != 0) {
3052 final boolean isSet = (metaState & 1) != 0;
3053 metaState >>>= 1; // unsigned shift!
3054 if (isSet) {
3055 final String name = META_SYMBOLIC_NAMES[i];
3056 if (result == null) {
3057 if (metaState == 0) {
3058 return name;
3059 }
3060 result = new StringBuilder(name);
3061 } else {
3062 result.append('|');
3063 result.append(name);
3064 }
3065 }
3066 i += 1;
3067 }
3068 return result.toString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003069 }
3070
Jeff Sharkey9e8f83d2019-02-28 12:06:45 -07003071 public static final @android.annotation.NonNull Parcelable.Creator<KeyEvent> CREATOR
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003072 = new Parcelable.Creator<KeyEvent>() {
Jim Miller07e03842016-06-22 15:18:13 -07003073 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003074 public KeyEvent createFromParcel(Parcel in) {
Jeff Brown6ec402b2010-07-28 15:48:59 -07003075 in.readInt(); // skip token, we already know this is a KeyEvent
3076 return KeyEvent.createFromParcelBody(in);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003077 }
3078
Jim Miller07e03842016-06-22 15:18:13 -07003079 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003080 public KeyEvent[] newArray(int size) {
3081 return new KeyEvent[size];
3082 }
3083 };
RoboErik01fe6612014-02-13 14:19:04 -08003084
Jeff Brown6ec402b2010-07-28 15:48:59 -07003085 /** @hide */
3086 public static KeyEvent createFromParcelBody(Parcel in) {
3087 return new KeyEvent(in);
3088 }
RoboErik01fe6612014-02-13 14:19:04 -08003089
Jeff Brown6ec402b2010-07-28 15:48:59 -07003090 private KeyEvent(Parcel in) {
Jeff Brown91c69ab2011-02-14 17:03:18 -08003091 mDeviceId = in.readInt();
3092 mSource = in.readInt();
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01003093 mDisplayId = in.readInt();
Jeff Brown6ec402b2010-07-28 15:48:59 -07003094 mAction = in.readInt();
3095 mKeyCode = in.readInt();
3096 mRepeatCount = in.readInt();
3097 mMetaState = in.readInt();
3098 mScanCode = in.readInt();
3099 mFlags = in.readInt();
3100 mDownTime = in.readLong();
3101 mEventTime = in.readLong();
Siarhei Vishniakoue481d332018-07-18 14:46:00 +01003102 mCharacters = in.readString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003103 }
3104
Jim Miller07e03842016-06-22 15:18:13 -07003105 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003106 public void writeToParcel(Parcel out, int flags) {
Jeff Brown6ec402b2010-07-28 15:48:59 -07003107 out.writeInt(PARCEL_TOKEN_KEY_EVENT);
Jeff Brown91c69ab2011-02-14 17:03:18 -08003108
3109 out.writeInt(mDeviceId);
3110 out.writeInt(mSource);
Siarhei Vishniakou91fa08f2018-06-08 22:49:30 +01003111 out.writeInt(mDisplayId);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003112 out.writeInt(mAction);
3113 out.writeInt(mKeyCode);
3114 out.writeInt(mRepeatCount);
3115 out.writeInt(mMetaState);
Jeff Brown46b9ac02010-04-22 18:58:52 -07003116 out.writeInt(mScanCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003117 out.writeInt(mFlags);
3118 out.writeLong(mDownTime);
3119 out.writeLong(mEventTime);
Siarhei Vishniakoue481d332018-07-18 14:46:00 +01003120 out.writeString(mCharacters);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003121 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08003122}