Ошибка Android Visualizer только в Android 6.0
Я обнаружил одну проблему, связанную с Visualizer, которая имеет место только на устройствах Android 6.0. Не знаю, почему это происходит, поэтому любая помощь будет признательна. Вот стек ошибок:
AudioEffect: set(): AudioFlinger could not create effect, status: -1
visualizers-JNI: Visualizer initCheck failed -3
Visualizer-JAVA: Error code -3 when initializing Visualizer.
java.lang.RuntimeException: Cannot initialize Visualizer engine, error: -3
System.err: at android.media.audiofx.Visualizer.<init>(Visualizer.java:218)
System.err: at com.xxx.xxxx.customviews.visualizer.VisualizerView.link(VisualizerView.java:101)
и вот код, который вызывает это:
public void link(MediaPlayer player) {
if (player == null) {
throw new NullPointerException("Cannot link to null MediaPlayer");
}
Equalizer mEqualizer = new Equalizer(0, player.getAudioSessionId());
mEqualizer.setEnabled(true); // need to enable equalizer
try {
int aud = player.getAudioSessionId();
**mVisualizer = new Visualizer(aud);**
mVisualizer.setEnabled(false);
mVisualizer.setCaptureSize(Visualizer.getCaptureSizeRange()[1]);
Visualizer.OnDataCaptureListener captureListener = new Visualizer.OnDataCaptureListener() {
@Override
public void onWaveFormDataCapture(Visualizer visualizer, byte[] bytes, int samplingRate) {
updateVisualizer(bytes);
}
@Override
public void onFftDataCapture(Visualizer visualizer, byte[] bytes, int samplingRate) {
updateVisualizerFFT(bytes);
}
};
mVisualizer.setDataCaptureListener(captureListener, Visualizer.getMaxCaptureRate() / 2, true, true);
mVisualizer.setEnabled(true);
player.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mediaPlayer) {
mVisualizer.setEnabled(false);
}
});
}catch(Exception e) {
e.printStackTrace();
}
}
Любая помощь будет оценена. Заранее спасибо =)
4 ответа
Может быть, нижележащему компоненту (-ам) нужны некоторые разрешения, которые не предоставляются автоматически в 6.0. Перейти к AppInfo для этого приложения; перейти к разрешениям; Убедитесь, что все разрешения, запрошенные этим приложением, были предоставлены.
Убедитесь, что у вас есть это разрешение в вашем Манифесте, как того требует визуализатор.
<uses-permission android:name="android.permission.RECORD_AUDIO"/>
Поскольку это разрешение "опасно", вам также необходимо попросить пользователя предоставить разрешение во время выполнения.
Это сводило меня с ума в течение нескольких недель... Я сосредоточился на своем Visualizer
код, в котором система разрешений 6.0 была проблемой. Я проверил это на 4.2.2, 5.0 и 6.0.1 на реальных устройствах. Я до сих пор не знаю, почему диалоговое окно разрешений не появляется, когда я тестирую приложение на реальных устройствах. Кроме того, вручную включив Microphone
разрешение решило проблему, в настройках App Info.
if (ActivityCompat.checkSelfPermission(context, Manifest.permission.RECORD_AUDIO) != PackageManager.PERMISSION_GRANTED)
{
requestPermissions(new String[]{android.Manifest.permission.RECORD_AUDIO}, 1);
}
Можете ли вы попробовать добавить в свой список разрешений в файле манифеста:
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS"/>