ハードウェア再生コントロールキーを使用してオーディオ再生を制御する方法に関するトレーニングセクションに続いて、リスナークラスを作成します。
public class RemoteControlReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context arg0, Intent intent) {
if (Intent.ACTION_MEDIA_BUTTON.equals(intent.getAction())) {
KeyEvent event = (KeyEvent)intent.getParcelableExtra(Intent.EXTRA_KEY_EVENT);
Log.e(TAG, "ACTION_MEDIA_BUTTON");
int keycode = event.getKeyCode();
switch (keycode)
{
case KeyEvent.KEYCODE_MEDIA_NEXT:
Log.e(TAG, "KEYCODE_MEDIA_NEXT");
break;
case KeyEvent.KEYCODE_MEDIA_PLAY_PAUSE:
Log.e(TAG, "KEYCODE_MEDIA_PLAY_PAUSE");
break;
case KeyEvent.KEYCODE_MEDIA_PREVIOUS:
Log.e(TAG, "KEYCODE_MEDIA_PREVIOUS");
break;
default:
}
if (/*KeyEvent.KEYCODE_MEDIA_PLAY*/ 126 == event.getKeyCode()) { // KEYCODE_MEDIA_PLAY undefined for API < 11
Log.e(TAG, "KEYCODE_MEDIA_PLAY");
}
}
}
}
アクティビティのonCreate()に登録しました:
private AudioManager mAudioManager;
private ComponentName mRemoteControlReceiver;
...
...
mAudioManager = (AudioManager)getSystemService(Context.AUDIO_SERVICE);
mRemoteControlReceiver = new ComponentName(this, RemoteControlReceiver.class);
mAudioManager.registerMediaButtonEventReceiver(mRemoteControlReceiver);
そしてそれをマニフェストに登録しました:
<receiver android:name=".RemoteControlReceiver">
<intent-filter>
<action android:name="android.intent.action.MEDIA_BUTTON" />
</intent-filter>
</receiver>
ただし、これらのボタンのいずれかを押しても、LogCatにログメッセージは表示されません。(メディアの再生中に押されたかどうかに関係なく)
私のコードは他のメディアプレーヤーからのこれらのイベントを傍受しているようですが、なぜ私のLog.e()
メッセージが表示されないのですか?私は何が欠けていますか?
ところで、これらのボタンのいずれかを押すと、代わりに次のメッセージが表示されます。
W/KeyCharacterMap(19801): Can't open keycharmap file
W/KeyCharacterMap(19801): Error loading keycharmap file '/system/usr/keychars/h2w_headset.kcm.bin'. hw.keyboards.131075.devname='h2w headset'
W/KeyCharacterMap(19801): Using default keymap: /system/usr/keychars/qwerty.kcm.bin