blob: 052ef7c73e772689c9bfc9f68469732ac61ddb90 [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
19import android.os.Parcel;
20import android.os.Parcelable;
Jeff Brown6b53e8d2010-11-10 16:03:06 -080021import android.text.method.MetaKeyKeyListener;
Dianne Hackborn8d374262009-09-14 21:21:52 -070022import android.util.Log;
Dianne Hackborn83fe3f52009-09-12 23:38:30 -070023import android.util.SparseIntArray;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080024import android.view.KeyCharacterMap;
25import android.view.KeyCharacterMap.KeyData;
26
27/**
Jeff Browndc1ab4b2010-09-14 18:03:38 -070028 * Object used to report key and button events.
29 * <p>
30 * Each key press is described by a sequence of key events. A key press
31 * starts with a key event with {@link #ACTION_DOWN}. If the key is held
32 * sufficiently long that it repeats, then the initial down is followed
33 * additional key events with {@link #ACTION_DOWN} and a non-zero value for
34 * {@link #getRepeatCount()}. The last key event is a {@link #ACTION_UP}
35 * for the key up. If the key press is canceled, the key up event will have the
36 * {@link #FLAG_CANCELED} flag set.
37 * </p><p>
38 * Key events are generally accompanied by a key code ({@link #getKeyCode()}),
39 * scan code ({@link #getScanCode()}) and meta state ({@link #getMetaState()}).
40 * Key code constants are defined in this class. Scan code constants are raw
41 * device-specific codes obtained from the OS and so are not generally meaningful
42 * to applications unless interpreted using the {@link KeyCharacterMap}.
43 * Meta states describe the pressed state of key modifiers
44 * such as {@link #META_SHIFT_ON} or {@link #META_ALT_ON}.
45 * </p><p>
Jeff Brown497a92c2010-09-12 17:55:08 -070046 * Key codes typically correspond one-to-one with individual keys on an input device.
47 * Many keys and key combinations serve quite different functions on different
48 * input devices so care must be taken when interpreting them. Always use the
49 * {@link KeyCharacterMap} associated with the input device when mapping keys
50 * to characters. Be aware that there may be multiple key input devices active
51 * at the same time and each will have its own key character map.
52 * </p><p>
Jean Chalard405bc512012-05-29 19:12:34 +090053 * As soft input methods can use multiple and inventive ways of inputting text,
54 * there is no guarantee that any key press on a soft keyboard will generate a key
55 * event: this is left to the IME's discretion, and in fact sending such events is
56 * discouraged. You should never rely on receiving KeyEvents for any key on a soft
57 * input method. In particular, the default software keyboard will never send any
58 * key event to any application targetting Jelly Bean or later, and will only send
59 * events for some presses of the delete and return keys to applications targetting
60 * Ice Cream Sandwich or earlier. Be aware that other software input methods may
61 * never send key events regardless of the version. Consider using editor actions
62 * like {@link android.view.inputmethod.EditorInfo#IME_ACTION_DONE} if you need
63 * specific interaction with the software keyboard, as it gives more visibility to
64 * the user as to how your application will react to key presses.
65 * </p><p>
Jeff Browndc1ab4b2010-09-14 18:03:38 -070066 * When interacting with an IME, the framework may deliver key events
67 * with the special action {@link #ACTION_MULTIPLE} that either specifies
68 * that single repeated key code or a sequence of characters to insert.
69 * </p><p>
Jeff Brownb6997262010-10-08 22:31:17 -070070 * In general, the framework cannot guarantee that the key events it delivers
71 * to a view always constitute complete key sequences since some events may be dropped
72 * or modified by containing views before they are delivered. The view implementation
73 * should be prepared to handle {@link #FLAG_CANCELED} and should tolerate anomalous
74 * situations such as receiving a new {@link #ACTION_DOWN} without first having
75 * received an {@link #ACTION_UP} for the prior key press.
Jeff Browndc1ab4b2010-09-14 18:03:38 -070076 * </p><p>
77 * Refer to {@link InputDevice} for more information about how different kinds of
78 * input devices and sources represent keys and buttons.
79 * </p>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080080 */
Jeff Brownc5ed5912010-07-14 18:48:53 -070081public class KeyEvent extends InputEvent implements Parcelable {
Jeff Browndc1ab4b2010-09-14 18:03:38 -070082 /** Key code constant: Unknown key code. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080083 public static final int KEYCODE_UNKNOWN = 0;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070084 /** Key code constant: Soft Left key.
85 * Usually situated below the display on phones and used as a multi-function
86 * feature key for selecting a software defined function shown on the bottom left
87 * of the display. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080088 public static final int KEYCODE_SOFT_LEFT = 1;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070089 /** Key code constant: Soft Right 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 right
92 * of the display. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080093 public static final int KEYCODE_SOFT_RIGHT = 2;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070094 /** Key code constant: Home key.
95 * This key is handled by the framework and is never delivered to applications. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080096 public static final int KEYCODE_HOME = 3;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070097 /** Key code constant: Back key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080098 public static final int KEYCODE_BACK = 4;
Jeff Browndc1ab4b2010-09-14 18:03:38 -070099 /** Key code constant: Call key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800100 public static final int KEYCODE_CALL = 5;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700101 /** Key code constant: End Call key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800102 public static final int KEYCODE_ENDCALL = 6;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700103 /** Key code constant: '0' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800104 public static final int KEYCODE_0 = 7;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700105 /** Key code constant: '1' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800106 public static final int KEYCODE_1 = 8;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700107 /** Key code constant: '2' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800108 public static final int KEYCODE_2 = 9;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700109 /** Key code constant: '3' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800110 public static final int KEYCODE_3 = 10;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700111 /** Key code constant: '4' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800112 public static final int KEYCODE_4 = 11;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700113 /** Key code constant: '5' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800114 public static final int KEYCODE_5 = 12;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700115 /** Key code constant: '6' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800116 public static final int KEYCODE_6 = 13;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700117 /** Key code constant: '7' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800118 public static final int KEYCODE_7 = 14;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700119 /** Key code constant: '8' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800120 public static final int KEYCODE_8 = 15;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700121 /** Key code constant: '9' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800122 public static final int KEYCODE_9 = 16;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700123 /** Key code constant: '*' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800124 public static final int KEYCODE_STAR = 17;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700125 /** Key code constant: '#' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800126 public static final int KEYCODE_POUND = 18;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700127 /** Key code constant: Directional Pad Up key.
128 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800129 public static final int KEYCODE_DPAD_UP = 19;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700130 /** Key code constant: Directional Pad Down key.
131 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800132 public static final int KEYCODE_DPAD_DOWN = 20;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700133 /** Key code constant: Directional Pad Left key.
134 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800135 public static final int KEYCODE_DPAD_LEFT = 21;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700136 /** Key code constant: Directional Pad Right key.
137 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800138 public static final int KEYCODE_DPAD_RIGHT = 22;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700139 /** Key code constant: Directional Pad Center key.
140 * May also be synthesized from trackball motions. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800141 public static final int KEYCODE_DPAD_CENTER = 23;
Jeff Brownb0418da2010-11-01 15:24:01 -0700142 /** Key code constant: Volume Up key.
143 * Adjusts the speaker volume up. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800144 public static final int KEYCODE_VOLUME_UP = 24;
Jeff Brownb0418da2010-11-01 15:24:01 -0700145 /** Key code constant: Volume Down key.
146 * Adjusts the speaker volume down. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800147 public static final int KEYCODE_VOLUME_DOWN = 25;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700148 /** Key code constant: Power key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800149 public static final int KEYCODE_POWER = 26;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700150 /** Key code constant: Camera key.
151 * Used to launch a camera application or take pictures. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800152 public static final int KEYCODE_CAMERA = 27;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700153 /** Key code constant: Clear key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800154 public static final int KEYCODE_CLEAR = 28;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700155 /** Key code constant: 'A' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800156 public static final int KEYCODE_A = 29;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700157 /** Key code constant: 'B' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800158 public static final int KEYCODE_B = 30;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700159 /** Key code constant: 'C' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800160 public static final int KEYCODE_C = 31;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700161 /** Key code constant: 'D' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800162 public static final int KEYCODE_D = 32;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700163 /** Key code constant: 'E' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800164 public static final int KEYCODE_E = 33;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700165 /** Key code constant: 'F' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800166 public static final int KEYCODE_F = 34;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700167 /** Key code constant: 'G' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800168 public static final int KEYCODE_G = 35;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700169 /** Key code constant: 'H' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800170 public static final int KEYCODE_H = 36;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700171 /** Key code constant: 'I' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800172 public static final int KEYCODE_I = 37;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700173 /** Key code constant: 'J' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800174 public static final int KEYCODE_J = 38;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700175 /** Key code constant: 'K' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800176 public static final int KEYCODE_K = 39;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700177 /** Key code constant: 'L' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800178 public static final int KEYCODE_L = 40;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700179 /** Key code constant: 'M' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800180 public static final int KEYCODE_M = 41;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700181 /** Key code constant: 'N' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800182 public static final int KEYCODE_N = 42;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700183 /** Key code constant: 'O' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800184 public static final int KEYCODE_O = 43;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700185 /** Key code constant: 'P' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800186 public static final int KEYCODE_P = 44;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700187 /** Key code constant: 'Q' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800188 public static final int KEYCODE_Q = 45;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700189 /** Key code constant: 'R' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800190 public static final int KEYCODE_R = 46;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700191 /** Key code constant: 'S' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800192 public static final int KEYCODE_S = 47;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700193 /** Key code constant: 'T' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800194 public static final int KEYCODE_T = 48;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700195 /** Key code constant: 'U' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800196 public static final int KEYCODE_U = 49;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700197 /** Key code constant: 'V' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800198 public static final int KEYCODE_V = 50;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700199 /** Key code constant: 'W' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800200 public static final int KEYCODE_W = 51;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700201 /** Key code constant: 'X' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800202 public static final int KEYCODE_X = 52;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700203 /** Key code constant: 'Y' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800204 public static final int KEYCODE_Y = 53;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700205 /** Key code constant: 'Z' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800206 public static final int KEYCODE_Z = 54;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700207 /** Key code constant: ',' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800208 public static final int KEYCODE_COMMA = 55;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700209 /** Key code constant: '.' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800210 public static final int KEYCODE_PERIOD = 56;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700211 /** Key code constant: Left Alt modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800212 public static final int KEYCODE_ALT_LEFT = 57;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700213 /** Key code constant: Right Alt modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800214 public static final int KEYCODE_ALT_RIGHT = 58;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700215 /** Key code constant: Left Shift modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800216 public static final int KEYCODE_SHIFT_LEFT = 59;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700217 /** Key code constant: Right Shift modifier key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800218 public static final int KEYCODE_SHIFT_RIGHT = 60;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700219 /** Key code constant: Tab key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800220 public static final int KEYCODE_TAB = 61;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700221 /** Key code constant: Space key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800222 public static final int KEYCODE_SPACE = 62;
Jeff Brown224d4a12010-10-07 20:28:53 -0700223 /** Key code constant: Symbol modifier key.
224 * Used to enter alternate symbols. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800225 public static final int KEYCODE_SYM = 63;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700226 /** Key code constant: Explorer special function key.
227 * Used to launch a browser application. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800228 public static final int KEYCODE_EXPLORER = 64;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700229 /** Key code constant: Envelope special function key.
230 * Used to launch a mail application. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800231 public static final int KEYCODE_ENVELOPE = 65;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700232 /** Key code constant: Enter key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800233 public static final int KEYCODE_ENTER = 66;
Jeff Brown224d4a12010-10-07 20:28:53 -0700234 /** Key code constant: Backspace key.
Jeff Brown497a92c2010-09-12 17:55:08 -0700235 * Deletes characters before the insertion point, unlike {@link #KEYCODE_FORWARD_DEL}. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800236 public static final int KEYCODE_DEL = 67;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700237 /** Key code constant: '`' (backtick) key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800238 public static final int KEYCODE_GRAVE = 68;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700239 /** Key code constant: '-'. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800240 public static final int KEYCODE_MINUS = 69;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700241 /** Key code constant: '=' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800242 public static final int KEYCODE_EQUALS = 70;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700243 /** Key code constant: '[' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800244 public static final int KEYCODE_LEFT_BRACKET = 71;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700245 /** Key code constant: ']' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800246 public static final int KEYCODE_RIGHT_BRACKET = 72;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700247 /** Key code constant: '\' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800248 public static final int KEYCODE_BACKSLASH = 73;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700249 /** Key code constant: ';' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800250 public static final int KEYCODE_SEMICOLON = 74;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700251 /** Key code constant: ''' (apostrophe) key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800252 public static final int KEYCODE_APOSTROPHE = 75;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700253 /** Key code constant: '/' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800254 public static final int KEYCODE_SLASH = 76;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700255 /** Key code constant: '@' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800256 public static final int KEYCODE_AT = 77;
Jeff Brown224d4a12010-10-07 20:28:53 -0700257 /** Key code constant: Number modifier key.
258 * Used to enter numeric symbols.
259 * This key is not Num Lock; it is more like {@link #KEYCODE_ALT_LEFT} and is
260 * interpreted as an ALT key by {@link android.text.method.MetaKeyKeyListener}. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800261 public static final int KEYCODE_NUM = 78;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700262 /** Key code constant: Headset Hook key.
263 * Used to hang up calls and stop media. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800264 public static final int KEYCODE_HEADSETHOOK = 79;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700265 /** Key code constant: Camera Focus key.
266 * Used to focus the camera. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800267 public static final int KEYCODE_FOCUS = 80; // *Camera* focus
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700268 /** Key code constant: '+' key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800269 public static final int KEYCODE_PLUS = 81;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700270 /** Key code constant: Menu key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800271 public static final int KEYCODE_MENU = 82;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700272 /** Key code constant: Notification key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800273 public static final int KEYCODE_NOTIFICATION = 83;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700274 /** Key code constant: Search key. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800275 public static final int KEYCODE_SEARCH = 84;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700276 /** Key code constant: Play/Pause media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700277 public static final int KEYCODE_MEDIA_PLAY_PAUSE= 85;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700278 /** Key code constant: Stop media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700279 public static final int KEYCODE_MEDIA_STOP = 86;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700280 /** Key code constant: Play Next media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700281 public static final int KEYCODE_MEDIA_NEXT = 87;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700282 /** Key code constant: Play Previous media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700283 public static final int KEYCODE_MEDIA_PREVIOUS = 88;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700284 /** Key code constant: Rewind media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700285 public static final int KEYCODE_MEDIA_REWIND = 89;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700286 /** Key code constant: Fast Forward media key. */
Dianne Hackborn935ae462009-04-13 16:11:55 -0700287 public static final int KEYCODE_MEDIA_FAST_FORWARD = 90;
Jeff Brownb0418da2010-11-01 15:24:01 -0700288 /** Key code constant: Mute key.
289 * Mutes the microphone, unlike {@link #KEYCODE_VOLUME_MUTE}. */
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800290 public static final int KEYCODE_MUTE = 91;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700291 /** Key code constant: Page Up key. */
Chih-Wei Huang4fedd802009-05-27 15:52:50 +0800292 public static final int KEYCODE_PAGE_UP = 92;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700293 /** Key code constant: Page Down key. */
Chih-Wei Huang4fedd802009-05-27 15:52:50 +0800294 public static final int KEYCODE_PAGE_DOWN = 93;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700295 /** Key code constant: Picture Symbols modifier key.
296 * Used to switch symbol sets (Emoji, Kao-moji). */
mogimob032bc02009-10-03 03:13:56 +0900297 public static final int KEYCODE_PICTSYMBOLS = 94; // switch symbol-sets (Emoji,Kao-moji)
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700298 /** Key code constant: Switch Charset modifier key.
299 * Used to switch character sets (Kanji, Katakana). */
mogimob032bc02009-10-03 03:13:56 +0900300 public static final int KEYCODE_SWITCH_CHARSET = 95; // switch char-sets (Kanji,Katakana)
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700301 /** Key code constant: A Button key.
302 * On a game controller, the A button should be either the button labeled A
Michael Wright6b57bde2013-01-28 20:35:58 -0800303 * or the first button on the bottom row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700304 public static final int KEYCODE_BUTTON_A = 96;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700305 /** Key code constant: B Button key.
306 * On a game controller, the B button should be either the button labeled B
Michael Wright6b57bde2013-01-28 20:35:58 -0800307 * or the second button on the bottom row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700308 public static final int KEYCODE_BUTTON_B = 97;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700309 /** Key code constant: C Button key.
310 * On a game controller, the C button should be either the button labeled C
Michael Wright6b57bde2013-01-28 20:35:58 -0800311 * or the third button on the bottom row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700312 public static final int KEYCODE_BUTTON_C = 98;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700313 /** Key code constant: X Button key.
314 * On a game controller, the X button should be either the button labeled X
Michael Wright6b57bde2013-01-28 20:35:58 -0800315 * or the first button on the upper row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700316 public static final int KEYCODE_BUTTON_X = 99;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700317 /** Key code constant: Y Button key.
318 * On a game controller, the Y button should be either the button labeled Y
Michael Wright6b57bde2013-01-28 20:35:58 -0800319 * or the second button on the upper row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700320 public static final int KEYCODE_BUTTON_Y = 100;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700321 /** Key code constant: Z Button key.
322 * On a game controller, the Z button should be either the button labeled Z
Michael Wright6b57bde2013-01-28 20:35:58 -0800323 * or the third button on the upper row of controller buttons. */
Jeff Brownfd035822010-06-30 16:10:35 -0700324 public static final int KEYCODE_BUTTON_Z = 101;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700325 /** Key code constant: L1 Button key.
326 * On a game controller, the L1 button should be either the button labeled L1 (or L)
327 * or the top left trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700328 public static final int KEYCODE_BUTTON_L1 = 102;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700329 /** Key code constant: R1 Button key.
330 * On a game controller, the R1 button should be either the button labeled R1 (or R)
331 * or the top right trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700332 public static final int KEYCODE_BUTTON_R1 = 103;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700333 /** Key code constant: L2 Button key.
334 * On a game controller, the L2 button should be either the button labeled L2
335 * or the bottom left trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700336 public static final int KEYCODE_BUTTON_L2 = 104;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700337 /** Key code constant: R2 Button key.
338 * On a game controller, the R2 button should be either the button labeled R2
339 * or the bottom right trigger button. */
Jeff Brownfd035822010-06-30 16:10:35 -0700340 public static final int KEYCODE_BUTTON_R2 = 105;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700341 /** Key code constant: Left Thumb Button key.
342 * On a game controller, the left thumb button indicates that the left (or only)
343 * joystick is pressed. */
Jeff Brownfd035822010-06-30 16:10:35 -0700344 public static final int KEYCODE_BUTTON_THUMBL = 106;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700345 /** Key code constant: Right Thumb Button key.
346 * On a game controller, the right thumb button indicates that the right
347 * joystick is pressed. */
Jeff Brownfd035822010-06-30 16:10:35 -0700348 public static final int KEYCODE_BUTTON_THUMBR = 107;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700349 /** Key code constant: Start Button key.
350 * On a game controller, the button labeled Start. */
Jeff Brownfd035822010-06-30 16:10:35 -0700351 public static final int KEYCODE_BUTTON_START = 108;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700352 /** Key code constant: Select Button key.
353 * On a game controller, the button labeled Select. */
Jeff Brownfd035822010-06-30 16:10:35 -0700354 public static final int KEYCODE_BUTTON_SELECT = 109;
Jeff Browndc1ab4b2010-09-14 18:03:38 -0700355 /** Key code constant: Mode Button key.
356 * On a game controller, the button labeled Mode. */
Jeff Brownfd035822010-06-30 16:10:35 -0700357 public static final int KEYCODE_BUTTON_MODE = 110;
Jeff Brown497a92c2010-09-12 17:55:08 -0700358 /** Key code constant: Escape key. */
359 public static final int KEYCODE_ESCAPE = 111;
360 /** Key code constant: Forward Delete key.
361 * Deletes characters ahead of the insertion point, unlike {@link #KEYCODE_DEL}. */
362 public static final int KEYCODE_FORWARD_DEL = 112;
363 /** Key code constant: Left Control modifier key. */
364 public static final int KEYCODE_CTRL_LEFT = 113;
365 /** Key code constant: Right Control modifier key. */
366 public static final int KEYCODE_CTRL_RIGHT = 114;
Jeff Brown28cbf4b2010-12-13 10:33:20 -0800367 /** Key code constant: Caps Lock key. */
Jeff Brown497a92c2010-09-12 17:55:08 -0700368 public static final int KEYCODE_CAPS_LOCK = 115;
369 /** Key code constant: Scroll Lock key. */
370 public static final int KEYCODE_SCROLL_LOCK = 116;
371 /** Key code constant: Left Meta modifier key. */
372 public static final int KEYCODE_META_LEFT = 117;
373 /** Key code constant: Right Meta modifier key. */
374 public static final int KEYCODE_META_RIGHT = 118;
375 /** Key code constant: Function modifier key. */
376 public static final int KEYCODE_FUNCTION = 119;
377 /** Key code constant: System Request / Print Screen key. */
378 public static final int KEYCODE_SYSRQ = 120;
379 /** Key code constant: Break / Pause key. */
380 public static final int KEYCODE_BREAK = 121;
381 /** Key code constant: Home Movement key.
382 * Used for scrolling or moving the cursor around to the start of a line
383 * or to the top of a list. */
384 public static final int KEYCODE_MOVE_HOME = 122;
385 /** Key code constant: End Movement key.
386 * Used for scrolling or moving the cursor around to the end of a line
387 * or to the bottom of a list. */
388 public static final int KEYCODE_MOVE_END = 123;
389 /** Key code constant: Insert key.
390 * Toggles insert / overwrite edit mode. */
391 public static final int KEYCODE_INSERT = 124;
392 /** Key code constant: Forward key.
393 * Navigates forward in the history stack. Complement of {@link #KEYCODE_BACK}. */
394 public static final int KEYCODE_FORWARD = 125;
395 /** Key code constant: Play media key. */
396 public static final int KEYCODE_MEDIA_PLAY = 126;
397 /** Key code constant: Pause media key. */
398 public static final int KEYCODE_MEDIA_PAUSE = 127;
399 /** Key code constant: Close media key.
400 * May be used to close a CD tray, for example. */
401 public static final int KEYCODE_MEDIA_CLOSE = 128;
402 /** Key code constant: Eject media key.
403 * May be used to eject a CD tray, for example. */
404 public static final int KEYCODE_MEDIA_EJECT = 129;
405 /** Key code constant: Record media key. */
406 public static final int KEYCODE_MEDIA_RECORD = 130;
407 /** Key code constant: F1 key. */
408 public static final int KEYCODE_F1 = 131;
409 /** Key code constant: F2 key. */
410 public static final int KEYCODE_F2 = 132;
411 /** Key code constant: F3 key. */
412 public static final int KEYCODE_F3 = 133;
413 /** Key code constant: F4 key. */
414 public static final int KEYCODE_F4 = 134;
415 /** Key code constant: F5 key. */
416 public static final int KEYCODE_F5 = 135;
417 /** Key code constant: F6 key. */
418 public static final int KEYCODE_F6 = 136;
419 /** Key code constant: F7 key. */
420 public static final int KEYCODE_F7 = 137;
421 /** Key code constant: F8 key. */
422 public static final int KEYCODE_F8 = 138;
423 /** Key code constant: F9 key. */
424 public static final int KEYCODE_F9 = 139;
425 /** Key code constant: F10 key. */
426 public static final int KEYCODE_F10 = 140;
427 /** Key code constant: F11 key. */
428 public static final int KEYCODE_F11 = 141;
429 /** Key code constant: F12 key. */
430 public static final int KEYCODE_F12 = 142;
Jeff Brown28cbf4b2010-12-13 10:33:20 -0800431 /** Key code constant: Num Lock key.
Jeff Brown497a92c2010-09-12 17:55:08 -0700432 * This is the Num Lock key; it is different from {@link #KEYCODE_NUM}.
Jeff Brown28cbf4b2010-12-13 10:33:20 -0800433 * This key alters the behavior of other keys on the numeric keypad. */
Jeff Brown497a92c2010-09-12 17:55:08 -0700434 public static final int KEYCODE_NUM_LOCK = 143;
435 /** Key code constant: Numeric keypad '0' key. */
436 public static final int KEYCODE_NUMPAD_0 = 144;
437 /** Key code constant: Numeric keypad '1' key. */
438 public static final int KEYCODE_NUMPAD_1 = 145;
439 /** Key code constant: Numeric keypad '2' key. */
440 public static final int KEYCODE_NUMPAD_2 = 146;
441 /** Key code constant: Numeric keypad '3' key. */
442 public static final int KEYCODE_NUMPAD_3 = 147;
443 /** Key code constant: Numeric keypad '4' key. */
444 public static final int KEYCODE_NUMPAD_4 = 148;
445 /** Key code constant: Numeric keypad '5' key. */
446 public static final int KEYCODE_NUMPAD_5 = 149;
447 /** Key code constant: Numeric keypad '6' key. */
448 public static final int KEYCODE_NUMPAD_6 = 150;
449 /** Key code constant: Numeric keypad '7' key. */
450 public static final int KEYCODE_NUMPAD_7 = 151;
451 /** Key code constant: Numeric keypad '8' key. */
452 public static final int KEYCODE_NUMPAD_8 = 152;
453 /** Key code constant: Numeric keypad '9' key. */
454 public static final int KEYCODE_NUMPAD_9 = 153;
455 /** Key code constant: Numeric keypad '/' key (for division). */
456 public static final int KEYCODE_NUMPAD_DIVIDE = 154;
457 /** Key code constant: Numeric keypad '*' key (for multiplication). */
458 public static final int KEYCODE_NUMPAD_MULTIPLY = 155;
459 /** Key code constant: Numeric keypad '-' key (for subtraction). */
460 public static final int KEYCODE_NUMPAD_SUBTRACT = 156;
461 /** Key code constant: Numeric keypad '+' key (for addition). */
462 public static final int KEYCODE_NUMPAD_ADD = 157;
463 /** Key code constant: Numeric keypad '.' key (for decimals or digit grouping). */
464 public static final int KEYCODE_NUMPAD_DOT = 158;
465 /** Key code constant: Numeric keypad ',' key (for decimals or digit grouping). */
466 public static final int KEYCODE_NUMPAD_COMMA = 159;
467 /** Key code constant: Numeric keypad Enter key. */
468 public static final int KEYCODE_NUMPAD_ENTER = 160;
469 /** Key code constant: Numeric keypad '=' key. */
470 public static final int KEYCODE_NUMPAD_EQUALS = 161;
471 /** Key code constant: Numeric keypad '(' key. */
472 public static final int KEYCODE_NUMPAD_LEFT_PAREN = 162;
473 /** Key code constant: Numeric keypad ')' key. */
474 public static final int KEYCODE_NUMPAD_RIGHT_PAREN = 163;
Jeff Brownb0418da2010-11-01 15:24:01 -0700475 /** Key code constant: Volume Mute key.
476 * Mutes the speaker, unlike {@link #KEYCODE_MUTE}.
477 * This key should normally be implemented as a toggle such that the first press
478 * mutes the speaker and the second press restores the original volume. */
479 public static final int KEYCODE_VOLUME_MUTE = 164;
Jason Bayer3adf4902010-11-09 14:54:55 -0800480 /** Key code constant: Info key.
481 * Common on TV remotes to show additional information related to what is
482 * currently being viewed. */
483 public static final int KEYCODE_INFO = 165;
484 /** Key code constant: Channel up key.
485 * On TV remotes, increments the television channel. */
486 public static final int KEYCODE_CHANNEL_UP = 166;
487 /** Key code constant: Channel down key.
488 * On TV remotes, decrements the television channel. */
489 public static final int KEYCODE_CHANNEL_DOWN = 167;
490 /** Key code constant: Zoom in key. */
491 public static final int KEYCODE_ZOOM_IN = 168;
492 /** Key code constant: Zoom out key. */
493 public static final int KEYCODE_ZOOM_OUT = 169;
494 /** Key code constant: TV key.
495 * On TV remotes, switches to viewing live TV. */
496 public static final int KEYCODE_TV = 170;
497 /** Key code constant: Window key.
498 * On TV remotes, toggles picture-in-picture mode or other windowing functions. */
499 public static final int KEYCODE_WINDOW = 171;
500 /** Key code constant: Guide key.
501 * On TV remotes, shows a programming guide. */
502 public static final int KEYCODE_GUIDE = 172;
503 /** Key code constant: DVR key.
504 * On some TV remotes, switches to a DVR mode for recorded shows. */
505 public static final int KEYCODE_DVR = 173;
506 /** Key code constant: Bookmark key.
507 * On some TV remotes, bookmarks content or web pages. */
508 public static final int KEYCODE_BOOKMARK = 174;
509 /** Key code constant: Toggle captions key.
510 * Switches the mode for closed-captioning text, for example during television shows. */
511 public static final int KEYCODE_CAPTIONS = 175;
512 /** Key code constant: Settings key.
513 * Starts the system settings activity. */
514 public static final int KEYCODE_SETTINGS = 176;
515 /** Key code constant: TV power key.
516 * On TV remotes, toggles the power on a television screen. */
517 public static final int KEYCODE_TV_POWER = 177;
518 /** Key code constant: TV input key.
519 * On TV remotes, switches the input on a television screen. */
520 public static final int KEYCODE_TV_INPUT = 178;
521 /** Key code constant: Set-top-box power key.
522 * On TV remotes, toggles the power on an external Set-top-box. */
523 public static final int KEYCODE_STB_POWER = 179;
524 /** Key code constant: Set-top-box input key.
525 * On TV remotes, switches the input mode on an external Set-top-box. */
526 public static final int KEYCODE_STB_INPUT = 180;
527 /** Key code constant: A/V Receiver power key.
528 * On TV remotes, toggles the power on an external A/V Receiver. */
529 public static final int KEYCODE_AVR_POWER = 181;
530 /** Key code constant: A/V Receiver input key.
531 * On TV remotes, switches the input mode on an external A/V Receiver. */
532 public static final int KEYCODE_AVR_INPUT = 182;
533 /** Key code constant: Red "programmable" key.
534 * On TV remotes, acts as a contextual/programmable key. */
535 public static final int KEYCODE_PROG_RED = 183;
536 /** Key code constant: Green "programmable" key.
537 * On TV remotes, actsas a contextual/programmable key. */
538 public static final int KEYCODE_PROG_GREEN = 184;
539 /** Key code constant: Yellow "programmable" key.
540 * On TV remotes, acts as a contextual/programmable key. */
541 public static final int KEYCODE_PROG_YELLOW = 185;
542 /** Key code constant: Blue "programmable" key.
543 * On TV remotes, acts as a contextual/programmable key. */
544 public static final int KEYCODE_PROG_BLUE = 186;
Jeff Brown49ed71d2010-12-06 17:13:33 -0800545 /** Key code constant: App switch key.
546 * Should bring up the application switcher dialog. */
547 public static final int KEYCODE_APP_SWITCH = 187;
Jeff Browncb1404e2011-01-15 18:14:15 -0800548 /** Key code constant: Generic Game Pad Button #1.*/
549 public static final int KEYCODE_BUTTON_1 = 188;
550 /** Key code constant: Generic Game Pad Button #2.*/
551 public static final int KEYCODE_BUTTON_2 = 189;
552 /** Key code constant: Generic Game Pad Button #3.*/
553 public static final int KEYCODE_BUTTON_3 = 190;
554 /** Key code constant: Generic Game Pad Button #4.*/
555 public static final int KEYCODE_BUTTON_4 = 191;
556 /** Key code constant: Generic Game Pad Button #5.*/
557 public static final int KEYCODE_BUTTON_5 = 192;
558 /** Key code constant: Generic Game Pad Button #6.*/
559 public static final int KEYCODE_BUTTON_6 = 193;
560 /** Key code constant: Generic Game Pad Button #7.*/
561 public static final int KEYCODE_BUTTON_7 = 194;
562 /** Key code constant: Generic Game Pad Button #8.*/
563 public static final int KEYCODE_BUTTON_8 = 195;
564 /** Key code constant: Generic Game Pad Button #9.*/
565 public static final int KEYCODE_BUTTON_9 = 196;
566 /** Key code constant: Generic Game Pad Button #10.*/
567 public static final int KEYCODE_BUTTON_10 = 197;
568 /** Key code constant: Generic Game Pad Button #11.*/
569 public static final int KEYCODE_BUTTON_11 = 198;
570 /** Key code constant: Generic Game Pad Button #12.*/
571 public static final int KEYCODE_BUTTON_12 = 199;
572 /** Key code constant: Generic Game Pad Button #13.*/
573 public static final int KEYCODE_BUTTON_13 = 200;
574 /** Key code constant: Generic Game Pad Button #14.*/
575 public static final int KEYCODE_BUTTON_14 = 201;
576 /** Key code constant: Generic Game Pad Button #15.*/
577 public static final int KEYCODE_BUTTON_15 = 202;
578 /** Key code constant: Generic Game Pad Button #16.*/
579 public static final int KEYCODE_BUTTON_16 = 203;
Jeff Brown9812aed2011-03-07 17:09:51 -0800580 /** Key code constant: Language Switch key.
581 * Toggles the current input language such as switching between English and Japanese on
582 * a QWERTY keyboard. On some devices, the same function may be performed by
583 * pressing Shift+Spacebar. */
584 public static final int KEYCODE_LANGUAGE_SWITCH = 204;
585 /** Key code constant: Manner Mode key.
586 * Toggles silent or vibrate mode on and off to make the device behave more politely
587 * in certain settings such as on a crowded train. On some devices, the key may only
588 * operate when long-pressed. */
589 public static final int KEYCODE_MANNER_MODE = 205;
590 /** Key code constant: 3D Mode key.
591 * Toggles the display between 2D and 3D mode. */
592 public static final int KEYCODE_3D_MODE = 206;
Jeff Brown6651a632011-11-28 12:59:11 -0800593 /** Key code constant: Contacts special function key.
594 * Used to launch an address book application. */
595 public static final int KEYCODE_CONTACTS = 207;
596 /** Key code constant: Calendar special function key.
597 * Used to launch a calendar application. */
598 public static final int KEYCODE_CALENDAR = 208;
599 /** Key code constant: Music special function key.
600 * Used to launch a music player application. */
601 public static final int KEYCODE_MUSIC = 209;
602 /** Key code constant: Calculator special function key.
603 * Used to launch a calculator application. */
604 public static final int KEYCODE_CALCULATOR = 210;
Yang Chuang7511f9c2012-02-10 15:18:26 +0800605 /** Key code constant: Japanese full-width / half-width key. */
606 public static final int KEYCODE_ZENKAKU_HANKAKU = 211;
607 /** Key code constant: Japanese alphanumeric key. */
608 public static final int KEYCODE_EISU = 212;
609 /** Key code constant: Japanese non-conversion key. */
610 public static final int KEYCODE_MUHENKAN = 213;
611 /** Key code constant: Japanese conversion key. */
612 public static final int KEYCODE_HENKAN = 214;
613 /** Key code constant: Japanese katakana / hiragana key. */
614 public static final int KEYCODE_KATAKANA_HIRAGANA = 215;
615 /** Key code constant: Japanese Yen key. */
616 public static final int KEYCODE_YEN = 216;
617 /** Key code constant: Japanese Ro key. */
618 public static final int KEYCODE_RO = 217;
619 /** Key code constant: Japanese kana key. */
620 public static final int KEYCODE_KANA = 218;
Jeff Brownde7a8ea2012-06-13 18:28:57 -0700621 /** Key code constant: Assist key.
622 * Launches the global assist activity. Not delivered to applications. */
623 public static final int KEYCODE_ASSIST = 219;
Michael Wright1df477a2013-01-31 16:19:18 -0800624 /** Key code constant: Brightness Down key.
625 * Adjusts the screen brightness down. */
626 public static final int KEYCODE_BRIGHTNESS_DOWN = 220;
627 /** Key code constant: Brightness Up key.
628 * Adjusts the screen brightness up. */
629 public static final int KEYCODE_BRIGHTNESS_UP = 221;
Jeff Brown6212a492014-03-07 13:58:47 -0800630 /** Key code constant: Audio Track key.
Jaekyun Seokbfdad8e2013-07-08 13:53:21 +0900631 * Switches the audio tracks. */
632 public static final int KEYCODE_MEDIA_AUDIO_TRACK = 222;
Jeff Brown6212a492014-03-07 13:58:47 -0800633 /** Key code constant: Sleep key.
634 * Puts the device to sleep. Behaves somewhat like {@link #KEYCODE_POWER} but it
635 * has no effect if the device is already asleep. */
636 public static final int KEYCODE_SLEEP = 223;
637 /** Key code constant: Wakeup key.
638 * Wakes up the device. Behaves somewhat like {@link #KEYCODE_POWER} but it
639 * has no effect if the device is already awake. */
640 public static final int KEYCODE_WAKEUP = 224;
Tim Kilbourn87cd0dc2014-04-14 15:37:51 -0700641 /** Key code constant: Pairing key.
642 * Initiates peripheral pairing mode. Useful for pairing remote control
643 * devices or game controllers, especially if no other input mode is
644 * available. */
645 public static final int KEYCODE_PAIRING = 225;
Jinsuk Kim96658f72014-05-14 15:33:43 +0900646 /** Key code constant: Media Top Menu key.
647 * Goes to the top of media menu. */
648 public static final int KEYCODE_MEDIA_TOP_MENU = 226;
649 /** Key code constant: '11' key. */
650 public static final int KEYCODE_11 = 227;
651 /** Key code constant: '12' key. */
652 public static final int KEYCODE_12 = 228;
653 /** Key code constant: Last Channel key.
654 * Goes to the last viewed channel. */
655 public static final int KEYCODE_LAST_CHANNEL = 229;
656 /** Key code constant: TV data service key.
657 * Displays data services like weather, sports. */
658 public static final int KEYCODE_TV_DATA_SERVICE = 230;
Michael Wrightdc63f7b2014-08-21 19:05:21 -0700659 /** Key code constant: Voice Assist key.
660 * Launches the global voice assist activity. Not delivered to applications. */
661 public static final int KEYCODE_VOICE_ASSIST = 231;
ASAZU, Hidekidbd6aba2014-08-27 18:03:30 +0900662 /** Key code constant: Radio key.
663 * Toggles TV service / Radio service. */
664 public static final int KEYCODE_TV_RADIO_SERVICE = 232;
665 /** Key code constant: Teletext key.
666 * Displays Teletext service. */
667 public static final int KEYCODE_TV_TELETEXT = 233;
668 /** Key code constant: Number entry key.
669 * Initiates to enter multi-digit channel nubmber when each digit key is assigned
670 * for selecting separate channel. Corresponds to Number Entry Mode (0x1D) of CEC
671 * User Control Code. */
672 public static final int KEYCODE_TV_NUMBER_ENTRY = 234;
673 /** Key code constant: Analog Terrestrial key.
674 * Switches to analog terrestrial broadcast service. */
675 public static final int KEYCODE_TV_TERRESTRIAL_ANALOG = 235;
676 /** Key code constant: Digital Terrestrial key.
677 * Switches to digital terrestrial broadcast service. */
678 public static final int KEYCODE_TV_TERRESTRIAL_DIGITAL = 236;
679 /** Key code constant: Satellite key.
680 * Switches to digital satellite broadcast service. */
681 public static final int KEYCODE_TV_SATELLITE = 237;
682 /** Key code constant: BS key.
683 * Switches to BS digital satellite broadcasting service available in Japan. */
684 public static final int KEYCODE_TV_SATELLITE_BS = 238;
685 /** Key code constant: CS key.
686 * Switches to CS digital satellite broadcasting service available in Japan. */
687 public static final int KEYCODE_TV_SATELLITE_CS = 239;
688 /** Key code constant: BS/CS key.
689 * Toggles between BS and CS digital satellite services. */
690 public static final int KEYCODE_TV_SATELLITE_SERVICE = 240;
691 /** Key code constant: Toggle Network key.
692 * Toggles selecting broacast services. */
693 public static final int KEYCODE_TV_NETWORK = 241;
694 /** Key code constant: Antenna/Cable key.
695 * Toggles broadcast input source between antenna and cable. */
696 public static final int KEYCODE_TV_ANTENNA_CABLE = 242;
697 /** Key code constant: HDMI #1 key.
698 * Switches to HDMI input #1. */
699 public static final int KEYCODE_TV_INPUT_HDMI_1 = 243;
700 /** Key code constant: HDMI #2 key.
701 * Switches to HDMI input #2. */
702 public static final int KEYCODE_TV_INPUT_HDMI_2 = 244;
703 /** Key code constant: HDMI #3 key.
704 * Switches to HDMI input #3. */
705 public static final int KEYCODE_TV_INPUT_HDMI_3 = 245;
706 /** Key code constant: HDMI #4 key.
707 * Switches to HDMI input #4. */
708 public static final int KEYCODE_TV_INPUT_HDMI_4 = 246;
709 /** Key code constant: Composite #1 key.
710 * Switches to composite video input #1. */
711 public static final int KEYCODE_TV_INPUT_COMPOSITE_1 = 247;
712 /** Key code constant: Composite #2 key.
713 * Switches to composite video input #2. */
714 public static final int KEYCODE_TV_INPUT_COMPOSITE_2 = 248;
715 /** Key code constant: Component #1 key.
716 * Switches to component video input #1. */
717 public static final int KEYCODE_TV_INPUT_COMPONENT_1 = 249;
718 /** Key code constant: Component #2 key.
719 * Switches to component video input #2. */
720 public static final int KEYCODE_TV_INPUT_COMPONENT_2 = 250;
721 /** Key code constant: VGA #1 key.
722 * Switches to VGA (analog RGB) input #1. */
723 public static final int KEYCODE_TV_INPUT_VGA_1 = 251;
724 /** Key code constant: Audio description key.
725 * Toggles audio description off / on. */
726 public static final int KEYCODE_TV_AUDIO_DESCRIPTION = 252;
727 /** Key code constant: Audio description mixing volume up key.
728 * Louden audio description volume as compared with normal audio volume. */
729 public static final int KEYCODE_TV_AUDIO_DESCRIPTION_MIX_UP = 253;
730 /** Key code constant: Audio description mixing volume down key.
731 * Lessen audio description volume as compared with normal audio volume. */
732 public static final int KEYCODE_TV_AUDIO_DESCRIPTION_MIX_DOWN = 254;
733 /** Key code constant: Zoom mode key.
734 * Changes Zoom mode (Normal, Full, Zoom, Wide-zoom, etc.) */
735 public static final int KEYCODE_TV_ZOOM_MODE = 255;
736 /** Key code constant: Contents menu key.
737 * Goes to the title list. Corresponds to Contents Menu (0x0B) of CEC User Control
738 * Code */
739 public static final int KEYCODE_TV_CONTENTS_MENU = 256;
740 /** Key code constant: Media context menu key.
741 * Goes to the context menu of media contents. Corresponds to Media Context-sensitive
742 * Menu (0x11) of CEC User Control Code. */
743 public static final int KEYCODE_TV_MEDIA_CONTEXT_MENU = 257;
744 /** Key code constant: Timer programming key.
745 * Goes to the timer recording menu. Corresponds to Timer Programming (0x54) of
746 * CEC User Control Code. */
747 public static final int KEYCODE_TV_TIMER_PROGRAMMING = 258;
748 /** Key code constant: Help key. */
749 public static final int KEYCODE_HELP = 259;
Michael Wright600b9842015-08-06 15:16:22 +0100750 /** Key code constant: Navigate to previous key.
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700751 * Goes backward by one item in an ordered collection of items. */
752 public static final int KEYCODE_NAVIGATE_PREVIOUS = 260;
Michael Wright600b9842015-08-06 15:16:22 +0100753 /** Key code constant: Navigate to next key.
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700754 * Advances to the next item in an ordered collection of items. */
755 public static final int KEYCODE_NAVIGATE_NEXT = 261;
756 /** Key code constant: Navigate in key.
Michael Wright600b9842015-08-06 15:16:22 +0100757 * Activates the item that currently has focus or expands to the next level of a navigation
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700758 * hierarchy. */
759 public static final int KEYCODE_NAVIGATE_IN = 262;
760 /** Key code constant: Navigate out key.
Michael Wright600b9842015-08-06 15:16:22 +0100761 * Backs out one level of a navigation hierarchy or collapses the item that currently has
Joseph Cooper55b9ed42015-04-15 16:21:58 -0700762 * focus. */
763 public static final int KEYCODE_NAVIGATE_OUT = 263;
Anthony Hugh26fa5012015-06-23 10:44:17 -0700764 /** Key code constant: Primary stem key for Wear
765 * Main power/reset button on watch.
766 * @hide */
767 public static final int KEYCODE_STEM_PRIMARY = 264;
768 /** Key code constant: Generic stem key 1 for Wear
769 * @hide */
770 public static final int KEYCODE_STEM_1 = 265;
771 /** Key code constant: Generic stem key 2 for Wear
772 * @hide */
773 public static final int KEYCODE_STEM_2 = 266;
774 /** Key code constant: Generic stem key 3 for Wear
775 * @hide */
776 public static final int KEYCODE_STEM_3 = 267;
Michael Wright600b9842015-08-06 15:16:22 +0100777 /** Key code constant: Skip forward media key. */
778 public static final int KEYCODE_MEDIA_SKIP_FORWARD = 272;
779 /** Key code constant: Skip backward media key. */
780 public static final int KEYCODE_MEDIA_SKIP_BACKWARD = 273;
781 /** Key code constant: Step forward media key.
782 * Steps media forward, one frame at a time. */
783 public static final int KEYCODE_MEDIA_STEP_FORWARD = 274;
784 /** Key code constant: Step backward media key.
785 * Steps media backward, one frame at a time. */
786 public static final int KEYCODE_MEDIA_STEP_BACKWARD = 275;
Nick Armstrong-Crews56ecfcc2015-09-07 21:46:50 -0700787 /** Key code constant: put device to sleep unless a wakelock is held.
788 * @hide */
789 public static final int KEYCODE_SOFT_SLEEP = 276;
Jeff Brown497a92c2010-09-12 17:55:08 -0700790
Nick Armstrong-Crews56ecfcc2015-09-07 21:46:50 -0700791 private static final int LAST_KEYCODE = KEYCODE_SOFT_SLEEP;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800792
793 // NOTE: If you add a new keycode here you must also add it to:
794 // isSystem()
Michael Wrightdc63f7b2014-08-21 19:05:21 -0700795 // isWakeKey()
Chirayu Desai61c37ae2013-04-15 20:11:37 +0530796 // frameworks/native/include/android/keycodes.h
Jinsuk Kim96658f72014-05-14 15:33:43 +0900797 // frameworks/native/include/input/InputEventLabels.h
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800798 // frameworks/base/core/res/res/values/attrs.xml
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800799 // emulator?
Jeff Brown6651a632011-11-28 12:59:11 -0800800 // LAST_KEYCODE
Dianne Hackborn935ae462009-04-13 16:11:55 -0700801 //
802 // Also Android currently does not reserve code ranges for vendor-
803 // specific key codes. If you have new key codes to have, you
804 // MUST contribute a patch to the open source project to define
805 // those new codes. This is intended to maintain a consistent
806 // set of key code definitions across all Android devices.
Jeff Brown497a92c2010-09-12 17:55:08 -0700807
Jeff Brown497a92c2010-09-12 17:55:08 -0700808 // Symbolic names of all metakeys in bit order from least significant to most significant.
809 // Accordingly there are exactly 32 values in this table.
810 private static final String[] META_SYMBOLIC_NAMES = new String[] {
811 "META_SHIFT_ON",
812 "META_ALT_ON",
813 "META_SYM_ON",
814 "META_FUNCTION_ON",
815 "META_ALT_LEFT_ON",
816 "META_ALT_RIGHT_ON",
817 "META_SHIFT_LEFT_ON",
818 "META_SHIFT_RIGHT_ON",
819 "META_CAP_LOCKED",
820 "META_ALT_LOCKED",
821 "META_SYM_LOCKED",
822 "0x00000800",
823 "META_CTRL_ON",
824 "META_CTRL_LEFT_ON",
825 "META_CTRL_RIGHT_ON",
826 "0x00008000",
827 "META_META_ON",
828 "META_META_LEFT_ON",
829 "META_META_RIGHT_ON",
830 "0x00080000",
Jeff Brown51e7fe72010-10-29 22:19:53 -0700831 "META_CAPS_LOCK_ON",
832 "META_NUM_LOCK_ON",
833 "META_SCROLL_LOCK_ON",
Jeff Brown497a92c2010-09-12 17:55:08 -0700834 "0x00800000",
835 "0x01000000",
836 "0x02000000",
837 "0x04000000",
838 "0x08000000",
839 "0x10000000",
840 "0x20000000",
841 "0x40000000",
842 "0x80000000",
843 };
844
Michael Wright337d9d22014-04-22 15:03:48 -0700845 private static final String LABEL_PREFIX = "KEYCODE_";
846
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800847 /**
848 * @deprecated There are now more than MAX_KEYCODE keycodes.
849 * Use {@link #getMaxKeyCode()} instead.
850 */
851 @Deprecated
852 public static final int MAX_KEYCODE = 84;
853
854 /**
855 * {@link #getAction} value: the key has been pressed down.
856 */
857 public static final int ACTION_DOWN = 0;
858 /**
859 * {@link #getAction} value: the key has been released.
860 */
861 public static final int ACTION_UP = 1;
862 /**
863 * {@link #getAction} value: multiple duplicate key events have
864 * occurred in a row, or a complex string is being delivered. If the
865 * key code is not {#link {@link #KEYCODE_UNKNOWN} then the
866 * {#link {@link #getRepeatCount()} method returns the number of times
867 * the given key code should be executed.
Jeff Brown46b9ac02010-04-22 18:58:52 -0700868 * Otherwise, if the key code is {@link #KEYCODE_UNKNOWN}, then
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800869 * this is a sequence of characters as returned by {@link #getCharacters}.
870 */
871 public static final int ACTION_MULTIPLE = 2;
872
873 /**
Jeff Brown497a92c2010-09-12 17:55:08 -0700874 * SHIFT key locked in CAPS mode.
875 * Reserved for use by {@link MetaKeyKeyListener} for a published constant in its API.
876 * @hide
877 */
878 public static final int META_CAP_LOCKED = 0x100;
879
880 /**
881 * ALT key locked.
882 * Reserved for use by {@link MetaKeyKeyListener} for a published constant in its API.
883 * @hide
884 */
885 public static final int META_ALT_LOCKED = 0x200;
886
887 /**
888 * SYM key locked.
889 * Reserved for use by {@link MetaKeyKeyListener} for a published constant in its API.
890 * @hide
891 */
892 public static final int META_SYM_LOCKED = 0x400;
893
894 /**
895 * Text is in selection mode.
896 * Reserved for use by {@link MetaKeyKeyListener} for a private unpublished constant
897 * in its API that is currently being retained for legacy reasons.
898 * @hide
899 */
900 public static final int META_SELECTING = 0x800;
901
902 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800903 * <p>This mask is used to check whether one of the ALT meta keys is pressed.</p>
904 *
905 * @see #isAltPressed()
906 * @see #getMetaState()
907 * @see #KEYCODE_ALT_LEFT
908 * @see #KEYCODE_ALT_RIGHT
909 */
910 public static final int META_ALT_ON = 0x02;
911
912 /**
913 * <p>This mask is used to check whether the left ALT meta key is pressed.</p>
914 *
915 * @see #isAltPressed()
916 * @see #getMetaState()
917 * @see #KEYCODE_ALT_LEFT
918 */
919 public static final int META_ALT_LEFT_ON = 0x10;
920
921 /**
922 * <p>This mask is used to check whether the right the ALT meta key is pressed.</p>
923 *
924 * @see #isAltPressed()
925 * @see #getMetaState()
926 * @see #KEYCODE_ALT_RIGHT
927 */
928 public static final int META_ALT_RIGHT_ON = 0x20;
929
930 /**
931 * <p>This mask is used to check whether one of the SHIFT meta keys is pressed.</p>
932 *
933 * @see #isShiftPressed()
934 * @see #getMetaState()
935 * @see #KEYCODE_SHIFT_LEFT
936 * @see #KEYCODE_SHIFT_RIGHT
937 */
938 public static final int META_SHIFT_ON = 0x1;
939
940 /**
941 * <p>This mask is used to check whether the left SHIFT meta key is pressed.</p>
942 *
943 * @see #isShiftPressed()
944 * @see #getMetaState()
945 * @see #KEYCODE_SHIFT_LEFT
946 */
947 public static final int META_SHIFT_LEFT_ON = 0x40;
948
949 /**
950 * <p>This mask is used to check whether the right SHIFT meta key is pressed.</p>
951 *
952 * @see #isShiftPressed()
953 * @see #getMetaState()
954 * @see #KEYCODE_SHIFT_RIGHT
955 */
956 public static final int META_SHIFT_RIGHT_ON = 0x80;
957
958 /**
959 * <p>This mask is used to check whether the SYM meta key is pressed.</p>
960 *
961 * @see #isSymPressed()
962 * @see #getMetaState()
963 */
964 public static final int META_SYM_ON = 0x4;
965
966 /**
Jeff Brown497a92c2010-09-12 17:55:08 -0700967 * <p>This mask is used to check whether the FUNCTION meta key is pressed.</p>
968 *
969 * @see #isFunctionPressed()
970 * @see #getMetaState()
971 */
972 public static final int META_FUNCTION_ON = 0x8;
973
974 /**
975 * <p>This mask is used to check whether one of the CTRL meta keys is pressed.</p>
976 *
977 * @see #isCtrlPressed()
978 * @see #getMetaState()
979 * @see #KEYCODE_CTRL_LEFT
980 * @see #KEYCODE_CTRL_RIGHT
981 */
982 public static final int META_CTRL_ON = 0x1000;
983
984 /**
985 * <p>This mask is used to check whether the left CTRL meta key is pressed.</p>
986 *
987 * @see #isCtrlPressed()
988 * @see #getMetaState()
989 * @see #KEYCODE_CTRL_LEFT
990 */
991 public static final int META_CTRL_LEFT_ON = 0x2000;
992
993 /**
994 * <p>This mask is used to check whether the right CTRL meta key is pressed.</p>
995 *
996 * @see #isCtrlPressed()
997 * @see #getMetaState()
998 * @see #KEYCODE_CTRL_RIGHT
999 */
1000 public static final int META_CTRL_RIGHT_ON = 0x4000;
1001
1002 /**
1003 * <p>This mask is used to check whether one of the META meta keys is pressed.</p>
1004 *
1005 * @see #isMetaPressed()
1006 * @see #getMetaState()
1007 * @see #KEYCODE_META_LEFT
1008 * @see #KEYCODE_META_RIGHT
1009 */
1010 public static final int META_META_ON = 0x10000;
1011
1012 /**
1013 * <p>This mask is used to check whether the left META meta key is pressed.</p>
1014 *
1015 * @see #isMetaPressed()
1016 * @see #getMetaState()
1017 * @see #KEYCODE_META_LEFT
1018 */
1019 public static final int META_META_LEFT_ON = 0x20000;
1020
1021 /**
1022 * <p>This mask is used to check whether the right META meta key is pressed.</p>
1023 *
1024 * @see #isMetaPressed()
1025 * @see #getMetaState()
1026 * @see #KEYCODE_META_RIGHT
1027 */
1028 public static final int META_META_RIGHT_ON = 0x40000;
1029
1030 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07001031 * <p>This mask is used to check whether the CAPS LOCK meta key is on.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07001032 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07001033 * @see #isCapsLockOn()
Jeff Brown497a92c2010-09-12 17:55:08 -07001034 * @see #getMetaState()
1035 * @see #KEYCODE_CAPS_LOCK
1036 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07001037 public static final int META_CAPS_LOCK_ON = 0x100000;
Jeff Brown497a92c2010-09-12 17:55:08 -07001038
1039 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07001040 * <p>This mask is used to check whether the NUM LOCK meta key is on.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07001041 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07001042 * @see #isNumLockOn()
Jeff Brown497a92c2010-09-12 17:55:08 -07001043 * @see #getMetaState()
1044 * @see #KEYCODE_NUM_LOCK
1045 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07001046 public static final int META_NUM_LOCK_ON = 0x200000;
Jeff Brown497a92c2010-09-12 17:55:08 -07001047
1048 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07001049 * <p>This mask is used to check whether the SCROLL LOCK meta key is on.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07001050 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07001051 * @see #isScrollLockOn()
Jeff Brown497a92c2010-09-12 17:55:08 -07001052 * @see #getMetaState()
1053 * @see #KEYCODE_SCROLL_LOCK
1054 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07001055 public static final int META_SCROLL_LOCK_ON = 0x400000;
Jeff Brown497a92c2010-09-12 17:55:08 -07001056
Jeff Brown64da12a2011-01-04 19:57:47 -08001057 /**
1058 * This mask is a combination of {@link #META_SHIFT_ON}, {@link #META_SHIFT_LEFT_ON}
1059 * and {@link #META_SHIFT_RIGHT_ON}.
1060 */
Jeff Brownc1df9072010-12-21 16:38:50 -08001061 public static final int META_SHIFT_MASK = META_SHIFT_ON
1062 | META_SHIFT_LEFT_ON | META_SHIFT_RIGHT_ON;
1063
Jeff Brown64da12a2011-01-04 19:57:47 -08001064 /**
1065 * This mask is a combination of {@link #META_ALT_ON}, {@link #META_ALT_LEFT_ON}
1066 * and {@link #META_ALT_RIGHT_ON}.
1067 */
Jeff Brownc1df9072010-12-21 16:38:50 -08001068 public static final int META_ALT_MASK = META_ALT_ON
1069 | META_ALT_LEFT_ON | META_ALT_RIGHT_ON;
1070
Jeff Brown64da12a2011-01-04 19:57:47 -08001071 /**
1072 * This mask is a combination of {@link #META_CTRL_ON}, {@link #META_CTRL_LEFT_ON}
1073 * and {@link #META_CTRL_RIGHT_ON}.
1074 */
Jeff Brownc1df9072010-12-21 16:38:50 -08001075 public static final int META_CTRL_MASK = META_CTRL_ON
1076 | META_CTRL_LEFT_ON | META_CTRL_RIGHT_ON;
1077
Jeff Brown64da12a2011-01-04 19:57:47 -08001078 /**
1079 * This mask is a combination of {@link #META_META_ON}, {@link #META_META_LEFT_ON}
1080 * and {@link #META_META_RIGHT_ON}.
1081 */
1082 public static final int META_META_MASK = META_META_ON
Jeff Brownc1df9072010-12-21 16:38:50 -08001083 | META_META_LEFT_ON | META_META_RIGHT_ON;
1084
Jeff Brown497a92c2010-09-12 17:55:08 -07001085 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001086 * This mask is set if the device woke because of this key event.
Jeff Brown037c33e2014-04-09 00:31:55 -07001087 *
1088 * @deprecated This flag will never be set by the system since the system
1089 * consumes all wake keys itself.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001090 */
Jeff Brown037c33e2014-04-09 00:31:55 -07001091 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001092 public static final int FLAG_WOKE_HERE = 0x1;
RoboErik01fe6612014-02-13 14:19:04 -08001093
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001094 /**
1095 * This mask is set if the key event was generated by a software keyboard.
1096 */
1097 public static final int FLAG_SOFT_KEYBOARD = 0x2;
RoboErik01fe6612014-02-13 14:19:04 -08001098
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001099 /**
1100 * This mask is set if we don't want the key event to cause us to leave
1101 * touch mode.
1102 */
1103 public static final int FLAG_KEEP_TOUCH_MODE = 0x4;
RoboErik01fe6612014-02-13 14:19:04 -08001104
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001105 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001106 * This mask is set if an event was known to come from a trusted part
1107 * of the system. That is, the event is known to come from the user,
1108 * and could not have been spoofed by a third party component.
1109 */
1110 public static final int FLAG_FROM_SYSTEM = 0x8;
RoboErik01fe6612014-02-13 14:19:04 -08001111
The Android Open Source Project10592532009-03-18 17:39:46 -07001112 /**
1113 * This mask is used for compatibility, to identify enter keys that are
1114 * coming from an IME whose enter key has been auto-labelled "next" or
1115 * "done". This allows TextView to dispatch these as normal enter keys
1116 * for old applications, but still do the appropriate action when
1117 * receiving them.
1118 */
1119 public static final int FLAG_EDITOR_ACTION = 0x10;
RoboErik01fe6612014-02-13 14:19:04 -08001120
The Android Open Source Project10592532009-03-18 17:39:46 -07001121 /**
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001122 * When associated with up key events, this indicates that the key press
1123 * has been canceled. Typically this is used with virtual touch screen
1124 * keys, where the user can slide from the virtual key area on to the
1125 * display: in that case, the application will receive a canceled up
1126 * event and should not perform the action normally associated with the
1127 * key. Note that for this to work, the application can not perform an
1128 * action for a key until it receives an up or the long press timeout has
RoboErik01fe6612014-02-13 14:19:04 -08001129 * expired.
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001130 */
1131 public static final int FLAG_CANCELED = 0x20;
RoboErik01fe6612014-02-13 14:19:04 -08001132
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001133 /**
1134 * This key event was generated by a virtual (on-screen) hard key area.
1135 * Typically this is an area of the touchscreen, outside of the regular
1136 * display, dedicated to "hardware" buttons.
1137 */
1138 public static final int FLAG_VIRTUAL_HARD_KEY = 0x40;
RoboErik01fe6612014-02-13 14:19:04 -08001139
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07001140 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001141 * This flag is set for the first key repeat that occurs after the
1142 * long press timeout.
1143 */
1144 public static final int FLAG_LONG_PRESS = 0x80;
RoboErik01fe6612014-02-13 14:19:04 -08001145
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001146 /**
1147 * Set when a key event has {@link #FLAG_CANCELED} set because a long
RoboErik01fe6612014-02-13 14:19:04 -08001148 * press action was executed while it was down.
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001149 */
1150 public static final int FLAG_CANCELED_LONG_PRESS = 0x100;
RoboErik01fe6612014-02-13 14:19:04 -08001151
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001152 /**
1153 * Set for {@link #ACTION_UP} when this event's key code is still being
1154 * tracked from its initial down. That is, somebody requested that tracking
1155 * started on the key down and a long press has not caused
1156 * the tracking to be canceled.
1157 */
1158 public static final int FLAG_TRACKING = 0x200;
Jeff Brown49ed71d2010-12-06 17:13:33 -08001159
1160 /**
1161 * Set when a key event has been synthesized to implement default behavior
1162 * for an event that the application did not handle.
1163 * Fallback key events are generated by unhandled trackball motions
1164 * (to emulate a directional keypad) and by certain unhandled key presses
1165 * that are declared in the key map (such as special function numeric keypad
1166 * keys when numlock is off).
1167 */
1168 public static final int FLAG_FALLBACK = 0x400;
1169
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001170 /**
Michael Wrighta44dd262013-04-10 21:12:00 -07001171 * Signifies that the key is being predispatched.
1172 * @hide
1173 */
1174 public static final int FLAG_PREDISPATCH = 0x20000000;
1175
1176 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001177 * Private control to determine when an app is tracking a key sequence.
1178 * @hide
1179 */
1180 public static final int FLAG_START_TRACKING = 0x40000000;
Jeff Brown21bc5c92011-02-28 18:27:14 -08001181
1182 /**
1183 * Private flag that indicates when the system has detected that this key event
1184 * may be inconsistent with respect to the sequence of previously delivered key events,
1185 * such as when a key up event is sent but the key was not down.
1186 *
1187 * @hide
1188 * @see #isTainted
1189 * @see #setTainted
1190 */
1191 public static final int FLAG_TAINTED = 0x80000000;
1192
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001193 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001194 * Returns the maximum keycode.
1195 */
1196 public static int getMaxKeyCode() {
1197 return LAST_KEYCODE;
1198 }
1199
1200 /**
1201 * Get the character that is produced by putting accent on the character
1202 * c.
1203 * For example, getDeadChar('`', 'e') returns &egrave;.
1204 */
1205 public static int getDeadChar(int accent, int c) {
1206 return KeyCharacterMap.getDeadChar(accent, c);
1207 }
RoboErik01fe6612014-02-13 14:19:04 -08001208
Dianne Hackborn8d374262009-09-14 21:21:52 -07001209 static final boolean DEBUG = false;
1210 static final String TAG = "KeyEvent";
Jeff Brown1f245102010-11-18 20:53:46 -08001211
1212 private static final int MAX_RECYCLED = 10;
1213 private static final Object gRecyclerLock = new Object();
1214 private static int gRecyclerUsed;
1215 private static KeyEvent gRecyclerTop;
1216
1217 private KeyEvent mNext;
Jeff Brown1f245102010-11-18 20:53:46 -08001218
Jeff Brown91c69ab2011-02-14 17:03:18 -08001219 private int mDeviceId;
1220 private int mSource;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001221 private int mMetaState;
1222 private int mAction;
1223 private int mKeyCode;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001224 private int mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001225 private int mRepeatCount;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001226 private int mFlags;
1227 private long mDownTime;
1228 private long mEventTime;
1229 private String mCharacters;
1230
1231 public interface Callback {
1232 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001233 * Called when a key down event has occurred. If you return true,
1234 * you can first call {@link KeyEvent#startTracking()
1235 * KeyEvent.startTracking()} to have the framework track the event
1236 * through its {@link #onKeyUp(int, KeyEvent)} and also call your
1237 * {@link #onKeyLongPress(int, KeyEvent)} if it occurs.
RoboErik01fe6612014-02-13 14:19:04 -08001238 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001239 * @param keyCode The value in event.getKeyCode().
1240 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001241 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001242 * @return If you handled the event, return true. If you want to allow
1243 * the event to be handled by the next receiver, return false.
1244 */
1245 boolean onKeyDown(int keyCode, KeyEvent event);
1246
1247 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001248 * Called when a long press has occurred. If you return true,
1249 * the final key up will have {@link KeyEvent#FLAG_CANCELED} and
1250 * {@link KeyEvent#FLAG_CANCELED_LONG_PRESS} set. Note that in
1251 * order to receive this callback, someone in the event change
1252 * <em>must</em> return true from {@link #onKeyDown} <em>and</em>
1253 * call {@link KeyEvent#startTracking()} on the event.
RoboErik01fe6612014-02-13 14:19:04 -08001254 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001255 * @param keyCode The value in event.getKeyCode().
1256 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001257 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001258 * @return If you handled the event, return true. If you want to allow
1259 * the event to be handled by the next receiver, return false.
1260 */
1261 boolean onKeyLongPress(int keyCode, KeyEvent event);
1262
1263 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001264 * Called when a key up event has occurred.
RoboErik01fe6612014-02-13 14:19:04 -08001265 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001266 * @param keyCode The value in event.getKeyCode().
1267 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001268 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001269 * @return If you handled the event, return true. If you want to allow
1270 * the event to be handled by the next receiver, return false.
1271 */
1272 boolean onKeyUp(int keyCode, KeyEvent event);
1273
1274 /**
1275 * Called when multiple down/up pairs of the same key have occurred
1276 * in a row.
RoboErik01fe6612014-02-13 14:19:04 -08001277 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001278 * @param keyCode The value in event.getKeyCode().
1279 * @param count Number of pairs as returned by event.getRepeatCount().
1280 * @param event Description of the key event.
RoboErik01fe6612014-02-13 14:19:04 -08001281 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001282 * @return If you handled the event, return true. If you want to allow
1283 * the event to be handled by the next receiver, return false.
1284 */
1285 boolean onKeyMultiple(int keyCode, int count, KeyEvent event);
1286 }
1287
Michael Wright337d9d22014-04-22 15:03:48 -07001288 private static native String nativeKeyCodeToString(int keyCode);
1289 private static native int nativeKeyCodeFromString(String keyCode);
Jeff Brown497a92c2010-09-12 17:55:08 -07001290
Jeff Brown1f245102010-11-18 20:53:46 -08001291 private KeyEvent() {
1292 }
1293
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001294 /**
1295 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001296 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001297 * @param action Action code: either {@link #ACTION_DOWN},
1298 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1299 * @param code The key code.
1300 */
1301 public KeyEvent(int action, int code) {
1302 mAction = action;
1303 mKeyCode = code;
1304 mRepeatCount = 0;
Jeff Brown6b53e8d2010-11-10 16:03:06 -08001305 mDeviceId = KeyCharacterMap.VIRTUAL_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001306 }
1307
1308 /**
1309 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001310 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001311 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1312 * at which this key code originally went down.
1313 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1314 * at which this event happened.
1315 * @param action Action code: either {@link #ACTION_DOWN},
1316 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1317 * @param code The key code.
1318 * @param repeat A repeat count for down events (> 0 if this is after the
1319 * initial down) or event count for multiple events.
1320 */
1321 public KeyEvent(long downTime, long eventTime, int action,
1322 int code, int repeat) {
1323 mDownTime = downTime;
1324 mEventTime = eventTime;
1325 mAction = action;
1326 mKeyCode = code;
1327 mRepeatCount = repeat;
Jeff Brown6b53e8d2010-11-10 16:03:06 -08001328 mDeviceId = KeyCharacterMap.VIRTUAL_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001329 }
1330
1331 /**
1332 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001333 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001334 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1335 * at which this key code originally went down.
1336 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1337 * at which this event happened.
1338 * @param action Action code: either {@link #ACTION_DOWN},
1339 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1340 * @param code The key code.
1341 * @param repeat A repeat count for down events (> 0 if this is after the
1342 * initial down) or event count for multiple events.
1343 * @param metaState Flags indicating which meta keys are currently pressed.
1344 */
1345 public KeyEvent(long downTime, long eventTime, int action,
1346 int code, int repeat, int metaState) {
1347 mDownTime = downTime;
1348 mEventTime = eventTime;
1349 mAction = action;
1350 mKeyCode = code;
1351 mRepeatCount = repeat;
1352 mMetaState = metaState;
Jeff Brown6b53e8d2010-11-10 16:03:06 -08001353 mDeviceId = KeyCharacterMap.VIRTUAL_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001354 }
1355
1356 /**
1357 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001358 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001359 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1360 * at which this key code originally went down.
1361 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1362 * at which this event happened.
1363 * @param action Action code: either {@link #ACTION_DOWN},
1364 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1365 * @param code The key code.
1366 * @param repeat A repeat count for down events (> 0 if this is after the
1367 * initial down) or event count for multiple events.
1368 * @param metaState Flags indicating which meta keys are currently pressed.
Jeff Brownc5ed5912010-07-14 18:48:53 -07001369 * @param deviceId The device ID that generated the key event.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001370 * @param scancode Raw device scan code of the event.
1371 */
1372 public KeyEvent(long downTime, long eventTime, int action,
1373 int code, int repeat, int metaState,
Jeff Brownc5ed5912010-07-14 18:48:53 -07001374 int deviceId, int scancode) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001375 mDownTime = downTime;
1376 mEventTime = eventTime;
1377 mAction = action;
1378 mKeyCode = code;
1379 mRepeatCount = repeat;
1380 mMetaState = metaState;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001381 mDeviceId = deviceId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001382 mScanCode = scancode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001383 }
1384
1385 /**
1386 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001387 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001388 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1389 * at which this key code originally went down.
1390 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1391 * at which this event happened.
1392 * @param action Action code: either {@link #ACTION_DOWN},
1393 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1394 * @param code The key code.
1395 * @param repeat A repeat count for down events (> 0 if this is after the
1396 * initial down) or event count for multiple events.
1397 * @param metaState Flags indicating which meta keys are currently pressed.
Jeff Brownc5ed5912010-07-14 18:48:53 -07001398 * @param deviceId The device ID that generated the key event.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001399 * @param scancode Raw device scan code of the event.
1400 * @param flags The flags for this key event
1401 */
1402 public KeyEvent(long downTime, long eventTime, int action,
1403 int code, int repeat, int metaState,
Jeff Brownc5ed5912010-07-14 18:48:53 -07001404 int deviceId, int scancode, int flags) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001405 mDownTime = downTime;
1406 mEventTime = eventTime;
1407 mAction = action;
1408 mKeyCode = code;
1409 mRepeatCount = repeat;
1410 mMetaState = metaState;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001411 mDeviceId = deviceId;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001412 mScanCode = scancode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001413 mFlags = flags;
1414 }
1415
1416 /**
Jeff Brownc5ed5912010-07-14 18:48:53 -07001417 * Create a new key event.
RoboErik01fe6612014-02-13 14:19:04 -08001418 *
Jeff Brownc5ed5912010-07-14 18:48:53 -07001419 * @param downTime The time (in {@link android.os.SystemClock#uptimeMillis})
1420 * at which this key code originally went down.
1421 * @param eventTime The time (in {@link android.os.SystemClock#uptimeMillis})
1422 * at which this event happened.
1423 * @param action Action code: either {@link #ACTION_DOWN},
1424 * {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
1425 * @param code The key code.
1426 * @param repeat A repeat count for down events (> 0 if this is after the
1427 * initial down) or event count for multiple events.
1428 * @param metaState Flags indicating which meta keys are currently pressed.
1429 * @param deviceId The device ID that generated the key event.
1430 * @param scancode Raw device scan code of the event.
1431 * @param flags The flags for this key event
1432 * @param source The input source such as {@link InputDevice#SOURCE_KEYBOARD}.
1433 */
1434 public KeyEvent(long downTime, long eventTime, int action,
1435 int code, int repeat, int metaState,
1436 int deviceId, int scancode, int flags, int source) {
1437 mDownTime = downTime;
1438 mEventTime = eventTime;
1439 mAction = action;
1440 mKeyCode = code;
1441 mRepeatCount = repeat;
1442 mMetaState = metaState;
1443 mDeviceId = deviceId;
1444 mScanCode = scancode;
1445 mFlags = flags;
1446 mSource = source;
1447 }
1448
1449 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001450 * Create a new key event for a string of characters. The key code,
Jeff Brownc5ed5912010-07-14 18:48:53 -07001451 * action, repeat count and source will automatically be set to
1452 * {@link #KEYCODE_UNKNOWN}, {@link #ACTION_MULTIPLE}, 0, and
1453 * {@link InputDevice#SOURCE_KEYBOARD} for you.
RoboErik01fe6612014-02-13 14:19:04 -08001454 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001455 * @param time The time (in {@link android.os.SystemClock#uptimeMillis})
1456 * at which this event occured.
1457 * @param characters The string of characters.
Jeff Brownc5ed5912010-07-14 18:48:53 -07001458 * @param deviceId The device ID that generated the key event.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001459 * @param flags The flags for this key event
1460 */
Jeff Brownc5ed5912010-07-14 18:48:53 -07001461 public KeyEvent(long time, String characters, int deviceId, int flags) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001462 mDownTime = time;
1463 mEventTime = time;
1464 mCharacters = characters;
1465 mAction = ACTION_MULTIPLE;
1466 mKeyCode = KEYCODE_UNKNOWN;
1467 mRepeatCount = 0;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001468 mDeviceId = deviceId;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001469 mFlags = flags;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001470 mSource = InputDevice.SOURCE_KEYBOARD;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001471 }
1472
1473 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001474 * Make an exact copy of an existing key event.
1475 */
1476 public KeyEvent(KeyEvent origEvent) {
1477 mDownTime = origEvent.mDownTime;
1478 mEventTime = origEvent.mEventTime;
1479 mAction = origEvent.mAction;
1480 mKeyCode = origEvent.mKeyCode;
1481 mRepeatCount = origEvent.mRepeatCount;
1482 mMetaState = origEvent.mMetaState;
1483 mDeviceId = origEvent.mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001484 mSource = origEvent.mSource;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001485 mScanCode = origEvent.mScanCode;
The Android Open Source Project10592532009-03-18 17:39:46 -07001486 mFlags = origEvent.mFlags;
1487 mCharacters = origEvent.mCharacters;
1488 }
1489
1490 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001491 * Copy an existing key event, modifying its time and repeat count.
RoboErik01fe6612014-02-13 14:19:04 -08001492 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001493 * @deprecated Use {@link #changeTimeRepeat(KeyEvent, long, int)}
1494 * instead.
RoboErik01fe6612014-02-13 14:19:04 -08001495 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001496 * @param origEvent The existing event to be copied.
1497 * @param eventTime The new event time
1498 * (in {@link android.os.SystemClock#uptimeMillis}) of the event.
1499 * @param newRepeat The new repeat count of the event.
1500 */
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001501 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001502 public KeyEvent(KeyEvent origEvent, long eventTime, int newRepeat) {
1503 mDownTime = origEvent.mDownTime;
1504 mEventTime = eventTime;
1505 mAction = origEvent.mAction;
1506 mKeyCode = origEvent.mKeyCode;
1507 mRepeatCount = newRepeat;
1508 mMetaState = origEvent.mMetaState;
1509 mDeviceId = origEvent.mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001510 mSource = origEvent.mSource;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001511 mScanCode = origEvent.mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001512 mFlags = origEvent.mFlags;
1513 mCharacters = origEvent.mCharacters;
1514 }
1515
Jeff Brown1f245102010-11-18 20:53:46 -08001516 private static KeyEvent obtain() {
1517 final KeyEvent ev;
1518 synchronized (gRecyclerLock) {
1519 ev = gRecyclerTop;
1520 if (ev == null) {
1521 return new KeyEvent();
1522 }
1523 gRecyclerTop = ev.mNext;
1524 gRecyclerUsed -= 1;
1525 }
Jeff Brown1f245102010-11-18 20:53:46 -08001526 ev.mNext = null;
Jeff Brown32cbc38552011-12-01 14:01:49 -08001527 ev.prepareForReuse();
Jeff Brown1f245102010-11-18 20:53:46 -08001528 return ev;
1529 }
1530
1531 /**
1532 * Obtains a (potentially recycled) key event.
1533 *
1534 * @hide
1535 */
1536 public static KeyEvent obtain(long downTime, long eventTime, int action,
1537 int code, int repeat, int metaState,
1538 int deviceId, int scancode, int flags, int source, String characters) {
1539 KeyEvent ev = obtain();
1540 ev.mDownTime = downTime;
1541 ev.mEventTime = eventTime;
1542 ev.mAction = action;
1543 ev.mKeyCode = code;
1544 ev.mRepeatCount = repeat;
1545 ev.mMetaState = metaState;
1546 ev.mDeviceId = deviceId;
1547 ev.mScanCode = scancode;
1548 ev.mFlags = flags;
1549 ev.mSource = source;
1550 ev.mCharacters = characters;
1551 return ev;
1552 }
1553
1554 /**
Jeff Brown21bc5c92011-02-28 18:27:14 -08001555 * Obtains a (potentially recycled) copy of another key event.
1556 *
1557 * @hide
1558 */
1559 public static KeyEvent obtain(KeyEvent other) {
1560 KeyEvent ev = obtain();
1561 ev.mDownTime = other.mDownTime;
1562 ev.mEventTime = other.mEventTime;
1563 ev.mAction = other.mAction;
1564 ev.mKeyCode = other.mKeyCode;
1565 ev.mRepeatCount = other.mRepeatCount;
1566 ev.mMetaState = other.mMetaState;
1567 ev.mDeviceId = other.mDeviceId;
1568 ev.mScanCode = other.mScanCode;
1569 ev.mFlags = other.mFlags;
1570 ev.mSource = other.mSource;
1571 ev.mCharacters = other.mCharacters;
1572 return ev;
1573 }
1574
1575 /** @hide */
1576 @Override
1577 public KeyEvent copy() {
1578 return obtain(this);
1579 }
1580
1581 /**
Jeff Brown1f245102010-11-18 20:53:46 -08001582 * Recycles a key event.
1583 * Key events should only be recycled if they are owned by the system since user
1584 * code expects them to be essentially immutable, "tracking" notwithstanding.
1585 *
1586 * @hide
1587 */
Jeff Brown92cc2d82011-12-02 01:19:47 -08001588 @Override
Jeff Brown1f245102010-11-18 20:53:46 -08001589 public final void recycle() {
Jeff Brown32cbc38552011-12-01 14:01:49 -08001590 super.recycle();
Jeff Brown1f245102010-11-18 20:53:46 -08001591 mCharacters = null;
1592
1593 synchronized (gRecyclerLock) {
1594 if (gRecyclerUsed < MAX_RECYCLED) {
1595 gRecyclerUsed++;
1596 mNext = gRecyclerTop;
1597 gRecyclerTop = this;
1598 }
1599 }
1600 }
1601
Jeff Brown92cc2d82011-12-02 01:19:47 -08001602 /** @hide */
1603 @Override
1604 public final void recycleIfNeededAfterDispatch() {
1605 // Do nothing.
1606 }
1607
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001608 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001609 * Create a new key event that is the same as the given one, but whose
1610 * event time and repeat count are replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001611 *
The Android Open Source Project10592532009-03-18 17:39:46 -07001612 * @param event The existing event to be copied. This is not modified.
1613 * @param eventTime The new event time
1614 * (in {@link android.os.SystemClock#uptimeMillis}) of the event.
1615 * @param newRepeat The new repeat count of the event.
1616 */
1617 public static KeyEvent changeTimeRepeat(KeyEvent event, long eventTime,
1618 int newRepeat) {
1619 return new KeyEvent(event, eventTime, newRepeat);
1620 }
RoboErik01fe6612014-02-13 14:19:04 -08001621
The Android Open Source Project10592532009-03-18 17:39:46 -07001622 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001623 * Create a new key event that is the same as the given one, but whose
1624 * event time and repeat count are replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001625 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001626 * @param event The existing event to be copied. This is not modified.
1627 * @param eventTime The new event time
1628 * (in {@link android.os.SystemClock#uptimeMillis}) of the event.
1629 * @param newRepeat The new repeat count of the event.
1630 * @param newFlags New flags for the event, replacing the entire value
1631 * in the original event.
1632 */
1633 public static KeyEvent changeTimeRepeat(KeyEvent event, long eventTime,
1634 int newRepeat, int newFlags) {
1635 KeyEvent ret = new KeyEvent(event);
1636 ret.mEventTime = eventTime;
1637 ret.mRepeatCount = newRepeat;
1638 ret.mFlags = newFlags;
1639 return ret;
1640 }
RoboErik01fe6612014-02-13 14:19:04 -08001641
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07001642 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001643 * Copy an existing key event, modifying its action.
RoboErik01fe6612014-02-13 14:19:04 -08001644 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001645 * @param origEvent The existing event to be copied.
1646 * @param action The new action code of the event.
1647 */
The Android Open Source Project10592532009-03-18 17:39:46 -07001648 private KeyEvent(KeyEvent origEvent, int action) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001649 mDownTime = origEvent.mDownTime;
1650 mEventTime = origEvent.mEventTime;
1651 mAction = action;
1652 mKeyCode = origEvent.mKeyCode;
1653 mRepeatCount = origEvent.mRepeatCount;
1654 mMetaState = origEvent.mMetaState;
1655 mDeviceId = origEvent.mDeviceId;
Jeff Brownc5ed5912010-07-14 18:48:53 -07001656 mSource = origEvent.mSource;
Jeff Brown46b9ac02010-04-22 18:58:52 -07001657 mScanCode = origEvent.mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001658 mFlags = origEvent.mFlags;
1659 // Don't copy mCharacters, since one way or the other we'll lose it
1660 // when changing the action.
1661 }
1662
1663 /**
The Android Open Source Project10592532009-03-18 17:39:46 -07001664 * Create a new key event that is the same as the given one, but whose
1665 * action is replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001666 *
The Android Open Source Project10592532009-03-18 17:39:46 -07001667 * @param event The existing event to be copied. This is not modified.
1668 * @param action The new action code of the event.
1669 */
1670 public static KeyEvent changeAction(KeyEvent event, int action) {
1671 return new KeyEvent(event, action);
1672 }
RoboErik01fe6612014-02-13 14:19:04 -08001673
The Android Open Source Project10592532009-03-18 17:39:46 -07001674 /**
1675 * Create a new key event that is the same as the given one, but whose
1676 * flags are replaced with the given value.
RoboErik01fe6612014-02-13 14:19:04 -08001677 *
The Android Open Source Project10592532009-03-18 17:39:46 -07001678 * @param event The existing event to be copied. This is not modified.
1679 * @param flags The new flags constant.
1680 */
1681 public static KeyEvent changeFlags(KeyEvent event, int flags) {
1682 event = new KeyEvent(event);
1683 event.mFlags = flags;
1684 return event;
1685 }
Jeff Brown21bc5c92011-02-28 18:27:14 -08001686
1687 /** @hide */
1688 @Override
1689 public final boolean isTainted() {
1690 return (mFlags & FLAG_TAINTED) != 0;
1691 }
1692
1693 /** @hide */
1694 @Override
1695 public final void setTainted(boolean tainted) {
1696 mFlags = tainted ? mFlags | FLAG_TAINTED : mFlags & ~FLAG_TAINTED;
1697 }
1698
The Android Open Source Project10592532009-03-18 17:39:46 -07001699 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001700 * Don't use in new code, instead explicitly check
1701 * {@link #getAction()}.
RoboErik01fe6612014-02-13 14:19:04 -08001702 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001703 * @return If the action is ACTION_DOWN, returns true; else false.
1704 *
1705 * @deprecated
1706 * @hide
1707 */
1708 @Deprecated public final boolean isDown() {
1709 return mAction == ACTION_DOWN;
1710 }
1711
Michael Wright337d9d22014-04-22 15:03:48 -07001712 /** Is this a system key? System keys can not be used for menu shortcuts.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001713 */
1714 public final boolean isSystem() {
Michael Wright337d9d22014-04-22 15:03:48 -07001715 return isSystemKey(mKeyCode);
Dianne Hackborn3c80a4a2010-06-29 19:20:40 -07001716 }
1717
1718 /** @hide */
Michael Wright337d9d22014-04-22 15:03:48 -07001719 public final boolean isWakeKey() {
1720 return isWakeKey(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001721 }
1722
Jeff Brown6f2fba42011-02-19 01:08:02 -08001723 /**
1724 * Returns true if the specified keycode is a gamepad button.
1725 * @return True if the keycode is a gamepad button, such as {@link #KEYCODE_BUTTON_A}.
1726 */
1727 public static final boolean isGamepadButton(int keyCode) {
1728 switch (keyCode) {
1729 case KeyEvent.KEYCODE_BUTTON_A:
1730 case KeyEvent.KEYCODE_BUTTON_B:
1731 case KeyEvent.KEYCODE_BUTTON_C:
1732 case KeyEvent.KEYCODE_BUTTON_X:
1733 case KeyEvent.KEYCODE_BUTTON_Y:
1734 case KeyEvent.KEYCODE_BUTTON_Z:
1735 case KeyEvent.KEYCODE_BUTTON_L1:
1736 case KeyEvent.KEYCODE_BUTTON_R1:
1737 case KeyEvent.KEYCODE_BUTTON_L2:
1738 case KeyEvent.KEYCODE_BUTTON_R2:
1739 case KeyEvent.KEYCODE_BUTTON_THUMBL:
1740 case KeyEvent.KEYCODE_BUTTON_THUMBR:
1741 case KeyEvent.KEYCODE_BUTTON_START:
1742 case KeyEvent.KEYCODE_BUTTON_SELECT:
1743 case KeyEvent.KEYCODE_BUTTON_MODE:
1744 case KeyEvent.KEYCODE_BUTTON_1:
1745 case KeyEvent.KEYCODE_BUTTON_2:
1746 case KeyEvent.KEYCODE_BUTTON_3:
1747 case KeyEvent.KEYCODE_BUTTON_4:
1748 case KeyEvent.KEYCODE_BUTTON_5:
1749 case KeyEvent.KEYCODE_BUTTON_6:
1750 case KeyEvent.KEYCODE_BUTTON_7:
1751 case KeyEvent.KEYCODE_BUTTON_8:
1752 case KeyEvent.KEYCODE_BUTTON_9:
1753 case KeyEvent.KEYCODE_BUTTON_10:
1754 case KeyEvent.KEYCODE_BUTTON_11:
1755 case KeyEvent.KEYCODE_BUTTON_12:
1756 case KeyEvent.KEYCODE_BUTTON_13:
1757 case KeyEvent.KEYCODE_BUTTON_14:
1758 case KeyEvent.KEYCODE_BUTTON_15:
1759 case KeyEvent.KEYCODE_BUTTON_16:
1760 return true;
1761 default:
1762 return false;
1763 }
1764 }
1765
Michael Wright25b0c302013-07-10 12:54:06 -07001766 /** Whether key will, by default, trigger a click on the focused view.
1767 * @hide
1768 */
1769 public static final boolean isConfirmKey(int keyCode) {
1770 switch (keyCode) {
1771 case KeyEvent.KEYCODE_DPAD_CENTER:
1772 case KeyEvent.KEYCODE_ENTER:
1773 return true;
1774 default:
1775 return false;
1776 }
1777 }
1778
RoboErik01fe6612014-02-13 14:19:04 -08001779 /**
1780 * Whether this key is a media key, which can be send to apps that are
1781 * interested in media key events.
1782 *
1783 * @hide
1784 */
1785 public static final boolean isMediaKey(int keyCode) {
1786 switch (keyCode) {
1787 case KeyEvent.KEYCODE_MEDIA_PLAY:
1788 case KeyEvent.KEYCODE_MEDIA_PAUSE:
1789 case KeyEvent.KEYCODE_MEDIA_PLAY_PAUSE:
1790 case KeyEvent.KEYCODE_MUTE:
1791 case KeyEvent.KEYCODE_HEADSETHOOK:
1792 case KeyEvent.KEYCODE_MEDIA_STOP:
1793 case KeyEvent.KEYCODE_MEDIA_NEXT:
1794 case KeyEvent.KEYCODE_MEDIA_PREVIOUS:
1795 case KeyEvent.KEYCODE_MEDIA_REWIND:
1796 case KeyEvent.KEYCODE_MEDIA_RECORD:
1797 case KeyEvent.KEYCODE_MEDIA_FAST_FORWARD:
1798 return true;
1799 }
1800 return false;
1801 }
1802
Michael Wright337d9d22014-04-22 15:03:48 -07001803
1804 /** Is this a system key? System keys can not be used for menu shortcuts.
1805 * @hide
1806 */
1807 public static final boolean isSystemKey(int keyCode) {
1808 switch (keyCode) {
1809 case KeyEvent.KEYCODE_MENU:
1810 case KeyEvent.KEYCODE_SOFT_RIGHT:
1811 case KeyEvent.KEYCODE_HOME:
1812 case KeyEvent.KEYCODE_BACK:
1813 case KeyEvent.KEYCODE_CALL:
1814 case KeyEvent.KEYCODE_ENDCALL:
1815 case KeyEvent.KEYCODE_VOLUME_UP:
1816 case KeyEvent.KEYCODE_VOLUME_DOWN:
1817 case KeyEvent.KEYCODE_VOLUME_MUTE:
1818 case KeyEvent.KEYCODE_MUTE:
1819 case KeyEvent.KEYCODE_POWER:
1820 case KeyEvent.KEYCODE_HEADSETHOOK:
1821 case KeyEvent.KEYCODE_MEDIA_PLAY:
1822 case KeyEvent.KEYCODE_MEDIA_PAUSE:
1823 case KeyEvent.KEYCODE_MEDIA_PLAY_PAUSE:
1824 case KeyEvent.KEYCODE_MEDIA_STOP:
1825 case KeyEvent.KEYCODE_MEDIA_NEXT:
1826 case KeyEvent.KEYCODE_MEDIA_PREVIOUS:
1827 case KeyEvent.KEYCODE_MEDIA_REWIND:
1828 case KeyEvent.KEYCODE_MEDIA_RECORD:
1829 case KeyEvent.KEYCODE_MEDIA_FAST_FORWARD:
1830 case KeyEvent.KEYCODE_CAMERA:
1831 case KeyEvent.KEYCODE_FOCUS:
1832 case KeyEvent.KEYCODE_SEARCH:
1833 case KeyEvent.KEYCODE_BRIGHTNESS_DOWN:
1834 case KeyEvent.KEYCODE_BRIGHTNESS_UP:
1835 case KeyEvent.KEYCODE_MEDIA_AUDIO_TRACK:
Michael Wright337d9d22014-04-22 15:03:48 -07001836 return true;
1837 }
1838
1839 return false;
1840 }
1841
1842 /** @hide */
1843 public static final boolean isWakeKey(int keyCode) {
1844 switch (keyCode) {
1845 case KeyEvent.KEYCODE_BACK:
Michael Wright337d9d22014-04-22 15:03:48 -07001846 case KeyEvent.KEYCODE_MENU:
Michael Wright337d9d22014-04-22 15:03:48 -07001847 case KeyEvent.KEYCODE_WAKEUP:
Michael Wright8ac485a2014-06-04 12:38:18 -07001848 case KeyEvent.KEYCODE_PAIRING:
Michael Wright337d9d22014-04-22 15:03:48 -07001849 return true;
1850 }
1851 return false;
1852 }
1853
Michael Wrightce0c13a2014-07-30 10:49:21 -07001854 /** @hide */
1855 public static final boolean isMetaKey(int keyCode) {
1856 return keyCode == KeyEvent.KEYCODE_META_LEFT || keyCode == KeyEvent.KEYCODE_META_RIGHT;
1857 }
1858
Jeff Brown91c69ab2011-02-14 17:03:18 -08001859 /** {@inheritDoc} */
1860 @Override
1861 public final int getDeviceId() {
1862 return mDeviceId;
1863 }
1864
1865 /** {@inheritDoc} */
1866 @Override
1867 public final int getSource() {
1868 return mSource;
1869 }
1870
1871 /** {@inheritDoc} */
1872 @Override
1873 public final void setSource(int source) {
1874 mSource = source;
1875 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001876
1877 /**
1878 * <p>Returns the state of the meta keys.</p>
1879 *
1880 * @return an integer in which each bit set to 1 represents a pressed
1881 * meta key
1882 *
1883 * @see #isAltPressed()
1884 * @see #isShiftPressed()
1885 * @see #isSymPressed()
Jeff Brown497a92c2010-09-12 17:55:08 -07001886 * @see #isCtrlPressed()
1887 * @see #isMetaPressed()
1888 * @see #isFunctionPressed()
Jeff Brown51e7fe72010-10-29 22:19:53 -07001889 * @see #isCapsLockOn()
1890 * @see #isNumLockOn()
1891 * @see #isScrollLockOn()
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001892 * @see #META_ALT_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07001893 * @see #META_ALT_LEFT_ON
1894 * @see #META_ALT_RIGHT_ON
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001895 * @see #META_SHIFT_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07001896 * @see #META_SHIFT_LEFT_ON
1897 * @see #META_SHIFT_RIGHT_ON
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001898 * @see #META_SYM_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07001899 * @see #META_FUNCTION_ON
1900 * @see #META_CTRL_ON
1901 * @see #META_CTRL_LEFT_ON
1902 * @see #META_CTRL_RIGHT_ON
1903 * @see #META_META_ON
1904 * @see #META_META_LEFT_ON
1905 * @see #META_META_RIGHT_ON
Jeff Brown51e7fe72010-10-29 22:19:53 -07001906 * @see #META_CAPS_LOCK_ON
1907 * @see #META_NUM_LOCK_ON
1908 * @see #META_SCROLL_LOCK_ON
Jeff Brown54875002011-04-06 15:33:01 -07001909 * @see #getModifiers
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001910 */
1911 public final int getMetaState() {
1912 return mMetaState;
1913 }
1914
1915 /**
Jeff Brown54875002011-04-06 15:33:01 -07001916 * Returns the state of the modifier keys.
1917 * <p>
1918 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
1919 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
1920 * not considered modifier keys. Consequently, this function specifically masks out
1921 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
1922 * </p><p>
1923 * The value returned consists of the meta state (from {@link #getMetaState})
1924 * normalized using {@link #normalizeMetaState(int)} and then masked with
1925 * {@link #getModifierMetaStateMask} so that only valid modifier bits are retained.
1926 * </p>
1927 *
1928 * @return An integer in which each bit set to 1 represents a pressed modifier key.
1929 * @see #getMetaState
1930 */
1931 public final int getModifiers() {
1932 return normalizeMetaState(mMetaState) & META_MODIFIER_MASK;
1933 }
1934
1935 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001936 * Returns the flags for this key event.
1937 *
1938 * @see #FLAG_WOKE_HERE
1939 */
1940 public final int getFlags() {
1941 return mFlags;
1942 }
1943
Jeff Brown28cbf4b2010-12-13 10:33:20 -08001944 // Mask of all modifier key meta states. Specifically excludes locked keys like caps lock.
1945 private static final int META_MODIFIER_MASK =
1946 META_SHIFT_ON | META_SHIFT_LEFT_ON | META_SHIFT_RIGHT_ON
1947 | META_ALT_ON | META_ALT_LEFT_ON | META_ALT_RIGHT_ON
1948 | META_CTRL_ON | META_CTRL_LEFT_ON | META_CTRL_RIGHT_ON
1949 | META_META_ON | META_META_LEFT_ON | META_META_RIGHT_ON
1950 | META_SYM_ON | META_FUNCTION_ON;
1951
1952 // Mask of all lock key meta states.
1953 private static final int META_LOCK_MASK =
1954 META_CAPS_LOCK_ON | META_NUM_LOCK_ON | META_SCROLL_LOCK_ON;
1955
1956 // Mask of all valid meta states.
1957 private static final int META_ALL_MASK = META_MODIFIER_MASK | META_LOCK_MASK;
1958
1959 // Mask of all synthetic meta states that are reserved for API compatibility with
1960 // historical uses in MetaKeyKeyListener.
1961 private static final int META_SYNTHETIC_MASK =
1962 META_CAP_LOCKED | META_ALT_LOCKED | META_SYM_LOCKED | META_SELECTING;
1963
1964 // Mask of all meta states that are not valid use in specifying a modifier key.
1965 // These bits are known to be used for purposes other than specifying modifiers.
1966 private static final int META_INVALID_MODIFIER_MASK =
1967 META_LOCK_MASK | META_SYNTHETIC_MASK;
1968
1969 /**
1970 * Gets a mask that includes all valid modifier key meta state bits.
1971 * <p>
1972 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
1973 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
1974 * not considered modifier keys. Consequently, the mask specifically excludes
1975 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
1976 * </p>
1977 *
1978 * @return The modifier meta state mask which is a combination of
1979 * {@link #META_SHIFT_ON}, {@link #META_SHIFT_LEFT_ON}, {@link #META_SHIFT_RIGHT_ON},
1980 * {@link #META_ALT_ON}, {@link #META_ALT_LEFT_ON}, {@link #META_ALT_RIGHT_ON},
1981 * {@link #META_CTRL_ON}, {@link #META_CTRL_LEFT_ON}, {@link #META_CTRL_RIGHT_ON},
1982 * {@link #META_META_ON}, {@link #META_META_LEFT_ON}, {@link #META_META_RIGHT_ON},
1983 * {@link #META_SYM_ON}, {@link #META_FUNCTION_ON}.
1984 */
1985 public static int getModifierMetaStateMask() {
1986 return META_MODIFIER_MASK;
1987 }
1988
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001989 /**
1990 * Returns true if this key code is a modifier key.
Jeff Brown28cbf4b2010-12-13 10:33:20 -08001991 * <p>
1992 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
1993 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
1994 * not considered modifier keys. Consequently, this function return false
1995 * for those keys.
1996 * </p>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001997 *
Jeff Brown28cbf4b2010-12-13 10:33:20 -08001998 * @return True if the key code is one of
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001999 * {@link #KEYCODE_SHIFT_LEFT} {@link #KEYCODE_SHIFT_RIGHT},
Jeff Brown497a92c2010-09-12 17:55:08 -07002000 * {@link #KEYCODE_ALT_LEFT}, {@link #KEYCODE_ALT_RIGHT},
Jeff Brown497a92c2010-09-12 17:55:08 -07002001 * {@link #KEYCODE_CTRL_LEFT}, {@link #KEYCODE_CTRL_RIGHT},
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002002 * {@link #KEYCODE_META_LEFT}, or {@link #KEYCODE_META_RIGHT},
2003 * {@link #KEYCODE_SYM}, {@link #KEYCODE_NUM}, {@link #KEYCODE_FUNCTION}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002004 */
2005 public static boolean isModifierKey(int keyCode) {
Jeff Brown497a92c2010-09-12 17:55:08 -07002006 switch (keyCode) {
2007 case KEYCODE_SHIFT_LEFT:
2008 case KEYCODE_SHIFT_RIGHT:
2009 case KEYCODE_ALT_LEFT:
2010 case KEYCODE_ALT_RIGHT:
Jeff Brown497a92c2010-09-12 17:55:08 -07002011 case KEYCODE_CTRL_LEFT:
2012 case KEYCODE_CTRL_RIGHT:
2013 case KEYCODE_META_LEFT:
2014 case KEYCODE_META_RIGHT:
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002015 case KEYCODE_SYM:
2016 case KEYCODE_NUM:
2017 case KEYCODE_FUNCTION:
Jeff Brown497a92c2010-09-12 17:55:08 -07002018 return true;
2019 default:
2020 return false;
2021 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002022 }
2023
2024 /**
Jeff Brown28cbf4b2010-12-13 10:33:20 -08002025 * Normalizes the specified meta state.
2026 * <p>
2027 * The meta state is normalized such that if either the left or right modifier meta state
2028 * bits are set then the result will also include the universal bit for that modifier.
2029 * </p><p>
2030 * If the specified meta state contains {@link #META_ALT_LEFT_ON} then
2031 * the result will also contain {@link #META_ALT_ON} in addition to {@link #META_ALT_LEFT_ON}
2032 * and the other bits that were specified in the input. The same is process is
2033 * performed for shift, control and meta.
2034 * </p><p>
2035 * If the specified meta state contains synthetic meta states defined by
2036 * {@link MetaKeyKeyListener}, then those states are translated here and the original
2037 * synthetic meta states are removed from the result.
2038 * {@link MetaKeyKeyListener#META_CAP_LOCKED} is translated to {@link #META_CAPS_LOCK_ON}.
2039 * {@link MetaKeyKeyListener#META_ALT_LOCKED} is translated to {@link #META_ALT_ON}.
2040 * {@link MetaKeyKeyListener#META_SYM_LOCKED} is translated to {@link #META_SYM_ON}.
2041 * </p><p>
2042 * Undefined meta state bits are removed.
2043 * </p>
2044 *
2045 * @param metaState The meta state.
2046 * @return The normalized meta state.
2047 */
2048 public static int normalizeMetaState(int metaState) {
2049 if ((metaState & (META_SHIFT_LEFT_ON | META_SHIFT_RIGHT_ON)) != 0) {
2050 metaState |= META_SHIFT_ON;
2051 }
2052 if ((metaState & (META_ALT_LEFT_ON | META_ALT_RIGHT_ON)) != 0) {
2053 metaState |= META_ALT_ON;
2054 }
2055 if ((metaState & (META_CTRL_LEFT_ON | META_CTRL_RIGHT_ON)) != 0) {
2056 metaState |= META_CTRL_ON;
2057 }
2058 if ((metaState & (META_META_LEFT_ON | META_META_RIGHT_ON)) != 0) {
2059 metaState |= META_META_ON;
2060 }
2061 if ((metaState & MetaKeyKeyListener.META_CAP_LOCKED) != 0) {
2062 metaState |= META_CAPS_LOCK_ON;
2063 }
2064 if ((metaState & MetaKeyKeyListener.META_ALT_LOCKED) != 0) {
2065 metaState |= META_ALT_ON;
2066 }
2067 if ((metaState & MetaKeyKeyListener.META_SYM_LOCKED) != 0) {
2068 metaState |= META_SYM_ON;
2069 }
2070 return metaState & META_ALL_MASK;
2071 }
2072
2073 /**
2074 * Returns true if no modifiers keys are pressed according to the specified meta state.
2075 * <p>
2076 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2077 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2078 * not considered modifier keys. Consequently, this function ignores
2079 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2080 * </p><p>
2081 * The meta state is normalized prior to comparison using {@link #normalizeMetaState(int)}.
2082 * </p>
2083 *
2084 * @param metaState The meta state to consider.
2085 * @return True if no modifier keys are pressed.
2086 * @see #hasNoModifiers()
2087 */
2088 public static boolean metaStateHasNoModifiers(int metaState) {
2089 return (normalizeMetaState(metaState) & META_MODIFIER_MASK) == 0;
2090 }
2091
2092 /**
2093 * Returns true if only the specified modifier keys are pressed according to
2094 * the specified meta state. Returns false if a different combination of modifier
2095 * keys are pressed.
2096 * <p>
2097 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2098 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2099 * not considered modifier keys. Consequently, this function ignores
2100 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2101 * </p><p>
2102 * If the specified modifier mask includes directional modifiers, such as
2103 * {@link #META_SHIFT_LEFT_ON}, then this method ensures that the
2104 * modifier is pressed on that side.
2105 * If the specified modifier mask includes non-directional modifiers, such as
2106 * {@link #META_SHIFT_ON}, then this method ensures that the modifier
2107 * is pressed on either side.
2108 * If the specified modifier mask includes both directional and non-directional modifiers
2109 * for the same type of key, such as {@link #META_SHIFT_ON} and {@link #META_SHIFT_LEFT_ON},
2110 * then this method throws an illegal argument exception.
2111 * </p>
2112 *
2113 * @param metaState The meta state to consider.
2114 * @param modifiers The meta state of the modifier keys to check. May be a combination
2115 * of modifier meta states as defined by {@link #getModifierMetaStateMask()}. May be 0 to
2116 * ensure that no modifier keys are pressed.
2117 * @return True if only the specified modifier keys are pressed.
2118 * @throws IllegalArgumentException if the modifiers parameter contains invalid modifiers
2119 * @see #hasModifiers
2120 */
2121 public static boolean metaStateHasModifiers(int metaState, int modifiers) {
2122 // Note: For forward compatibility, we allow the parameter to contain meta states
2123 // that we do not recognize but we explicitly disallow meta states that
2124 // are not valid modifiers.
2125 if ((modifiers & META_INVALID_MODIFIER_MASK) != 0) {
2126 throw new IllegalArgumentException("modifiers must not contain "
2127 + "META_CAPS_LOCK_ON, META_NUM_LOCK_ON, META_SCROLL_LOCK_ON, "
2128 + "META_CAP_LOCKED, META_ALT_LOCKED, META_SYM_LOCKED, "
2129 + "or META_SELECTING");
2130 }
2131
2132 metaState = normalizeMetaState(metaState) & META_MODIFIER_MASK;
2133 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2134 META_SHIFT_ON, META_SHIFT_LEFT_ON, META_SHIFT_RIGHT_ON);
2135 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2136 META_ALT_ON, META_ALT_LEFT_ON, META_ALT_RIGHT_ON);
2137 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2138 META_CTRL_ON, META_CTRL_LEFT_ON, META_CTRL_RIGHT_ON);
2139 metaState = metaStateFilterDirectionalModifiers(metaState, modifiers,
2140 META_META_ON, META_META_LEFT_ON, META_META_RIGHT_ON);
2141 return metaState == modifiers;
2142 }
2143
2144 private static int metaStateFilterDirectionalModifiers(int metaState,
2145 int modifiers, int basic, int left, int right) {
2146 final boolean wantBasic = (modifiers & basic) != 0;
2147 final int directional = left | right;
2148 final boolean wantLeftOrRight = (modifiers & directional) != 0;
2149
2150 if (wantBasic) {
2151 if (wantLeftOrRight) {
2152 throw new IllegalArgumentException("modifiers must not contain "
2153 + metaStateToString(basic) + " combined with "
2154 + metaStateToString(left) + " or " + metaStateToString(right));
2155 }
2156 return metaState & ~directional;
2157 } else if (wantLeftOrRight) {
2158 return metaState & ~basic;
2159 } else {
2160 return metaState;
2161 }
2162 }
2163
2164 /**
2165 * Returns true if no modifier keys are pressed.
2166 * <p>
2167 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2168 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2169 * not considered modifier keys. Consequently, this function ignores
2170 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2171 * </p><p>
2172 * The meta state is normalized prior to comparison using {@link #normalizeMetaState(int)}.
2173 * </p>
2174 *
2175 * @return True if no modifier keys are pressed.
2176 * @see #metaStateHasNoModifiers
2177 */
2178 public final boolean hasNoModifiers() {
2179 return metaStateHasNoModifiers(mMetaState);
2180 }
2181
2182 /**
2183 * Returns true if only the specified modifiers keys are pressed.
2184 * Returns false if a different combination of modifier keys are pressed.
2185 * <p>
2186 * For the purposes of this function, {@link #KEYCODE_CAPS_LOCK},
2187 * {@link #KEYCODE_SCROLL_LOCK}, and {@link #KEYCODE_NUM_LOCK} are
2188 * not considered modifier keys. Consequently, this function ignores
2189 * {@link #META_CAPS_LOCK_ON}, {@link #META_SCROLL_LOCK_ON} and {@link #META_NUM_LOCK_ON}.
2190 * </p><p>
2191 * If the specified modifier mask includes directional modifiers, such as
2192 * {@link #META_SHIFT_LEFT_ON}, then this method ensures that the
2193 * modifier is pressed on that side.
2194 * If the specified modifier mask includes non-directional modifiers, such as
2195 * {@link #META_SHIFT_ON}, then this method ensures that the modifier
2196 * is pressed on either side.
2197 * If the specified modifier mask includes both directional and non-directional modifiers
2198 * for the same type of key, such as {@link #META_SHIFT_ON} and {@link #META_SHIFT_LEFT_ON},
2199 * then this method throws an illegal argument exception.
2200 * </p>
2201 *
2202 * @param modifiers The meta state of the modifier keys to check. May be a combination
2203 * of modifier meta states as defined by {@link #getModifierMetaStateMask()}. May be 0 to
2204 * ensure that no modifier keys are pressed.
2205 * @return True if only the specified modifier keys are pressed.
2206 * @throws IllegalArgumentException if the modifiers parameter contains invalid modifiers
2207 * @see #metaStateHasModifiers
2208 */
2209 public final boolean hasModifiers(int modifiers) {
2210 return metaStateHasModifiers(mMetaState, modifiers);
2211 }
2212
2213 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002214 * <p>Returns the pressed state of the ALT meta key.</p>
2215 *
2216 * @return true if the ALT key is pressed, false otherwise
2217 *
2218 * @see #KEYCODE_ALT_LEFT
2219 * @see #KEYCODE_ALT_RIGHT
2220 * @see #META_ALT_ON
2221 */
2222 public final boolean isAltPressed() {
2223 return (mMetaState & META_ALT_ON) != 0;
2224 }
2225
2226 /**
2227 * <p>Returns the pressed state of the SHIFT meta key.</p>
2228 *
2229 * @return true if the SHIFT key is pressed, false otherwise
2230 *
2231 * @see #KEYCODE_SHIFT_LEFT
2232 * @see #KEYCODE_SHIFT_RIGHT
2233 * @see #META_SHIFT_ON
2234 */
2235 public final boolean isShiftPressed() {
2236 return (mMetaState & META_SHIFT_ON) != 0;
2237 }
2238
2239 /**
2240 * <p>Returns the pressed state of the SYM meta key.</p>
2241 *
2242 * @return true if the SYM key is pressed, false otherwise
2243 *
2244 * @see #KEYCODE_SYM
2245 * @see #META_SYM_ON
2246 */
2247 public final boolean isSymPressed() {
2248 return (mMetaState & META_SYM_ON) != 0;
2249 }
2250
2251 /**
Jeff Brown497a92c2010-09-12 17:55:08 -07002252 * <p>Returns the pressed state of the CTRL meta key.</p>
2253 *
2254 * @return true if the CTRL key is pressed, false otherwise
2255 *
2256 * @see #KEYCODE_CTRL_LEFT
2257 * @see #KEYCODE_CTRL_RIGHT
2258 * @see #META_CTRL_ON
2259 */
2260 public final boolean isCtrlPressed() {
2261 return (mMetaState & META_CTRL_ON) != 0;
2262 }
2263
2264 /**
2265 * <p>Returns the pressed state of the META meta key.</p>
2266 *
2267 * @return true if the META key is pressed, false otherwise
2268 *
2269 * @see #KEYCODE_META_LEFT
2270 * @see #KEYCODE_META_RIGHT
2271 * @see #META_META_ON
2272 */
2273 public final boolean isMetaPressed() {
2274 return (mMetaState & META_META_ON) != 0;
2275 }
2276
2277 /**
2278 * <p>Returns the pressed state of the FUNCTION meta key.</p>
2279 *
2280 * @return true if the FUNCTION key is pressed, false otherwise
2281 *
2282 * @see #KEYCODE_FUNCTION
2283 * @see #META_FUNCTION_ON
2284 */
2285 public final boolean isFunctionPressed() {
2286 return (mMetaState & META_FUNCTION_ON) != 0;
2287 }
2288
2289 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07002290 * <p>Returns the locked state of the CAPS LOCK meta key.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07002291 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07002292 * @return true if the CAPS LOCK key is on, false otherwise
Jeff Brown497a92c2010-09-12 17:55:08 -07002293 *
2294 * @see #KEYCODE_CAPS_LOCK
Jeff Brown51e7fe72010-10-29 22:19:53 -07002295 * @see #META_CAPS_LOCK_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002296 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07002297 public final boolean isCapsLockOn() {
2298 return (mMetaState & META_CAPS_LOCK_ON) != 0;
Jeff Brown497a92c2010-09-12 17:55:08 -07002299 }
2300
2301 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07002302 * <p>Returns the locked state of the NUM LOCK meta key.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07002303 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07002304 * @return true if the NUM LOCK key is on, false otherwise
Jeff Brown497a92c2010-09-12 17:55:08 -07002305 *
2306 * @see #KEYCODE_NUM_LOCK
Jeff Brown51e7fe72010-10-29 22:19:53 -07002307 * @see #META_NUM_LOCK_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002308 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07002309 public final boolean isNumLockOn() {
2310 return (mMetaState & META_NUM_LOCK_ON) != 0;
Jeff Brown497a92c2010-09-12 17:55:08 -07002311 }
2312
2313 /**
Jeff Brown51e7fe72010-10-29 22:19:53 -07002314 * <p>Returns the locked state of the SCROLL LOCK meta key.</p>
Jeff Brown497a92c2010-09-12 17:55:08 -07002315 *
Jeff Brown51e7fe72010-10-29 22:19:53 -07002316 * @return true if the SCROLL LOCK key is on, false otherwise
Jeff Brown497a92c2010-09-12 17:55:08 -07002317 *
2318 * @see #KEYCODE_SCROLL_LOCK
Jeff Brown51e7fe72010-10-29 22:19:53 -07002319 * @see #META_SCROLL_LOCK_ON
Jeff Brown497a92c2010-09-12 17:55:08 -07002320 */
Jeff Brown51e7fe72010-10-29 22:19:53 -07002321 public final boolean isScrollLockOn() {
2322 return (mMetaState & META_SCROLL_LOCK_ON) != 0;
Jeff Brown497a92c2010-09-12 17:55:08 -07002323 }
2324
2325 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002326 * Retrieve the action of this key event. May be either
2327 * {@link #ACTION_DOWN}, {@link #ACTION_UP}, or {@link #ACTION_MULTIPLE}.
RoboErik01fe6612014-02-13 14:19:04 -08002328 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002329 * @return The event action: ACTION_DOWN, ACTION_UP, or ACTION_MULTIPLE.
2330 */
2331 public final int getAction() {
2332 return mAction;
2333 }
2334
2335 /**
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07002336 * For {@link #ACTION_UP} events, indicates that the event has been
2337 * canceled as per {@link #FLAG_CANCELED}.
2338 */
2339 public final boolean isCanceled() {
2340 return (mFlags&FLAG_CANCELED) != 0;
2341 }
RoboErik01fe6612014-02-13 14:19:04 -08002342
Dianne Hackbornddca3ee2009-07-23 19:01:31 -07002343 /**
Wale Ogunwalec3672cd2014-11-05 15:17:35 -08002344 * Set {@link #FLAG_CANCELED} flag for the key event.
2345 *
2346 * @hide
2347 */
2348 @Override
2349 public final void cancel() {
2350 mFlags |= FLAG_CANCELED;
2351 }
2352
2353 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002354 * Call this during {@link Callback#onKeyDown} to have the system track
2355 * the key through its final up (possibly including a long press). Note
2356 * that only one key can be tracked at a time -- if another key down
2357 * event is received while a previous one is being tracked, tracking is
2358 * stopped on the previous event.
2359 */
2360 public final void startTracking() {
2361 mFlags |= FLAG_START_TRACKING;
2362 }
RoboErik01fe6612014-02-13 14:19:04 -08002363
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002364 /**
2365 * For {@link #ACTION_UP} events, indicates that the event is still being
2366 * tracked from its initial down event as per
2367 * {@link #FLAG_TRACKING}.
2368 */
2369 public final boolean isTracking() {
2370 return (mFlags&FLAG_TRACKING) != 0;
2371 }
RoboErik01fe6612014-02-13 14:19:04 -08002372
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002373 /**
2374 * For {@link #ACTION_DOWN} events, indicates that the event has been
2375 * canceled as per {@link #FLAG_LONG_PRESS}.
2376 */
2377 public final boolean isLongPress() {
2378 return (mFlags&FLAG_LONG_PRESS) != 0;
2379 }
RoboErik01fe6612014-02-13 14:19:04 -08002380
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002381 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002382 * Retrieve the key code of the key event. This is the physical key that
2383 * was pressed, <em>not</em> the Unicode character.
RoboErik01fe6612014-02-13 14:19:04 -08002384 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002385 * @return The key code of the event.
2386 */
2387 public final int getKeyCode() {
2388 return mKeyCode;
2389 }
2390
2391 /**
2392 * For the special case of a {@link #ACTION_MULTIPLE} event with key
2393 * code of {@link #KEYCODE_UNKNOWN}, this is a raw string of characters
2394 * associated with the event. In all other cases it is null.
RoboErik01fe6612014-02-13 14:19:04 -08002395 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002396 * @return Returns a String of 1 or more characters associated with
2397 * the event.
2398 */
2399 public final String getCharacters() {
2400 return mCharacters;
2401 }
RoboErik01fe6612014-02-13 14:19:04 -08002402
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002403 /**
2404 * Retrieve the hardware key id of this key event. These values are not
2405 * reliable and vary from device to device.
2406 *
2407 * {@more}
2408 * Mostly this is here for debugging purposes.
2409 */
2410 public final int getScanCode() {
Jeff Brown46b9ac02010-04-22 18:58:52 -07002411 return mScanCode;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002412 }
2413
2414 /**
2415 * Retrieve the repeat count of the event. For both key up and key down
2416 * events, this is the number of times the key has repeated with the first
2417 * down starting at 0 and counting up from there. For multiple key
2418 * events, this is the number of down/up pairs that have occurred.
RoboErik01fe6612014-02-13 14:19:04 -08002419 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002420 * @return The number of times the key has repeated.
2421 */
2422 public final int getRepeatCount() {
2423 return mRepeatCount;
2424 }
2425
2426 /**
2427 * Retrieve the time of the most recent key down event,
2428 * in the {@link android.os.SystemClock#uptimeMillis} time base. If this
2429 * is a down event, this will be the same as {@link #getEventTime()}.
2430 * Note that when chording keys, this value is the down time of the
2431 * most recently pressed key, which may <em>not</em> be the same physical
2432 * key of this event.
RoboErik01fe6612014-02-13 14:19:04 -08002433 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002434 * @return Returns the most recent key down time, in the
2435 * {@link android.os.SystemClock#uptimeMillis} time base
2436 */
2437 public final long getDownTime() {
2438 return mDownTime;
2439 }
2440
2441 /**
Jeff Brownb11499d2012-04-20 19:54:22 -07002442 * Retrieve the time this event occurred,
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002443 * in the {@link android.os.SystemClock#uptimeMillis} time base.
Jeff Brownb11499d2012-04-20 19:54:22 -07002444 *
RoboErik01fe6612014-02-13 14:19:04 -08002445 * @return Returns the time this event occurred,
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002446 * in the {@link android.os.SystemClock#uptimeMillis} time base.
2447 */
Jeff Brownb11499d2012-04-20 19:54:22 -07002448 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002449 public final long getEventTime() {
2450 return mEventTime;
2451 }
2452
Jeff Brownb11499d2012-04-20 19:54:22 -07002453 /**
2454 * Retrieve the time this event occurred,
2455 * in the {@link android.os.SystemClock#uptimeMillis} time base but with
2456 * nanosecond (instead of millisecond) precision.
2457 * <p>
2458 * The value is in nanosecond precision but it may not have nanosecond accuracy.
2459 * </p>
2460 *
2461 * @return Returns the time this event occurred,
2462 * in the {@link android.os.SystemClock#uptimeMillis} time base but with
2463 * nanosecond (instead of millisecond) precision.
2464 *
2465 * @hide
2466 */
Jeff Brown4e91a182011-04-07 11:38:09 -07002467 @Override
2468 public final long getEventTimeNano() {
2469 return mEventTime * 1000000L;
2470 }
2471
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002472 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002473 * Renamed to {@link #getDeviceId}.
RoboErik01fe6612014-02-13 14:19:04 -08002474 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002475 * @hide
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002476 * @deprecated use {@link #getDeviceId()} instead.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002477 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002478 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002479 public final int getKeyboardDevice() {
2480 return mDeviceId;
2481 }
2482
2483 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002484 * Gets the {@link KeyCharacterMap} associated with the keyboard device.
2485 *
2486 * @return The associated key character map.
Andrew Sapperstein8ab3dc72011-06-23 18:56:44 -07002487 * @throws {@link KeyCharacterMap.UnavailableException} if the key character map
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002488 * could not be loaded because it was malformed or the default key character map
2489 * is missing from the system.
2490 *
Andrew Sapperstein8ab3dc72011-06-23 18:56:44 -07002491 * @see KeyCharacterMap#load
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002492 */
2493 public final KeyCharacterMap getKeyCharacterMap() {
2494 return KeyCharacterMap.load(mDeviceId);
2495 }
2496
2497 /**
2498 * Gets the primary character for this key.
2499 * In other words, the label that is physically printed on it.
2500 *
2501 * @return The display label character, or 0 if none (eg. for non-printing keys).
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002502 */
2503 public char getDisplayLabel() {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002504 return getKeyCharacterMap().getDisplayLabel(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002505 }
RoboErik01fe6612014-02-13 14:19:04 -08002506
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002507 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002508 * Gets the Unicode character generated by the specified key and meta
2509 * key state combination.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002510 * <p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002511 * Returns the Unicode character that the specified key would produce
2512 * when the specified meta bits (see {@link MetaKeyKeyListener})
2513 * were active.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002514 * </p><p>
2515 * Returns 0 if the key is not one that is used to type Unicode
2516 * characters.
2517 * </p><p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002518 * If the return value has bit {@link KeyCharacterMap#COMBINING_ACCENT} set, the
2519 * key is a "dead key" that should be combined with another to
2520 * actually produce a character -- see {@link KeyCharacterMap#getDeadChar} --
2521 * after masking with {@link KeyCharacterMap#COMBINING_ACCENT_MASK}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002522 * </p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002523 *
2524 * @return The associated character or combining accent, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002525 */
2526 public int getUnicodeChar() {
2527 return getUnicodeChar(mMetaState);
2528 }
RoboErik01fe6612014-02-13 14:19:04 -08002529
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002530 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002531 * Gets the Unicode character generated by the specified key and meta
2532 * key state combination.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002533 * <p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002534 * Returns the Unicode character that the specified key would produce
2535 * when the specified meta bits (see {@link MetaKeyKeyListener})
2536 * were active.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002537 * </p><p>
2538 * Returns 0 if the key is not one that is used to type Unicode
2539 * characters.
2540 * </p><p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002541 * If the return value has bit {@link KeyCharacterMap#COMBINING_ACCENT} set, the
2542 * key is a "dead key" that should be combined with another to
2543 * actually produce a character -- see {@link KeyCharacterMap#getDeadChar} --
2544 * after masking with {@link KeyCharacterMap#COMBINING_ACCENT_MASK}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002545 * </p>
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002546 *
2547 * @param metaState The meta key modifier state.
2548 * @return The associated character or combining accent, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002549 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002550 public int getUnicodeChar(int metaState) {
2551 return getKeyCharacterMap().get(mKeyCode, metaState);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002552 }
RoboErik01fe6612014-02-13 14:19:04 -08002553
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002554 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002555 * Get the character conversion data for a given key code.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002556 *
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002557 * @param results A {@link KeyCharacterMap.KeyData} instance that will be
2558 * filled with the results.
2559 * @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 -08002560 *
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002561 * @deprecated instead use {@link #getDisplayLabel()},
2562 * {@link #getNumber()} or {@link #getUnicodeChar(int)}.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002563 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002564 @Deprecated
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002565 public boolean getKeyData(KeyData results) {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002566 return getKeyCharacterMap().getKeyData(mKeyCode, results);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002567 }
RoboErik01fe6612014-02-13 14:19:04 -08002568
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002569 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002570 * Gets the first character in the character array that can be generated
2571 * by the specified key code.
2572 * <p>
2573 * This is a convenience function that returns the same value as
2574 * {@link #getMatch(char[],int) getMatch(chars, 0)}.
2575 * </p>
2576 *
2577 * @param chars The array of matching characters to consider.
2578 * @return The matching associated character, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002579 */
2580 public char getMatch(char[] chars) {
2581 return getMatch(chars, 0);
2582 }
RoboErik01fe6612014-02-13 14:19:04 -08002583
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002584 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002585 * Gets the first character in the character array that can be generated
2586 * by the specified key code. If there are multiple choices, prefers
2587 * the one that would be generated with the specified meta key modifier state.
2588 *
2589 * @param chars The array of matching characters to consider.
2590 * @param metaState The preferred meta key modifier state.
2591 * @return The matching associated character, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002592 */
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002593 public char getMatch(char[] chars, int metaState) {
2594 return getKeyCharacterMap().getMatch(mKeyCode, chars, metaState);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002595 }
RoboErik01fe6612014-02-13 14:19:04 -08002596
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002597 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002598 * Gets the number or symbol associated with the key.
2599 * <p>
2600 * The character value is returned, not the numeric value.
2601 * If the key is not a number, but is a symbol, the symbol is retuned.
2602 * </p><p>
2603 * This method is intended to to support dial pads and other numeric or
2604 * symbolic entry on keyboards where certain keys serve dual function
2605 * as alphabetic and symbolic keys. This method returns the number
2606 * or symbol associated with the key independent of whether the user
2607 * has pressed the required modifier.
2608 * </p><p>
2609 * For example, on one particular keyboard the keys on the top QWERTY row generate
2610 * numbers when ALT is pressed such that ALT-Q maps to '1'. So for that keyboard
2611 * when {@link #getNumber} is called with {@link KeyEvent#KEYCODE_Q} it returns '1'
2612 * so that the user can type numbers without pressing ALT when it makes sense.
2613 * </p>
2614 *
2615 * @return The associated numeric or symbolic character, or 0 if none.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002616 */
2617 public char getNumber() {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002618 return getKeyCharacterMap().getNumber(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002619 }
RoboErik01fe6612014-02-13 14:19:04 -08002620
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002621 /**
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002622 * Returns true if this key produces a glyph.
2623 *
2624 * @return True if the key is a printing key.
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002625 */
2626 public boolean isPrintingKey() {
Jeff Brown6b53e8d2010-11-10 16:03:06 -08002627 return getKeyCharacterMap().isPrintingKey(mKeyCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002628 }
RoboErik01fe6612014-02-13 14:19:04 -08002629
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002630 /**
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002631 * @deprecated Use {@link #dispatch(Callback, DispatcherState, Object)} instead.
2632 */
2633 @Deprecated
2634 public final boolean dispatch(Callback receiver) {
2635 return dispatch(receiver, null, null);
2636 }
RoboErik01fe6612014-02-13 14:19:04 -08002637
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002638 /**
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002639 * Deliver this key event to a {@link Callback} interface. If this is
2640 * an ACTION_MULTIPLE event and it is not handled, then an attempt will
2641 * be made to deliver a single normal event.
RoboErik01fe6612014-02-13 14:19:04 -08002642 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002643 * @param receiver The Callback that will be given the event.
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002644 * @param state State information retained across events.
2645 * @param target The target of the dispatch, for use in tracking.
RoboErik01fe6612014-02-13 14:19:04 -08002646 *
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002647 * @return The return value from the Callback method that was called.
2648 */
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002649 public final boolean dispatch(Callback receiver, DispatcherState state,
2650 Object target) {
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002651 switch (mAction) {
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002652 case ACTION_DOWN: {
2653 mFlags &= ~FLAG_START_TRACKING;
Dianne Hackborn8d374262009-09-14 21:21:52 -07002654 if (DEBUG) Log.v(TAG, "Key down to " + target + " in " + state
2655 + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002656 boolean res = receiver.onKeyDown(mKeyCode, this);
2657 if (state != null) {
2658 if (res && mRepeatCount == 0 && (mFlags&FLAG_START_TRACKING) != 0) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002659 if (DEBUG) Log.v(TAG, " Start tracking!");
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002660 state.startTracking(this, target);
2661 } else if (isLongPress() && state.isTracking(this)) {
2662 try {
2663 if (receiver.onKeyLongPress(mKeyCode, this)) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002664 if (DEBUG) Log.v(TAG, " Clear from long press!");
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002665 state.performedLongPress(this);
2666 res = true;
2667 }
2668 } catch (AbstractMethodError e) {
2669 }
2670 }
2671 }
2672 return res;
2673 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002674 case ACTION_UP:
Dianne Hackborn8d374262009-09-14 21:21:52 -07002675 if (DEBUG) Log.v(TAG, "Key up to " + target + " in " + state
2676 + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002677 if (state != null) {
2678 state.handleUpEvent(this);
2679 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002680 return receiver.onKeyUp(mKeyCode, this);
2681 case ACTION_MULTIPLE:
2682 final int count = mRepeatCount;
2683 final int code = mKeyCode;
2684 if (receiver.onKeyMultiple(code, count, this)) {
2685 return true;
2686 }
2687 if (code != KeyEvent.KEYCODE_UNKNOWN) {
2688 mAction = ACTION_DOWN;
2689 mRepeatCount = 0;
2690 boolean handled = receiver.onKeyDown(code, this);
2691 if (handled) {
2692 mAction = ACTION_UP;
2693 receiver.onKeyUp(code, this);
2694 }
2695 mAction = ACTION_MULTIPLE;
2696 mRepeatCount = count;
2697 return handled;
2698 }
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002699 return false;
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002700 }
2701 return false;
2702 }
2703
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002704 /**
2705 * Use with {@link KeyEvent#dispatch(Callback, DispatcherState, Object)}
2706 * for more advanced key dispatching, such as long presses.
2707 */
2708 public static class DispatcherState {
2709 int mDownKeyCode;
2710 Object mDownTarget;
2711 SparseIntArray mActiveLongPresses = new SparseIntArray();
RoboErik01fe6612014-02-13 14:19:04 -08002712
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002713 /**
2714 * Reset back to initial state.
2715 */
2716 public void reset() {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002717 if (DEBUG) Log.v(TAG, "Reset: " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002718 mDownKeyCode = 0;
2719 mDownTarget = null;
2720 mActiveLongPresses.clear();
2721 }
RoboErik01fe6612014-02-13 14:19:04 -08002722
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002723 /**
2724 * Stop any tracking associated with this target.
2725 */
2726 public void reset(Object target) {
2727 if (mDownTarget == target) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002728 if (DEBUG) Log.v(TAG, "Reset in " + target + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002729 mDownKeyCode = 0;
2730 mDownTarget = null;
2731 }
2732 }
RoboErik01fe6612014-02-13 14:19:04 -08002733
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002734 /**
2735 * Start tracking the key code associated with the given event. This
2736 * can only be called on a key down. It will allow you to see any
2737 * long press associated with the key, and will result in
2738 * {@link KeyEvent#isTracking} return true on the long press and up
2739 * events.
RoboErik01fe6612014-02-13 14:19:04 -08002740 *
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002741 * <p>This is only needed if you are directly dispatching events, rather
2742 * than handling them in {@link Callback#onKeyDown}.
2743 */
2744 public void startTracking(KeyEvent event, Object target) {
2745 if (event.getAction() != ACTION_DOWN) {
2746 throw new IllegalArgumentException(
2747 "Can only start tracking on a down event");
2748 }
Dianne Hackborn8d374262009-09-14 21:21:52 -07002749 if (DEBUG) Log.v(TAG, "Start trackingt in " + target + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002750 mDownKeyCode = event.getKeyCode();
2751 mDownTarget = target;
2752 }
RoboErik01fe6612014-02-13 14:19:04 -08002753
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002754 /**
2755 * Return true if the key event is for a key code that is currently
2756 * being tracked by the dispatcher.
2757 */
2758 public boolean isTracking(KeyEvent event) {
2759 return mDownKeyCode == event.getKeyCode();
2760 }
RoboErik01fe6612014-02-13 14:19:04 -08002761
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002762 /**
2763 * Keep track of the given event's key code as having performed an
2764 * action with a long press, so no action should occur on the up.
2765 * <p>This is only needed if you are directly dispatching events, rather
2766 * than handling them in {@link Callback#onKeyLongPress}.
2767 */
2768 public void performedLongPress(KeyEvent event) {
2769 mActiveLongPresses.put(event.getKeyCode(), 1);
2770 }
RoboErik01fe6612014-02-13 14:19:04 -08002771
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002772 /**
2773 * Handle key up event to stop tracking. This resets the dispatcher state,
2774 * and updates the key event state based on it.
2775 * <p>This is only needed if you are directly dispatching events, rather
2776 * than handling them in {@link Callback#onKeyUp}.
2777 */
2778 public void handleUpEvent(KeyEvent event) {
2779 final int keyCode = event.getKeyCode();
Dianne Hackborn8d374262009-09-14 21:21:52 -07002780 if (DEBUG) Log.v(TAG, "Handle key up " + event + ": " + this);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002781 int index = mActiveLongPresses.indexOfKey(keyCode);
2782 if (index >= 0) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002783 if (DEBUG) Log.v(TAG, " Index: " + index);
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002784 event.mFlags |= FLAG_CANCELED | FLAG_CANCELED_LONG_PRESS;
2785 mActiveLongPresses.removeAt(index);
2786 }
2787 if (mDownKeyCode == keyCode) {
Dianne Hackborn8d374262009-09-14 21:21:52 -07002788 if (DEBUG) Log.v(TAG, " Tracking!");
Dianne Hackborn83fe3f52009-09-12 23:38:30 -07002789 event.mFlags |= FLAG_TRACKING;
2790 mDownKeyCode = 0;
2791 mDownTarget = null;
2792 }
2793 }
2794 }
Jeff Brown497a92c2010-09-12 17:55:08 -07002795
2796 @Override
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002797 public String toString() {
Jeff Brownfe9f8ab2011-05-06 18:20:01 -07002798 StringBuilder msg = new StringBuilder();
2799 msg.append("KeyEvent { action=").append(actionToString(mAction));
2800 msg.append(", keyCode=").append(keyCodeToString(mKeyCode));
2801 msg.append(", scanCode=").append(mScanCode);
2802 if (mCharacters != null) {
2803 msg.append(", characters=\"").append(mCharacters).append("\"");
2804 }
2805 msg.append(", metaState=").append(metaStateToString(mMetaState));
2806 msg.append(", flags=0x").append(Integer.toHexString(mFlags));
2807 msg.append(", repeatCount=").append(mRepeatCount);
2808 msg.append(", eventTime=").append(mEventTime);
2809 msg.append(", downTime=").append(mDownTime);
2810 msg.append(", deviceId=").append(mDeviceId);
2811 msg.append(", source=0x").append(Integer.toHexString(mSource));
2812 msg.append(" }");
2813 return msg.toString();
Jeff Brown497a92c2010-09-12 17:55:08 -07002814 }
2815
2816 /**
2817 * Returns a string that represents the symbolic name of the specified action
Jeff Brown6f2fba42011-02-19 01:08:02 -08002818 * such as "ACTION_DOWN", or an equivalent numeric constant such as "35" if unknown.
Jeff Brown497a92c2010-09-12 17:55:08 -07002819 *
2820 * @param action The action.
2821 * @return The symbolic name of the specified action.
2822 * @hide
2823 */
2824 public static String actionToString(int action) {
2825 switch (action) {
2826 case ACTION_DOWN:
2827 return "ACTION_DOWN";
2828 case ACTION_UP:
2829 return "ACTION_UP";
2830 case ACTION_MULTIPLE:
2831 return "ACTION_MULTIPLE";
2832 default:
2833 return Integer.toString(action);
2834 }
2835 }
2836
2837 /**
2838 * Returns a string that represents the symbolic name of the specified keycode
Jeff Brown6f2fba42011-02-19 01:08:02 -08002839 * such as "KEYCODE_A", "KEYCODE_DPAD_UP", or an equivalent numeric constant
2840 * such as "1001" if unknown.
Jeff Brown497a92c2010-09-12 17:55:08 -07002841 *
2842 * @param keyCode The key code.
2843 * @return The symbolic name of the specified keycode.
2844 *
2845 * @see KeyCharacterMap#getDisplayLabel
Jeff Brown497a92c2010-09-12 17:55:08 -07002846 */
2847 public static String keyCodeToString(int keyCode) {
Michael Wright337d9d22014-04-22 15:03:48 -07002848 String symbolicName = nativeKeyCodeToString(keyCode);
2849 return symbolicName != null ? LABEL_PREFIX + symbolicName : Integer.toString(keyCode);
Jeff Brown497a92c2010-09-12 17:55:08 -07002850 }
2851
2852 /**
Jeff Brown6f2fba42011-02-19 01:08:02 -08002853 * Gets a keycode by its symbolic name such as "KEYCODE_A" or an equivalent
2854 * numeric constant such as "1001".
Jeff Brown497a92c2010-09-12 17:55:08 -07002855 *
2856 * @param symbolicName The symbolic name of the keycode.
Jeff Brown6f2fba42011-02-19 01:08:02 -08002857 * @return The keycode or {@link #KEYCODE_UNKNOWN} if not found.
Michael Wright072137c2013-04-24 20:41:20 -07002858 * @see #keycodeToString(int)
Jeff Brown497a92c2010-09-12 17:55:08 -07002859 */
2860 public static int keyCodeFromString(String symbolicName) {
Michael Wright337d9d22014-04-22 15:03:48 -07002861 if (symbolicName.startsWith(LABEL_PREFIX)) {
2862 symbolicName = symbolicName.substring(LABEL_PREFIX.length());
Michael Wright973efa02014-05-13 15:38:56 -07002863 int keyCode = nativeKeyCodeFromString(symbolicName);
2864 if (keyCode > 0) {
2865 return keyCode;
2866 }
Jeff Brown497a92c2010-09-12 17:55:08 -07002867 }
Jeff Brown497a92c2010-09-12 17:55:08 -07002868 try {
Jeff Brown6f2fba42011-02-19 01:08:02 -08002869 return Integer.parseInt(symbolicName, 10);
Jeff Brown497a92c2010-09-12 17:55:08 -07002870 } catch (NumberFormatException ex) {
Jeff Brown6f2fba42011-02-19 01:08:02 -08002871 return KEYCODE_UNKNOWN;
Jeff Brown497a92c2010-09-12 17:55:08 -07002872 }
2873 }
2874
2875 /**
2876 * Returns a string that represents the symbolic name of the specified combined meta
2877 * key modifier state flags such as "0", "META_SHIFT_ON",
Jeff Brown6f2fba42011-02-19 01:08:02 -08002878 * "META_ALT_ON|META_SHIFT_ON" or an equivalent numeric constant such as "0x10000000"
2879 * if unknown.
Jeff Brown497a92c2010-09-12 17:55:08 -07002880 *
2881 * @param metaState The meta state.
2882 * @return The symbolic name of the specified combined meta state flags.
2883 * @hide
2884 */
2885 public static String metaStateToString(int metaState) {
2886 if (metaState == 0) {
2887 return "0";
2888 }
2889 StringBuilder result = null;
2890 int i = 0;
2891 while (metaState != 0) {
2892 final boolean isSet = (metaState & 1) != 0;
2893 metaState >>>= 1; // unsigned shift!
2894 if (isSet) {
2895 final String name = META_SYMBOLIC_NAMES[i];
2896 if (result == null) {
2897 if (metaState == 0) {
2898 return name;
2899 }
2900 result = new StringBuilder(name);
2901 } else {
2902 result.append('|');
2903 result.append(name);
2904 }
2905 }
2906 i += 1;
2907 }
2908 return result.toString();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002909 }
2910
2911 public static final Parcelable.Creator<KeyEvent> CREATOR
2912 = new Parcelable.Creator<KeyEvent>() {
2913 public KeyEvent createFromParcel(Parcel in) {
Jeff Brown6ec402b2010-07-28 15:48:59 -07002914 in.readInt(); // skip token, we already know this is a KeyEvent
2915 return KeyEvent.createFromParcelBody(in);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002916 }
2917
2918 public KeyEvent[] newArray(int size) {
2919 return new KeyEvent[size];
2920 }
2921 };
RoboErik01fe6612014-02-13 14:19:04 -08002922
Jeff Brown6ec402b2010-07-28 15:48:59 -07002923 /** @hide */
2924 public static KeyEvent createFromParcelBody(Parcel in) {
2925 return new KeyEvent(in);
2926 }
RoboErik01fe6612014-02-13 14:19:04 -08002927
Jeff Brown6ec402b2010-07-28 15:48:59 -07002928 private KeyEvent(Parcel in) {
Jeff Brown91c69ab2011-02-14 17:03:18 -08002929 mDeviceId = in.readInt();
2930 mSource = in.readInt();
Jeff Brown6ec402b2010-07-28 15:48:59 -07002931 mAction = in.readInt();
2932 mKeyCode = in.readInt();
2933 mRepeatCount = in.readInt();
2934 mMetaState = in.readInt();
2935 mScanCode = in.readInt();
2936 mFlags = in.readInt();
2937 mDownTime = in.readLong();
2938 mEventTime = in.readLong();
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002939 }
2940
2941 public void writeToParcel(Parcel out, int flags) {
Jeff Brown6ec402b2010-07-28 15:48:59 -07002942 out.writeInt(PARCEL_TOKEN_KEY_EVENT);
Jeff Brown91c69ab2011-02-14 17:03:18 -08002943
2944 out.writeInt(mDeviceId);
2945 out.writeInt(mSource);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002946 out.writeInt(mAction);
2947 out.writeInt(mKeyCode);
2948 out.writeInt(mRepeatCount);
2949 out.writeInt(mMetaState);
Jeff Brown46b9ac02010-04-22 18:58:52 -07002950 out.writeInt(mScanCode);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002951 out.writeInt(mFlags);
2952 out.writeLong(mDownTime);
2953 out.writeLong(mEventTime);
2954 }
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08002955}