Звук Media recorder имеет низкое качество

#java #android #firebase #avaudioplayer #android-mediarecorder

#java #Android #firebase #avaudioplayer #android-mediarecorder

Вопрос:

Что я пытаюсь сделать, так это записать звук после того, как загрузить его в firebase, а затем извлечь в reciclerview, где я могу контролировать воспроизведение / остановку и прогресс. Например, звуковые сообщения WhatsApp

Класс AudioPlayer вызывается в основном действии нажатием кнопки и возвращает значение для загрузки файла в firebase.Он работает, но качество звука очень низкое, и он работает только в браузере или непосредственно в исходной папке, или я не могу воспроизвести его в других форматах, таких как THREE_GPP, только когда я воспроизводю его непосредственно в исходной папке.

 public class StartRecordMessage extends AppCompatActivity implements Runnable {

    private static String fileName = null;
    private MediaRecorder myAudioRecorder;
    private MediaPlayer player = null;
    private boolean permissionToRecordAccepted = false;
    private String[] permissions = {Manifest.permission.RECORD_AUDIO};
    private final String TAG = "StartRecordMessageClass";
    private String audioName = null;
    private String externalStoragePath,externalOutputPath,storagePath;

    public StartRecordMessage(MediaRecorder myAudioRecorder) {

        this.myAudioRecorder = myAudioRecorder;
    }


    @Override
    public void run() {

        startRecording();
    }


    public String startRecording (){
        myAudioRecorder = new MediaRecorder();
        myAudioRecorder.reset();
        myAudioRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
     myAudioRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
        myAudioRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);

        if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED))
        {
            externalStoragePath = Environment.getExternalStorageDirectory().getAbsolutePath();
            externalOutputPath = externalStoragePath   File.separator   "/Android/data/test.mp3";
            myAudioRecorder.setOutputFile(externalOutputPath);
        }
        else
        {
            storagePath = Environment.getDataDirectory().getAbsolutePath();
            myAudioRecorder.setOutputFile(storagePath   "/Android/data/test.mp3");
        }


        try {
            Log.i(TAG, "--------------recording started confirmed"   externalOutputPath   storagePath );
            myAudioRecorder.prepare();
            myAudioRecorder.start();
        } catch (IllegalStateException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        if (externalOutputPath.isEmpty()){
            return storagePath;
        }else {
            return externalOutputPath;
        }
    }
  

Метод следования находится в основном действии

 @Override
public void onRecordingCompleted() {
    Log.i(TAG, "---------completed");
    startThread = new Thread(new StartRecordMessage(myAudioRecorder));
    startThread.start();

        startRecordMessage = new StartRecordMessage(myAudioRecorder);
        audioMessage = startRecordMessage.startRecording();

        Log.i(TAG, "recordingCompleted--------------"   audioMessage);

       UploadSound(audioMessage);

}
    messageListAdapter.notifyDataSetChanged();
}
  

AudioPlayerClass

 public class AudioPlayer {

    public static void play(Context ctx, String path) {
        try {
            final AudioManager audioManager = (AudioManager) ctx.getSystemService(Context.AUDIO_SERVICE);
            final int currentVolume = audioManager.getStreamVolume(AudioManager.STREAM_MUSIC);

            final MediaPlayer mediaPlayer = MediaPlayer.create(ctx, Uri.parse(path));

            mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
                @Override
                public void onCompletion(MediaPlayer mp) {
                    if (!audioManager.isWiredHeadsetOn()) {
                        audioManager.setStreamVolume(AudioManager.STREAM_MUSIC, currentVolume, AudioManager.FLAG_VIBRATE);
                    }
                    mp.release();
                }
            });

            mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
                @Override
                public void onPrepared(MediaPlayer mp) {

                    if (!audioManager.isWiredHeadsetOn()) {
                        int volume = audioManager.getStreamMaxVolume(AudioManager.STREAM_MUSIC) / 2;
                        audioManager.setStreamVolume(AudioManager.STREAM_MUSIC, volume, AudioManager.FLAG_VIBRATE);
                    }
                    mp.start();

                }

            });

        }      catch(
                Throwable e)

        {
            Log.i("AudioUtil", "Unable to play: "   path, e);
        }
    }
}
  

AdapterClass

             holder.playStop.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                clickCount  ;

                if (clickCount==1) {
                    isPlayng=true;
                    holder.playStop.setBackgroundResource(R.drawable.ic_pause);

                    Log.i(TAG,"audio url---------------"   audio);

                    audioPlayer = new AudioPlayer();
                    audioPlayer.play(context,audio);

                    Log.i(TAG, "Media player ------------"  clickCount   " is play:  "  isPlayng);
                }

                if (clickCount>1){
                    isPlayng=false;
                    clickCount=0;
                    holder.playStop.setBackgroundResource(R.drawable.ic_play);
                    Log.i(TAG, "Media player ------------"   clickCount   " is play:  "   isPlayng);


                }
            }

        });
  

Следующая ошибка возникает, когда я хочу воспроизвести звук. Класс
Класс аудиоплеера вызывается в классе адаптера, но проблема заключается в
URL.

https://firebasestorage.googleapis.com/v0/b/chat-b18d3.appspot.com/o/Audio%….. 2020-11-12 22:59:44.739 2621-2621 I / AudioUtil: Невозможно воспроизвести: https://firebasestorage.googleapis.com/v0/b/chat-b18d3.appspot.com/o/Audio %….. java.lang.Исключение NullPointerException: попытка вызвать виртуальный метод ‘java.lang.Объект android.content.Context.getSystemService(java.lang.Строка)’ на нулевой ссылке на объект в com.example ….ChatRecord.AudioPlayer.play(AudioPlayer.java: 13) в com.example.chatMapOriginal.Профиль.Чат.Мои группы.GroupChatAdapter$ 1.onClick(GroupChatAdapter.java: 137) на android.view.View.performClick(View.java: 7192) на android.view.View.performClickInternal(View.java: 7166) на android.view.View.access$ 3500(View.java: 824) наandroid.view.View$performClick.run(View.java: 27592) в android.os.Handler.handleCallback(Handler.java: 888) в android.os.Handler.DispatchMessage(Handler.java:100) в android.os.Looper.loop(Looper.java: 213) в android.app.ActivityThread.main(ActivityThread.java: 8178) в java.lang.reflect.Метод.invoke(собственный метод) в com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:513) в com.android.internal.os.ZygoteInit.main(ZygoteInit.java: 1101)

Комментарии:

1. Пожалуйста, не используйте режим выделения / цитаты для вашего текста

Ответ №1:

попробуйте добавить значения в свой медиафайл.

пример.

 // Setup values for the media file
ContentValues values = new ContentValues(4);
long current = System.currentTimeMillis();
values.put(MediaStore.Audio.Media.TITLE, "audio file");
values.put(MediaStore.Audio.Media.DATE_ADDED, (int) (current / 1000));
values.put(MediaStore.Audio.Media.MIME_TYPE, "audio/3gpp");
values.put(MediaStore.Audio.Media.DATA, audiofile.getAbsolutePath());
ContentResolver contentResolver = getContentResolver();
// Construct uris
Uri base = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
Uri newUri = contentResolver.insert(base, values);
// Trigger broadcast to add
sendBroadcast(new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE, newUri));
Toast.makeText(this, "Added File "   newUri, Toast.LENGTH_LONG).show();
  

этот код отсюда