I want to take overinput over the Volume Up and Down. At the moment my code is:
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
Log.v(
If you handled the event, return
true
. If you want to allow the event to be handled by the next receiver, returnfalse
.
public boolean dispatchKeyEvent(KeyEvent event) {
if (event.getKeyCode() == KeyEvent.KEYCODE_VOLUME_UP) {
return true;
} else if (event.getKeyCode() == KeyEvent.KEYCODE_VOLUME_DOWN) {
return true;
}
return dispatchKeyEvent(event);
}
It's important to return true if you handled the event, but if you didn't handle the event, it's good to make sure that the event is still handled by the superclass. Here's some code from my app:
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN ||
keyCode == KeyEvent.KEYCODE_VOLUME_UP) {
changeColor(keyCode);
return true;
}
return super.onKeyDown(keyCode, event);
}
@Override
public boolean onKeyUp(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN ||
keyCode == KeyEvent.KEYCODE_VOLUME_UP) {
// do nothing
return true;
}
return super.onKeyUp(keyCode, event);
}
In my case, the superclass call was necessary so that other hardware buttons on my device continued to work.