- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我可以使用 MediaRecorder 或 AudioRecord 同时录制多个 channel 吗?我想要的是能够同时录制 MediaRecorder.AudioSource.VOICE_UPLINK 和 VOICE_DOWNLINK。可以分为两个单独的文件或具有两个 channel 的同一文件。我尝试使用两个单独的 MediaRecorder 实例。但只有第一个记录。第二个说输入不可用。我还尝试同时使用一个 MediaRecorder 和一个 AudioRecord。同样,两者都单独工作,但是当 AudioRecord 在 MediaRecorder 启动后出现时,会显示以下错误。
05-21 03:40:42.735: E/AudioRecord(1322): Could not get audio input for record source 1
05-21 03:40:42.735: E/AudioRecord-JNI(1322): Error creating AudioRecord instance: initialization check failed.
05-21 03:40:42.825: E/AudioRecord-Java(1322): [ android.media.AudioRecord ] Error code -20 when initializing native AudioRecord object.
我还尝试将第二个 MediaRecorder 放在一个新线程上。同样的结果。所以这让我想知道是否有可能同时记录。我也在考虑是否可以使用一个 AudioRecord 和两个 channel 设置来自 VOICE_UPLINK 和 VOICE_DOWNLINK 的两个独立输入,但我不知道如何设置源(如果可能的话)。
提前致谢
编辑:
Lucifer 的回答意味着 AudioRecord 不能异步调用,同时运行多个实例。有谁知道可以同时录制 AudioSource.VOICE_UPLINK 和 AudioSource.VOICE_DOWNLINK 的方法吗?也许使用具有多个 channel 的单个 AudioRecord 实例?
最佳答案
据我所知,AudioRecording 是一种同步方法。所以你不能同时做两个录音。
当您的代码进行第二次录制过程时,它显示错误 05-21 03:40:42.735: E/AudioRecord(1322): Could not get audio input for record source 1
这纯粹意味着 Recording Channel 已经被 First 忙了。
然而,这可以通过并行处理两个线程来实现,第一个线程记录特定时间量的方式。当控制通过两个第二个线程时,第一个线程停止录制,第二个线程开始录制,反之亦然。但对于移动设备,这将变得更加复杂。所以最好一次录制一个 channel 。
你可以创建一个录音队列,一个一个的录音。
关于android - 在 Android MediaRecorder 或使用 AudioRecord 上同时录制两个 channel ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10681634/
Android:我想从麦克风读取缓冲区以便我可以对其执行处理,以下是我的代码 int sampleRateInHz = 8000;// 44100, 22050 and 11025 i
我正在尝试在我的 Android 应用程序中将音频读取为 16 位整数。我使用 Xamarin.android 编写了这个应用程序。我为此使用 AudioRecord 低级库,因为我需要从手机麦克风读
访问AudioRecord.Builder的正确方法是什么?在 JNI 级别? 类似于AudioRecord类。 (jclass)jni_env->NewGlobalRef(jni_env->Find
嗨,我正在构建一个应用程序,它将使用来自 MIC 的传入音频并将其与存储的声音文件进行比较。目前,我正试图掌握 AudioRecord 函数中的数据在保存到字节数组时的样子。我的问题是返回的值都是零。
我打算在 Android 4.4.2 设备上录制立体声音频。但是,通过简单的录音应用程序(使用 AudioRecord)录制的音频与提供的配置不匹配。如果设备使用默认配置值,我希望在 logcat 中
我已经构建了一个监听背景噪音的应用程序。我发现,在收听时,用户无法调用电话或使用任何其他录制音频的应用程序。我想知道是否有一种方法可以在通话之前同时允许录制音频或显式禁用声音?这将如何实现? 最佳答案
请同时查看我的其他问题,因为我认为它们是相关的: Question 1 Question 2 Question 3 这是我正在使用的代码,当我按下按钮时,它将麦克风获得的音频信号传递到扬声器: pub
我在使用 AudioRecord 时遇到问题。 我正在开发一个应用程序,需要记录来自 MIC 的一些脉冲响应并用它制作一些 DSP。 捕获的音频存储在 WAV 文件中,然后从该文件绘制。 我创建了一个
我已经在我的 android 应用程序中使用 Mic 进行了录音,当使用 AudioPlayer 类将数据流式传输进来时,它播放得非常好。我的问题是我想向该数据附加一个 wav header ,以便它
我正在使用 AudioRecord 类录制音频。我想将音频录制到我的 Assets 文件夹或资源文件夹中的特定文件中。我认为录制没有问题。但是在读取缓冲区时它显示出一些问题(它正在抛出NullPoin
我目前正在开始为 Android 编写一个软件,该软件将要测量封闭房间的混响时间。 我不得不选择 AudioRecord而不是 MediaRecorder因为它让我有机会获得原始数据。 您可能知道 A
我使用 AudioRecorder 记录了 50 毫秒(10-12KHz 频率)的线性调频信号。在安静的房间里,距离为 50/60 厘米时,信号频谱图如下所示 背景中有很多噪音,还有一些回声。我想知道
我在使用 AudioRecord for Android 时遇到了问题。我已经尽可能多地在网上找到有关它的信息,但我似乎无法进行良好的初始化。 我创建 AudioRecord 对象的代码是这样的:
我想录制音频并以 WAV 格式播放。我必须使用 AudioRecord 来完成。有人可以帮我吗? 我经历了这个例子, http://androidsourcecode.blogspot.com.au/
我编写了一个标准代码,用于使用 AudioRecord 从麦克风接收数据。这是我的代码: AudioReceiver() { int minHardwareBufferSize = Audio
我的实验是这样的:首先,我使用matlab创建一个指定的wave文件,速率为44100,这意味着任何持续1s的 fragment 都包含44100个元素,这些元素以double形式呈现。然后,我使用智
我只在 Motorola Milestone 上遇到这个问题。代码: // init recorder recordInstance = new AudioRecord(MediaRecorder.A
我正在努力解决这个问题,我已经更改了比特率以减小录制文件的大小,我的应用程序正确地将音频文件发布到服务器,但我想最小化文件大小,这是我的录制代码 private void startRecordin
我正在尝试使用 AudioRecord 从麦克风录制一些音频。录音有效,但音量太大,而且我的剪报很糟糕。我尝试使用 AutomaticGainControl,但它在我的设备上不可用。有没有其他方法可以
我看了很多关于 AudioRecorder 初始化问题的帖子,所以我用一个函数来测试每一种可能性。不幸的是,没有工作的。我应该检查什么? @Override public void onCreat
我是一名优秀的程序员,十分优秀!