Я использовал и попробовал MediaRecorder.AudioSource.REMOTE_SUBMIX во время записи поверхности экрана, приложение вылетает из-за проблемы с разрешениями, протестировано в HT C 10 [с корнем superSu , установленным в нем].
Хотя он работает для следующих входов:
mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.DEFAULT);
Я хочу записать внутренний / выходной звук системы без использования mi c. Требование: мне нужно записывать активность экрана вместе со звуком (без использования микрофона), пока включен рекордер экрана, если YouTube воспроизводится, мне нужно записать его звук вместе с действиями на экране (без использования mi c). Я сталкиваюсь с проблемой только с аудио-частью, пожалуйста, предложите
private void initRecorder() {
try {
mMediaRecorder.setAudioSource(MediaRecorder.AudioSource.REMOTE_SUBMIX);
mMediaRecorder.setVideoSource(MediaRecorder.VideoSource.SURFACE);
mMediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
mMediaRecorder.setOutputFile(Environment
.getExternalStoragePublicDirectory(Environment
.DIRECTORY_DOWNLOADS) + "/video.mp4");
mMediaRecorder.setVideoSize(DISPLAY_WIDTH, DISPLAY_HEIGHT);
mMediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H264);
mMediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
mMediaRecorder.setVideoEncodingBitRate(512 * 1000);
mMediaRecorder.setVideoFrameRate(30);
int rotation = getWindowManager().getDefaultDisplay().getRotation();
int orientation = ORIENTATIONS.get(rotation + 90);
mMediaRecorder.setOrientationHint(orientation);
mMediaRecorder.prepare();
} catch (IOException e) {
e.printStackTrace();
}
}
Начать запись, появится диалоговое окно с разрешениями и создание следующей записи Logcat
2020-01-27 12:38:19.463 3958-3958/com.truiton.screencapture E/MediaRecorder: prepare failed: -2147483648
Нажатие на start теперь (разрешение пользователя) делает приложение cra sh со следующим logcat outpout
2020-01-27 12:55:09.174 12787-12787/com.truiton.screencapture E/MediaRecorder: start called in an invalid state: 0
2020-01-27 12:55:09.178 12787-12787/com.truiton.screencapture E/MediaRecorder: Failed to start recording
java.lang.IllegalStateException
at android.media.MediaRecorder._start(Native Method)
at android.media.MediaRecorder.start(MediaRecorder.java:1063)
at com.truiton.screencapture.MainActivity.onActivityResult(MainActivity.java:122)
at android.app.Activity.dispatchActivityResult(Activity.java:7246)
at android.app.ActivityThread.deliverResults(ActivityThread.java:4577)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:4631)
at android.app.ActivityThread.-wrap19(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1699)
at android.os.Handler.dispatchMessage(Handler.java:105)
at android.os.Looper.loop(Looper.java:180)
at android.app.ActivityThread.main(ActivityThread.java:6944)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:835)
2020-01-27 12:55:09.183 12787-12787/com.truiton.screencapture E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.truiton.screencapture, PID: 12787
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1000, result=-1, data=Intent { (has extras) }} to activity {com.truiton.screencapture/com.truiton.screencapture.MainActivity}: java.lang.IllegalStateException
at android.app.ActivityThread.deliverResults(ActivityThread.java:4581)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:4631)
at android.app.ActivityThread.-wrap19(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1699)
at android.os.Handler.dispatchMessage(Handler.java:105)
at android.os.Looper.loop(Looper.java:180)
at android.app.ActivityThread.main(ActivityThread.java:6944)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:835)
Caused by: java.lang.IllegalStateException
at android.media.MediaRecorder._start(Native Method)
at android.media.MediaRecorder.start(MediaRecorder.java:1063)
at com.truiton.screencapture.MainActivity.onActivityResult(MainActivity.java:122)
at android.app.Activity.dispatchActivityResult(Activity.java:7246)
at android.app.ActivityThread.deliverResults(ActivityThread.java:4577)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:4631)
at android.app.ActivityThread.-wrap19(Unknown Source:0)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1699)
at android.os.Handler.dispatchMessage(Handler.java:105)
at android.os.Looper.loop(Looper.java:180)
at android.app.ActivityThread.main(ActivityThread.java:6944)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:835)