项目上要求对手机传输出去的音频进行降噪处理,网上查了查资料,发现webrtc里面有关于降噪的模块,开始对webrtc学习,ns模块算是一个开始吧。
首先,需要将webrtc ns模块用android ndk编译为动态库,编译的方法网上很多,不详细说明了。
webrtc ns模块的使用比较简单,分为三个部分:
1.初始化
WebRtcNs_Create(&handle);
//先初始化一个句柄
WebRtcNs_Init(handle, frequency);
//将句柄传入,并且要传入采样频率,这里需要注意,我使用的android上层的audiorecord的采样频率是8000,但是我测试发现,给frequency也传8000,效果很不好,传入 16000,效果很好,不太理解,有时间了再研究看看
WebRtcNs_set_policy(handle, kVeryHigh);
//将句柄传入,第二个参数是去噪效果,可根据自己要求传入
2.对音频数据的处理
int WebRtcNs_Process(NsHandle* NS_inst, short* spframe, short* spframe_H, short* outframe, short* outframe_H)
//第一个参数很简单,传入初始化的句柄,我的安卓的采样频率是8000,所以第三个和第五个参数传入NULL,安卓上层采到的音频传入低二个参数,去噪完成后的音频数据,会 从第四个参数传出。具体如下:
WebRtcNs_Process(handle, buffer_in, NULL, buffer_out, NULL);
需要注意的是:传入的PCM数据肯定为short类型,传出的也是short类型,但是我发现,这个传出的short类型数据如果直接进行g711编码,如果编码为g711a的话,会有杂音,但是编码为g711u的话,没有杂音,所以,如果项目要求输出g711a,那么得先编码为g711u再转换为g711a,如果哪位大神知道更好的解决方案,请指教。
3.free
不需要降噪处理了,就将handle释放即可,WebRtcNs_Free(handle);