#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();
этот код отсюда