“This is the 8th day of my participation in the Gwen Challenge in November. Check out the details: The Last Gwen Challenge in 2021”
Android Key Event Transfer Process (3)
Transfer of key events at the application layer
Event passing process
Here we mainly explain two parts, mView creation and event passing process.
The last section explained how mView is created, but we’ll continue with how it is passed.
The dispatchKeyEvent DecorView
public boolean dispatchKeyEvent(KeyEvent event) {
final int keyCode = event.getKeyCode();
final int action = event.getAction();
final boolean isDown = action == KeyEvent.ACTION_DOWN;
if (isDown && (event.getRepeatCount() == 0)) {
// First handle chording of panel key: if a panel key is held
// but not released, try to execute a shortcut in it.
if ((mWindow.mPanelChordingKey > 0) && (mWindow.mPanelChordingKey ! = keyCode)) {boolean handled = dispatchKeyShortcutEvent(event);
if (handled) {
return true; }}// If a panel is open, perform a shortcut on it without the
// chorded panel key
if((mWindow.mPreparedPanel ! =null) && mWindow.mPreparedPanel.isOpen) {
if (mWindow.performPanelShortcut(mWindow.mPreparedPanel, keyCode, event, 0)) {
return true; }}}if(! mWindow.isDestroyed()) {final Window.Callback cb = mWindow.getCallback();
final booleanhandled = cb ! =null && mFeatureId < 0 ? cb.dispatchKeyEvent(event)
: super.dispatchKeyEvent(event);
if (handled) {
return true; }}return isDown ? mWindow.onKeyDown(mFeatureId, event.getKeyCode(), event)
: mWindow.onKeyUp(mFeatureId, event.getKeyCode(), event);
}
Copy the code
The previous two judgments deal with shortcut keys.
/ /...
if(! mWindow.isDestroyed()) {//cb represents an Activity
final Window.Callback cb = mWindow.getCallback();
final booleanhandled = cb ! =null && mFeatureId < 0 ? cb.dispatchKeyEvent(event)
: super.dispatchKeyEvent(event);
if (handled) {
return true; }}/ /...
Copy the code
MFeatureId: A feature representation of an application or an entire screen, or -1 for an application. The process is as follows:
Activity onCreate method ->setContentView->PhoneWindow setContentView-> installDecor()->generateDecor-> new DecorView(getContext(), -1)
If the Activity object is not empty and mFeatureId is -1, call the dispatchKeyEvent method on the Activity object. If the Activity object is empty, Call super.dispatchKeyevent (event) which is dispatchKeyEvent of the parent ViewGroup
If the return value is true, the event has been consumed and the keystroke event is not being delivered, otherwise execution will continue
return isDown ? PhoneWindow.this.onKeyDown(mFeatureId, event.getKeyCode(), event)
: PhoneWindow.this.onKeyUp(mFeatureId, event.getKeyCode(), event);
Copy the code
The onKeyDown, onKeyUp methods that will be passed to PhoneWindow.
The Activity of the dispatchKeyEvent
This method in the Activity acts as a keyblock, and if it is not handled at this step, the event is propagated down to the View or viewGroup for processing.
public boolean dispatchKeyEvent(KeyEvent event) {
// is called if there are events assigned to the Activity, such as a button or trackball
onUserInteraction();
// Let action bars open menus in response to the menu key prioritized over
// the window handling it
final int keyCode = event.getKeyCode();
Return true if the Menu key is used and the status bar consumes it
if(keyCode == KeyEvent.KEYCODE_MENU && mActionBar ! =null && mActionBar.onMenuKeyEvent(event)) {
return true;
}
Window win = getWindow();
if (win.superDispatchKeyEvent(event)) {
return true;
}
View decor = mDecor;
if (decor == null) decor = win.getDecorView();
return event.dispatch(this, decor ! =null
? decor.getKeyDispatcherState() : null.this);
}
Copy the code
/ /...
Window win = getWindow();
if (win.superDispatchKeyEvent(event)) {
return true;
}
/ /...
Copy the code
The PhoneWindow object is returned via getWindow, passing the event to the PhoneWindow object, mainly some handling of the release of the Back key.
If it is not consumed, it is passed along with other times to the parent’s ViewGroup, or dispatchKeyEvent to KeyEvent if it is not processed by the parent.