一、介绍
以前做过讯飞语音识别,比较简单,识别率很不错,但是它的识别时间是有限制的,最多60秒。可是有的时候我们需要更长的识别时间,例如朗诵古诗等功能。当然讯飞语音也是可以通过曲线救国来实现,就是每达到60秒时识别停止就立即重新开启,每次结束拼接录音。这么做,显然是麻烦的,百度语音解决了这个问题,它最近上线了长语音识别技术,可以不受时间限制,还是非常棒的。这次,我就专门抽成一个工具类使用,包括语音识别,录音拼接,录音播放、进度刷新,具体如何集成SDK看官方文档,我就不废话了,直接介绍如何使用我的这个工具类。
二、依赖
因为语音录制格式是pcm格式的,我使用lame静态库将其转成了mp3格式。
下载路径参考我的博客,有具体的介绍:
三、代码
SJVoiceTransform.h
View Code
SJVoiceTransform.m
View Code
BDHelper.h
View Code
BDHelper.m
View Code
四、注意
百度语音SDK只支持armv6、armv7的真机架构,不支持x86_64模拟器架构。
五、如何在模拟器下开发
办法:
1、首先将涉及到百度语音的代码全部采用宏定义注释掉,如:
#if !TARGET_IPHONE_SIMULATOR// 语音相关调用// self.asrEventManager = [BDSEventManager createEventManagerWithName:BDS_ASR_NAME];// 其他调用#endif
2、(重点要处理的地方)切换到模拟时,将libBaiduSpeechSDK.a静态包从Linked Frameworks and Librarise删掉(切换到真机时,再将libBaiduSpeechSDK.a导入进来就行)