音频录制流管理

2024-02-16 13:56 更新

对于录制音频类的应用,开发者需要关注该应用的音频流的状态以做出相应的操作,比如监听到状态为结束时,及时提示用户录制已结束。

读取或监听应用内音频流状态变化

参考使用AudioCapturer开发音频录制功能audio.createAudioCapturer,完成AudioCapturer的创建,然后可以通过以下两种方式查看音频流状态的变化:

  • 方法1:直接查看AudioCapturer的state
    1. let audioCapturerState = audioCapturer.state;
    2. console.info(`Current state is: ${audioCapturerState }`)
  • 方法2:注册stateChange监听AudioCapturer的状态变化:
    1. audioCapturer.on('stateChange', (capturerState) => {
    2. console.info(`State change to: ${capturerState}`)
    3. });

获取state后可对照AudioState来进行相应的操作,比如显示录制结束的提示等。

读取或监听所有录制流的变化

如果部分应用需要查询获取所有音频流的变化信息,可以通过AudioStreamManager读取或监听所有音频流的变化。

如下为音频流管理调用关系图:

在进行应用开发的过程中,开发者需要使用getStreamManager()创建一个AudioStreamManager实例,进而通过该实例管理音频流。开发者可通过调用on('audioCapturerChange')监听音频流的变化,在音频流状态变化、设备变化时获得通知,同时可通过off('audioCapturerChange')取消相关事件的监听。另外,开发者可以通过主动调用getCurrentAudioCapturerInfoArray()查询录制流的唯一ID、录制流客户端的UID、以及流状态等信息。

详细API含义可参考音频管理API文档AudioStreamManager

开发步骤及注意事项

  1. 创建AudioStreamManager实例。
    在使用AudioStreamManager的API前,需要使用getStreamManager()创建一个AudioStreamManager实例。
    1. import audio from '@ohos.multimedia.audio';
    2. let audioManager = audio.getAudioManager();
    3. let audioStreamManager = audioManager.getStreamManager();
  2. 使用on('audioCapturerChange')监听音频录制流更改事件。 如果音频流监听应用需要在音频录制流状态变化、设备变化时获取通知,可以订阅该事件。
    1. audioStreamManager.on('audioCapturerChange', (AudioCapturerChangeInfoArray) => {
    2. for (let i = 0; i < AudioCapturerChangeInfoArray.length; i++) {
    3. console.info(`## CapChange on is called for element ${i} ##`);
    4. console.info(`StreamId for ${i} is: ${AudioCapturerChangeInfoArray[i].streamId}`);
    5. console.info(`Source for ${i} is: ${AudioCapturerChangeInfoArray[i].capturerInfo.source}`);
    6. console.info(`Flag ${i} is: ${AudioCapturerChangeInfoArray[i].capturerInfo.capturerFlags}`);
    7. let devDescriptor = AudioCapturerChangeInfoArray[i].deviceDescriptors;
    8. for (let j = 0; j < AudioCapturerChangeInfoArray[i].deviceDescriptors.length; j++) {
    9. console.info(`Id: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].id}`);
    10. console.info(`Type: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].deviceType}`);
    11. console.info(`Role: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].deviceRole}`);
    12. console.info(`Name: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].name}`);
    13. console.info(`Address: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].address}`);
    14. console.info(`SampleRates: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].sampleRates[0]}`);
    15. console.info(`ChannelCounts ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].channelCounts[0]}`);
    16. console.info(`ChannelMask: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].channelMasks}`);
    17. }
    18. }
    19. });
  3. (可选)使用off('audioCapturerChange')取消监听音频录制流变化。
    1. audioStreamManager.off('audioCapturerChange');
    2. console.info('CapturerChange Off is called');
  4. (可选)使用getCurrentAudioCapturerInfoArray()获取当前音频录制流的信息。
    该接口可获取音频录制流唯一ID,音频录制客户端的UID,音频状态以及音频捕获器的其他信息。
    说明

    对所有音频流状态进行监听的应用需要申请权限ohos.permission.USE_BLUETOOTH,否则无法获得实际的设备名称和设备地址信息,查询到的设备名称和设备地址(蓝牙设备的相关属性)将为空字符串。

    1. async function getCurrentAudioCapturerInfoArray(){
    2. await audioStreamManager.getCurrentAudioCapturerInfoArray().then( function (AudioCapturerChangeInfoArray) {
    3. console.info('getCurrentAudioCapturerInfoArray **** Get Promise Called ****');
    4. if (AudioCapturerChangeInfoArray != null) {
    5. for (let i = 0; i < AudioCapturerChangeInfoArray.length; i++) {
    6. console.info(`StreamId for ${i} is: ${AudioCapturerChangeInfoArray[i].streamId}`);
    7. console.info(`Source for ${i} is: ${AudioCapturerChangeInfoArray[i].capturerInfo.source}`);
    8. console.info(`Flag ${i} is: ${AudioCapturerChangeInfoArray[i].capturerInfo.capturerFlags}`);
    9. for (let j = 0; j < AudioCapturerChangeInfoArray[i].deviceDescriptors.length; j++) {
    10. console.info(`Id: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].id}`);
    11. console.info(`Type: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].deviceType}`);
    12. console.info(`Role: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].deviceRole}`);
    13. console.info(`Name: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].name}`);
    14. console.info(`Address: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].address}`);
    15. console.info(`SampleRates: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].sampleRates[0]}`);
    16. console.info(`ChannelCounts ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].channelCounts[0]}`);
    17. console.info(`ChannelMask: ${i} : ${AudioCapturerChangeInfoArray[i].deviceDescriptors[j].channelMasks}`);
    18. }
    19. }
    20. }
    21. }).catch((err) => {
    22. console.error(`Invoke getCurrentAudioCapturerInfoArray failed, code is ${err.code}, message is ${err.message}`);
    23. });
    24. }
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号