audio-capturer.md 5.2 KB
Newer Older
Z
zengyawen 已提交
1
# 音频采集开发指导
L
doc  
lwx1059628 已提交
2

L
update  
lwx1059628 已提交
3
## 场景介绍
L
doc  
lwx1059628 已提交
4 5 6

AudioCapturer提供了用于获取原始音频文件的方法。开发者可以通过本指导了解应用如何通过AudioCapturer采集音频。

Z
zengyawen 已提交
7
### 状态检查
L
doc  
lwx1059628 已提交
8 9 10

在进行应用开发的过程中,建议开发者通过on('stateChange')方法订阅AudioCapturer的状态变更。因为针对AudioCapturer的某些操作,仅在音频采集器在固定状态时才能执行。如果应用在音频采集器处于错误状态时执行操作,系统可能会抛出异常或生成其他未定义的行为。

Z
zengyawen 已提交
11 12
详细API含义可参考:[音频管理API文档AudioCapturer](../reference/apis/js-apis-audio.md)

Z
zengyawen 已提交
13 14 15 16
**图1** 音频采集状态机

![](figures/audio-capturer-state.png)

L
doc  
lwx1059628 已提交
17 18
## 开发步骤

Z
zengyawen 已提交
19
1. 使用createAudioCapturer()创建一个AudioCapturer实例。
L
doc  
lwx1059628 已提交
20

Z
zengyawen 已提交
21 22 23
   在audioCapturerOptions中设置音频采集器的相关参数。该实例可用于音频采集、控制和获取采集状态,以及注册通知回调。 

   ```js
L
doc  
lwx1059628 已提交
24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
      var audioStreamInfo = {
           samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_44100,
           channels: audio.AudioChannel.CHANNEL_1,
           sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S16LE,
           encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW
       }
      
       var audioCapturerInfo = {
           source: audio.SourceType.SOURCE_TYPE_MIC,
           capturerFlags: 1
       }
      
       var audioCapturerOptions = {
           streamInfo: audioStreamInfo,
           capturerInfo: audioCapturerInfo
       }
      
       let audioCapturer = await audio.createAudioCapturer(audioCapturerOptions);
       var state = audioRenderer.state;
   ```

L
li-yifan2 已提交
45 46
2. (可选)使用on('stateChange')订阅音频采集器状态更改。
如果应用需要在采集器状态更新时进行一些操作,可以订阅该事件。更多事件请参考[API参考文档](../reference/apis/js-apis-audio.md)
L
li-yifan2 已提交
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76

   ```js
    audioCapturer.on('stateChange',(state) => {
    console.info('AudioCapturerLog: Changed State to : ' + state)
    switch (state) {
     case audio.AudioState.STATE_PREPARED:
         console.info('--------CHANGE IN AUDIO STATE----------PREPARED--------------');
         console.info('Audio State is : Prepared');
         break;
     case audio.AudioState.STATE_RUNNING:
         console.info('--------CHANGE IN AUDIO STATE----------RUNNING--------------');
         console.info('Audio State is : Running');
         break;
     case audio.AudioState.STATE_STOPPED:
         console.info('--------CHANGE IN AUDIO STATE----------STOPPED--------------');
         console.info('Audio State is : stopped');
         break;
     case audio.AudioState.STATE_RELEASED:
         console.info('--------CHANGE IN AUDIO STATE----------RELEASED--------------');
         console.info('Audio State is : released');
         break;
     default:
         console.info('--------CHANGE IN AUDIO STATE----------INVALID--------------');
         console.info('Audio State is : invalid');
         break;
     }
    });
   ```

3. 调用start()方法来启动/恢复采集任务。
Z
zengyawen 已提交
77

L
doc  
lwx1059628 已提交
78 79
   启动完成后,采集器状态将变更为STATE_RUNNING,然后应用可以开始读取缓冲区。

Z
zengyawen 已提交
80
   ```js
L
doc  
lwx1059628 已提交
81 82 83 84 85 86 87 88
   await audioCapturer.start();
   if (audioCapturer.state == audio.AudioState.STATE_RUNNING) {
       console.info('AudioRecLog: Capturer started');
   } else {
       console.info('AudioRecLog: Capturer start failed');
   }
   ```

L
li-yifan2 已提交
89
4. 使用getBufferSize()方法获取要读取的最小缓冲区大小。
L
doc  
lwx1059628 已提交
90

Z
zengyawen 已提交
91
   ```js
L
doc  
lwx1059628 已提交
92 93 94 95
   var bufferSize = await audioCapturer.getBufferSize();
   console.info('AudioRecLog: buffer size: ' + bufferSize);
   ```

L
li-yifan2 已提交
96
5. 读取采集器的音频数据并将其转换为字节流。重复调用read()方法读取数据,直到应用准备停止采集。   
Z
zengyawen 已提交
97

L
doc  
lwx1059628 已提交
98 99
   参考以下示例,将采集到的数据写入文件。 

Z
zengyawen 已提交
100
   ```js
L
doc  
lwx1059628 已提交
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
   import fileio from '@ohos.fileio';
      
   const path = '/data/data/.pulse_dir/capture_js.wav';
   let fd = fileio.openSync(path, 0o102, 0o777);
   if (fd !== null) {
       console.info('AudioRecLog: file fd created');
   }
   else{
       console.info('AudioRecLog: file fd create : FAILED');
       return;
   }
      
   fd = fileio.openSync(path, 0o2002, 0o666);
   if (fd !== null) {
       console.info('AudioRecLog: file fd opened in append mode');
   }
      
   var numBuffersToCapture = 150;
   while (numBuffersToCapture) {
       var buffer = await audioCapturer.read(bufferSize, true);
       if (typeof(buffer) == undefined) {
           console.info('read buffer failed');
       } else {
           var number = fileio.writeSync(fd, buffer);
           console.info('AudioRecLog: data written: ' + number);
       }
      
       numBuffersToCapture--;
   }
   ```

L
li-yifan2 已提交
132
6. 采集完成后,调用stop方法,停止录制。
L
doc  
lwx1059628 已提交
133 134 135 136 137 138 139 140 141 142

   ```
   await audioCapturer.stop();
   if (audioCapturer.state == audio.AudioState.STATE_STOPPED) {
       console.info('AudioRecLog: Capturer stopped');
   } else {
       console.info('AudioRecLog: Capturer stop failed');
   }
   ```

L
li-yifan2 已提交
143
7. 任务结束,调用release()方法释放相关资源。
L
doc  
lwx1059628 已提交
144

Z
zengyawen 已提交
145
   ```js
L
doc  
lwx1059628 已提交
146 147 148 149 150 151 152
   await audioCapturer.release();
   if (audioCapturer.state == audio.AudioState.STATE_RELEASED) {
       console.info('AudioRecLog: Capturer released');
   } else {
       console.info('AudioRecLog: Capturer release failed');
   }
   ```