Ошибка запуска MediaRecorder: -38
Я искал, чтобы проверить , если этот вопрос не dup, я вижу, что у некоторых нет ответа, а другие не помогли.
Это мой код :
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)
спасибо.
2 ответов
нашел решение , похоже, у меня была какая-то другая служба в фоновом режиме, которая использует AudioRecord и использует микрофон, а также.... так вот в -38 :)
в моем случае эта ошибка (MediaRecorder: start failed: -38
) появлялся после переключения на вторую камеру, когда я забыл выпустить MediaRecorder во время закрытия (первой) камеры:
mediaRecorder?.release()
mediaRecorder = null