这里添加新的键值,不是毫无凭据凭空创造的一个键值,
而是根据kernel中检测到的按键值,然后转化为android所需要的数值:
以添加一个linux键值为217,把它映射为android的键值Browser(这个键值之前不存在)为例介绍一下:
一、android之前没有这个键值,需要定义
/frameworks/base/core/java/android/view/KeyEvent.java
//定义这个新的键值
public static final int KEYCODE_BROWSER = 220;(在我这套代码里已经最大是219了,所以我们新加一个定义为220)
然后我们会看到有如下注释:
- // NOTE: If you add a new keycode here you must also add it to:
- // isSystem()
- // native/include/android/keycodes.h
- // frameworks/base/include/ui/KeycodeLabels.h
- // external/webkit/WebKit/android/plugins/ANPKeyCodes.h
- // frameworks/base/core/res/res/values/attrs.xml
- // emulator?
- // LAST_KEYCODE
- // KEYCODE_SYMBOLIC_NAMES
- //
- // Also Android currently does not reserve code ranges for vendor-
- // specific key codes. If you have new key codes to have, you
- // MUST contribute a patch to the open source project to define
- // those new codes. This is intended to maintain a consistent
- // set of key code definitions across all Android devices.
LAST_KEYCODE也就是最后一个keycode,因为添加了新的,所以需要更改这个的数值
- LAST_KEYCODE = KEYCODE_BROWSER
- private static final
- SparseArray KEYCODE_SYMBOLIC_NAMES = new SparseArray();
- private static void populateKeycodeSymbolicNames() {
- ……
- names.append(KEYCODE_MUSIC, "KEYCODE_MUSIC");
- names.append(KEYCODE_CALCULATOR, "KEYCODE_CALCULATOR");
- names.append(KEYCODE_BROWSER, "KEYCODE_BROWSER");
- }
上面的注释已经为我们指明了添加键值所需要的步骤:
二、/frameworks/base/core/java/android/view/KeyEvent.java
- public final boolean isSystem() {
- return native_isSystemKey(mKeyCode);
- }
- /frameworks/base/jni/android_view_KeyEvent.java
- static jboolean native_isSystemKey(JNIEnv* env, jobject clazz, jint
- keyCode) {
- return KeyEvent::isSystemKey(keyCode);
- }
- /frameworks/base/libs/androidfw/Input.cpp
- bool KeyEvent::isSystemKey(int32_t keyCode) {
- switch (keyCode) {
- ……
- case AKEYCODE_BROWSER:
- return true;
- }
- }
三、/frameworks/native/include/android/keycodes.h
- /*
- * Key codes.
- */
- enum {
- ……
- AKEYCODE_CALCULATOR = 210,
- AKEYCODE_BROWSER = 220,
- }
四、/frameworks/base/include/androidfw/KeycodeLabels.h
这里定义的实际上是我们在kl文件,也就是linux key到android key的一个映射表中的linux键值和android键值的名称;
比如frameworks/base/data/keyboards/Generic.kl:
……
key 217 BROWSER //这里的BROWSER就是我们定义的android键值的字符形式,217则是linux键值
那么,BROWSER不能无缘无故就使用,必然有定义位置,这个位置就是KeycodeLabels.h
- static const KeycodeLabel KEYCODES[] = {
- ……
- { "CALCULATOR", 210 },
- {"BROWSER", 220}, //这里的BROWSER就是我们上面使用的东西,而220是android键值
- { NULL, 0}
- }
在EventHub.cpp中加载并解析这个map:frameworks/base/data/keyboards/Generic.kl,那么得到的是linux键值217为key的string,这个string就是BROWSER,有了上面这个KEYCODES数组,就可以获得它对应的android键值了。
五、/external/webkit/Source/WebKit/android/plugins/ANPKeyCodes.h
- enum ANPKeyCodes {
- ……
- kAppSwitch_ANPKeyCode = 186,
- kBrowser_ANPKEYCODE = 220,
- };
六、/frameworks/base/core/res/res/values/attrs.xml
<enum name="KEYCODE_YEN" value="216" />
<enum name="KEYCODE_RO" value="217" />
<enum name="KEYCODE_KANA" value="218" />
<enum name="KEYCODE_INTERCOM" value="220" />
这些操作完成了之后,就完成了linux键到android的键值映射。
也就是android中多了一个KEYCODE_BROWSER它的值是220.
Linux部分简单,就是在kernel/include/linux/input.h里面加入#define BROWSER 217
然后在事件上报的时候,把217报上去就OK啦。