背景描述:
调用SoundPool提示系统音,发现无法正常提示。
调用代码如下:
private void playBySoundPool(){
Uri actualDefaultRingtoneUri = RingtoneManager.getActualDefaultRingtoneUri(getApplicationContext(), RingtoneManager.TYPE_NOTIFICATION);
Log.d(TAG,"actualDefaultRingtoneUri: "+actualDefaultRingtoneUri);
final SoundPool snd = new SoundPool(10, AudioManager.STREAM_MUSIC,5);
final int load = snd.load(actualDefaultRingtoneUri.getPath(), 1);
snd.setOnLoadCompleteListener(new SoundPool.OnLoadCompleteListener() {
@Override
public void onLoadComplete(SoundPool soundPool, int sampleId, int status) {
if (snd != null) {
int mStreamID = snd.play(load, 1.0f, 1.0f, 16, 0, 1.0f);
}
}
});
}
1、new SoundPool(10, AudioManager.STREAM_MUSIC,5);
问题原因:將 ringer mode 設成 silent , silent 會影響 STREAM_SYSTEM,STREAM_RING,STREAM_NOTIFICATION,STREAM_SYSTEM_ENFORCED,STREAM_DTMF 這些 stream。
会影响声音的提示
解决方案:使用AudioManager.STREAM_MUSIC类型
2、onLoadComplete没走到
提示如下log
09-25 13:14:05.707 W/MessageQueue( 2693): Handler (android.media.SoundPool$EventHandler) {59b14bc} sending message to a Handler on a dead thread
09-25 13:14:05.707 W/MessageQueue( 2693): java.lang.IllegalStateException: Handler (android.media.SoundPool$EventHandler) {59b14bc} sending message to a Handler on a dead thread
09-25 13:14:05.707 W/MessageQueue( 2693): at android.os.MessageQueue.enqueueMessage(MessageQueue.java:543)
09-25 13:14:05.707 W/MessageQueue( 2693): at android.os.Handler.enqueueMessage(Handler.java:643)
09-25 13:14:05.707 W/MessageQueue( 2693): at android.os.Handler.sendMessageAtTime(Handler.java:612)
09-25 13:14:05.707 W/MessageQueue( 2693): at android.os.Handler.sendMessageDelayed(Handler.java:582)
09-25 13:14:05.707 W/MessageQueue( 2693): at android.os.Handler.sendMessage(Handler.java:519)
09-25 13:14:05.707 W/MessageQueue( 2693): at android.media.SoundPool.postEventFromNative(SoundPool.java:566)
问题原因:service里调用soundPool,在load之前service结束。导致系统回调无法正常进行
解决方案:把soundPool相关代码post到handler中