6

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(TAG, event.toString());
    if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN){
        mLamp.moveBackward();

        return false;
    }
    else if(keyCode == KeyEvent.KEYCODE_VOLUME_UP){
        mLamp.moveForward();

        return false;
    }

    return true;
}
public boolean onKeyUp(int keyCode, KeyEvent event) {

    Log.v(TAG, event.toString());
    if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN){
        return false;
    }
    else if(keyCode == KeyEvent.KEYCODE_VOLUME_UP){
        return false;
    }

    return true;
}

This triggers the mLamp.moveBackward() and mLamp.moveForward() function but it still changes the volume of the ringer. What do I have to do that the ringer loudness doesn't change?

Christian
  • 25,249
  • 40
  • 134
  • 225

3 Answers3

20

If you handled the event, return true. If you want to allow the event to be handled by the next receiver, return false.

Adil Shaikh
  • 44,509
  • 17
  • 89
  • 111
zed_0xff
  • 32,417
  • 7
  • 53
  • 72
9

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.

vor23
  • 101
  • 2
  • 4
-2
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);
}
rijoviany
  • 5
  • 2