Неверное состояние устройства записи звука (неверный путь к файлу?) - PullRequest
0 голосов
/ 11 ноября 2018

У меня есть рекордер, который я пытаюсь сделать, чтобы проверить его и посмотреть, как он работает. Однако, когда я запускаю его, я получаю сообщение об ошибке:

E/MediaRecorder: start called in an invalid state: 4

Итак, я сделал googlejitzu и выяснил, что мой путь к файлу неверен. Это мой код:

final MediaRecorder recorder = new MediaRecorder();
    recorder.setAudioSource(MediaRecorder.AudioSource.MIC);
    recorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
    recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
    recorder.setOutputFile("Test");

    System.out.println("Hello");
    try {
        recorder.prepare();
    } catch (IOException e) {
        e.printStackTrace();

    }
    recorder.start();
    CountDownTimer countDownTimer = new CountDownTimer(30000, 1000) {
        @Override
        public void onTick(long l) {

        }

        @Override
        public void onFinish() {
            recorder.stop();
        }
    }.start();

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

Ошибка:

    11-11 01:49:48.275 23703-23703/com.example.arege.dayatalisten W/System.err: java.io.FileNotFoundException: Test: open failed: EROFS (Read-only file system)
11-11 01:49:48.276 23703-23703/com.example.arege.dayatalisten W/System.err:     at libcore.io.IoBridge.open(IoBridge.java:455)
        at java.io.RandomAccessFile.<init>(RandomAccessFile.java:247)
        at java.io.RandomAccessFile.<init>(RandomAccessFile.java:128)
        at android.media.MediaRecorder.prepare(MediaRecorder.java:834)
        at com.example.arege.dayatalisten.ListeningToTheWorld.onStartCommand(ListeningToTheWorld.java:47)
        at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:3432)
        at android.app.ActivityThread.-wrap21(ActivityThread.java)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1633)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:154)
        at android.app.ActivityThread.main(ActivityThread.java:6316)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:872)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:762)
    Caused by: android.system.ErrnoException: open failed: EROFS (Read-only file system)
11-11 01:49:48.277 23703-23703/com.example.arege.dayatalisten W/System.err:     at libcore.io.Posix.open(Native Method)
        at libcore.io.BlockGuardOs.open(BlockGuardOs.java:187)
        at libcore.io.IoBridge.open(IoBridge.java:441)
        ... 13 more

У меня есть оба необходимых разрешения.

1 Ответ

0 голосов
/ 11 ноября 2018

Вы пытаетесь записать во внутреннее хранилище, к которому у вашего приложения нет доступа. Это не рутированное устройство.

Вам необходимо записать свой файл на внешнее хранилище.

Используйте либо: getFilesDir() or getExternalFilesDir() (в контексте или действии), чтобы получить каталог и записать файл в это место.

Psuedocode:

File file = new File(context.getFilesDir(), "Test");
FileOutputStream outputStream = new FileOutputStream(file);
outputStream.write("contents".getBytes());
outputStream.close();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...