Christian
Christian

Reputation: 26387

Taking over the volume key on Android

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?

Upvotes: 6

Views: 14817

Answers (3)

zed_0xff
zed_0xff

Reputation: 33217

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

Upvotes: 20

rijoviany
rijoviany

Reputation: 5

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);
}

Upvotes: -2

vor23
vor23

Reputation: 101

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.

Upvotes: 9

Related Questions