Ошибка запуска MediaRecorder: -38

я искал, чтобы проверить, не является ли этот вопрос дубликатом, я вижу, что на некоторые из них нет ответа, а другие не помогли.

это мой код:

private void startRecording()
{
            mRecorder = new MediaRecorder();
            mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
            mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
            mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);

            mFileName = Environment.getExternalStorageDirectory().getAbsolutePath();
              mFileName += "/recordedHeckPost_.3gp";

            mRecorder.setOutputFile(mFileName);                  

                try {
                    mRecorder.prepare();
                    //Thread.sleep(2000);
                    mRecorder.start();                  
        }
                catch (InterruptedException e) 
                {   // TODO Auto-generated catch block
            e.printStackTrace();
        }     
            catch(IllegalStateException e)
            {
                e.printStackTrace();
            } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
}

private void stopRecording()
{
        mRecorder.stop();
        mRecorder.release();
        mRecorder = null;
}

После запуска этого кода (на Nexus 5) я получаю следующее начало неудачное исключение -38:

05-31 18:17:39.404: E/MediaRecorder(2464): start failed: -38
05-31 18:17:39.404: W/System.err(2464): java.lang.IllegalStateException
05-31 18:17:39.404: W/System.err(2464):     at android.media.MediaRecorder.start(Native Method)

Спасибо.


person Robocide    schedule 31.05.2014    source источник


Ответы (2)


Нашел решение, похоже, у меня была какая-то другая служба в фоновом режиме, которая использует AudioRecord и также использует микрофон .... так что это -38 :)

person Robocide    schedule 31.05.2014
comment
Какой именно фоновой службой это было? - person Vinay Gaba; 04.11.2014
comment
Это был один из моих сервисов приложений, а не ОС. - person Robocide; 04.11.2014
comment
Нашел! Из другого приложения я проверил, чей значок я скрыл! Черт, я бы никогда не понял этого без ответа о другой службе в фоновом режиме. Спасибо! - person Vinay Gaba; 04.11.2014
comment
как я могу найти эту другую службу, работающую в фоновом режиме для записи или использования микрофона? - person SRam; 12.01.2017
comment
просто проверьте исходный код своего приложения на наличие строк AudioRecord или MediaRecorder.... или каким-либо другим способом узнать, есть ли у вас код, использующий микрофон.... - person Robocide; 31.05.2017
comment
Вы нашли какое-нибудь решение, чтобы исправить это, не удаляя фоновые службы? Я использую github.com/JorenSix/TarsosDSP для определения высоты тона микрофона при записи видео. Так что не могли бы вы помочь мне решить эту проблему. - person hasan_shaikh; 05.04.2018

В моем случае эта ошибка (MediaRecorder: start failed: -38) появлялась после переключения на вторую камеру, когда я забыл отпустить MediaRecorder во время закрытия (первой) камеры:

mediaRecorder?.release()
mediaRecorder = null
person Francis    schedule 10.08.2018