Ошибка 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"/>
Другие вопросы по тегам