В настоящее время я разрабатываю приложение для Android, которое воспроизводит звук пользователю через различные промежутки времени. У меня есть рабочий код (см. Ниже), который функционирует точно так, как ожидалось, на моем Hero (работает 2.2) и на эмуляторе 1.6. Тем не менее, это не работает на моих друзей Xperia x8 - звук не воспроизводится. У него есть набор уведомлений, который отлично воспроизводится, когда он получает текст и т.д.
private void prepareAudio(){
alert = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
mp = new MediaPlayer();
if(alert != null){
try {
mp.setDataSource(ctx, alert);
} catch (IllegalArgumentException e) {
Log.i("Prepare Audio", e.getMessage());
} catch (SecurityException e) {
Log.i("Prepare Audio", e.getMessage());
} catch (IllegalStateException e) {
Log.i("Prepare Audio", e.getMessage());
} catch (IOException e) {
Log.i("Prepare Audio", e.getMessage());
}
}
am = (AudioManager)ctx.getSystemService(Context.AUDIO_SERVICE);
}
private void notifyUser(){
if(alert != null){
if (am.getStreamVolume(AudioManager.STREAM_ALARM) != 0) {
mp.setAudioStreamType(AudioManager.STREAM_ALARM);
mp.setLooping(false);
try {
mp.prepare();
} catch (IllegalStateException e) {
Log.i("Notify User", e.getMessage());
} catch (IOException e) {
Log.i("Notify User", e.getMessage());
}
mp.start();
} else {
Log.i("Notify User", "Alarm volume zero");
}
} else {
Log.i("Notify User", "Uri is null");
}
long[] pattern = {0,200,300,600};
v.vibrate(pattern, -1);
}
PrepareAudio вызывается при инициализации класса и notifyUser каждый раз, когда мы хотим воспроизвести звук. Телефон всегда вибрирует, когда это необходимо, поэтому notifyUser определенно называется.
В версии, которую установил мой друг, используется e.printStackTrace, а не Log.i, поэтому в лог-кате не выплескивается. Я собираюсь попытаться завладеть его телефоном, чтобы обновить его до версии с Log.i, но в то же время есть что-то явно неправильное с кодом, который может вызвать такую прерывистую проблему?
Спасибо,
Итак, оказалось, что обновление моей обработки исключений, как указано в исходном сообщении, похоже, устранило проблему.
Если вы используете приведенный выше код для чего-либо, стоит заметить, что иногда e.getMessage() возвращает null, поэтому вместо
Log.i("Notify User", e.getMessage());
использование
Log.i("Notify User", e.getMessage() + "");
Чтобы избежать каких-либо неприятных FC, когда генерируется исключение.
Извините за случайно неопровержимый вопрос!
Не уверен, но в старых версиях Android возникли проблемы с воспроизведением файлов WAV. Являются ли эти файлы WAV или файлы MP3, которые вы пытаетесь воспроизвести?