Nano Hash - криптовалюты, майнинг, программирование

Мое приложение для записи звука не может начать запись

Мое приложение выдает исключение IOException, когда я пытаюсь записать звук. java.io.FileNotFoundException: /storage/emulated/0/recording.3gp: ошибка открытия: EACCES (отказано в доступе). Это происходит внутри моего метода recordButton.SetOnClickListener, а точнее в части try-catch моего кода. Я действительно не знаю, почему это терпит неудачу, но у меня есть ощущение, что это как-то связано с моей строкой outputFile. Вот мой файл JAVA:

    package com.example.audiorecorder;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;

import android.Manifest;
import android.content.pm.PackageManager;
import android.media.MediaPlayer;
import android.media.MediaRecorder;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import java.io.IOException;

public class MainActivity extends AppCompatActivity {

Button playBtn, recordBtn, stopBtn;

String outputFile;

MediaRecorder mediaRecorder;

private static final int REQUEST_RECORD_AUDIO_PERMISSION = 200;

private boolean permissionToRecordAccepted = false;
private String [] permissions = {Manifest.permission.RECORD_AUDIO};

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull         int[] grantResults) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);
    switch (requestCode){
        case REQUEST_RECORD_AUDIO_PERMISSION:
            permissionToRecordAccepted  = grantResults[0] == PackageManager.PERMISSION_GRANTED;
            break;
    }
    if (!permissionToRecordAccepted ) finish();

}


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    ActivityCompat.requestPermissions(this, permissions, REQUEST_RECORD_AUDIO_PERMISSION);

    outputFile = Environment.getExternalStorageDirectory().getAbsolutePath() + "/recording.3gp";

    playBtn = findViewById(R.id.play_btn);
    recordBtn = findViewById(R.id.record_btn);
    stopBtn = findViewById(R.id.stop_btn);

    mediaRecorder = new MediaRecorder();

    mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
    mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
    mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
    mediaRecorder.setOutputFile(outputFile);


    recordBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            try{
                mediaRecorder.prepare();
                mediaRecorder.start();
                Toast.makeText(getApplicationContext(), "Recording started", Toast.LENGTH_LONG).show();
                System.out.println("IT TRIED RECORDING");
            } catch (IllegalStateException ise){
                System.out.println("FAIL RECORDING 1");
            } catch (IOException ioe){
                System.out.println("FAIL RECORDING 2");
            }

            System.out.println("ITS JUST PRESSING RECORD BUT NOTHING");

        }
    });

    stopBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            try{
                mediaRecorder.stop();
                mediaRecorder.release();
                mediaRecorder = null;
                System.out.println("IT TRIED STOPPING");

            } catch (Exception e){
                System.out.println("FAIL STOP 1");
            }

            Toast.makeText(getApplicationContext(), "Stop Recording", Toast.LENGTH_LONG).show();

        }
    });

    playBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            MediaPlayer mediaPlayer = new MediaPlayer();
            try {
                mediaPlayer.setDataSource(outputFile);
                mediaPlayer.prepare();
                mediaPlayer.start();
                Toast.makeText(getApplicationContext(), "Playing Audio", Toast.LENGTH_LONG).show();
            } catch (Exception e) {
                // make something
            }
        }
    });

}
}

Вот мой XML-файл:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity">

<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center_horizontal"
    android:layout_marginTop="40dp"
    android:textStyle="bold"
    android:text="RECORDER TEST LAB"
    android:textColor="#000000"
    android:textSize="24dp"
    />

<RelativeLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:padding="5dp"
    android:background="#000000"
    android:layout_marginTop="10dp"
    >

<Button
    android:id="@+id/record_btn"
    android:layout_height="80dp"
    android:layout_width="match_parent"
    android:textSize="22dp"
    android:background="#E70D0D"
    android:text="record"
    android:textStyle="bold"

    >

</Button>

</RelativeLayout>

<RelativeLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:padding="5dp"
    android:background="#000000"
    android:layout_marginTop="10dp"
    >

    <Button
        android:id="@+id/stop_btn"
        android:layout_height="80dp"
        android:layout_width="match_parent"
        android:textSize="22dp"
        android:background="#E70D0D"
        android:text="stop"
        android:textStyle="bold"

        >

    </Button>

</RelativeLayout>

<RelativeLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:padding="5dp"
    android:background="#000000"
    android:layout_marginTop="10dp"
    >

    <Button
        android:id="@+id/play_btn"
        android:layout_height="80dp"
        android:layout_width="match_parent"
        android:text="Play"
        android:textSize="22dp"
        android:background="#35E70D"
        android:textStyle="bold"
        />

</RelativeLayout>

Here is my android manifest:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.audiorecorder">

<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.STORAGE"/>

<application
android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:roundIcon="@mipmap/ic_launcher_round"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

Thank you in advance for your help. I will upvote an answer that helps me out!


  • @Ryan Mentley вот оно: java.io.FileNotFoundException: /storage/emulated/0/recording.3gp: ошибка открытия: EACCES (отказано в доступе) 23.01.2020
  • Это не детали. Пожалуйста, прочитайте Какие детали нам нужны? раздел связанной страницы. 23.01.2020
  • @ Райан Ментли, есть ли уже опубликованный вопрос (относящийся к медиа-рекордеру Android), на который вы можете мне направить, который может мне помочь? Я был бы очень признателен. 23.01.2020
  • Я полагаю, вы забыли добавить разрешение на чтение внешнего хранилища, попробуйте добавить: ‹uses-permission android:name=android.permission.READ_EXTERNAL_STORAGE/› в манифест Android. Также, если ваш уровень Android API ›= 23, вы должны запросить разрешение на доступ к файлам во время выполнения, используя ActivityCompat.requestPermissions. 23.01.2020
  • @easy_breezy Спасибо за ответ. Я собирался сдаться. Я добавил разрешение, но здесь все равно не работает: E/ExceptionTag: /storage/emulated/0/recording.3gp: open failed: EACCES (разрешение отклонено) java.io.FileNotFoundException: /storage/emulated/0/recording.3gp: Ошибка открытия: EACCES (отказано в доступе) в libcore.io.IoBridge.open(IoBridge.java:485) в java.io.RandomAccessFile.‹init›(RandomAccessFile.java:151) в android.media.MediaRecorder.prepare(MediaRecorder .java:1288) в com.example.audiorecorder.MainActivity$1.onClick(MainActivity.java:71) 23.01.2020

Ответы:


1

Вы также забыли запросить разрешение для WRITE_EXTERNAL_STORAGE.

String[] permissions = { Manifest.permission.RECORD_AUDIO, Manifest.permission.WRITE_EXTERNAL_STORAGE };
ActivityCompat.requestPermissions(this, permissions, PERMISSIONS_REQUEST_CODE);
23.01.2020
  • Спасибо за ответ, буду тестировать! 23.01.2020
  • @Mr.Octodood, какие коды вы пишете для «PERMISSIONS_REQUEST_CODE»? заранее спасибо. 02.06.2021
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

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

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

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

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..