最近有一个需求,就是要加入语音合成,并能够在进入后台或者锁屏之后能够播报,现在最流行的应该就是科大讯飞了,功能强大,用起来简单,但是如果只要简单的TTS功能就没有必要集成其他的SDK了,iOS中提供好的API就可以了。
AVSpeechSynthesizer
这个类可以用来播放一个或者多个语音内容,播放的语音内容都是通过实例化AVSpeechUtterance而得到,对于一个或者多个AVSpeechUtterance实例,AVSpeechSynthesizer对象起到队列的作用,提供了API可以控制和监视正在进行的语音播放,首先引入头文件:
#import <AVFoundation/AVFoundation.h>
创建AVSpeechSynthesizer:
AVSpeechSynthesizer *synthesizer = [[AVSpeechSynthesizer alloc] init];
播放合成语音的相关方法:
- (void)speakUtterance:(AVSpeechUtterance *)utterance;
AVSpeechSynthesizerDelegate协议的监听方法:
@optional
// 播放开始状态
- (void)speechSynthesizer:(AVSpeechSynthesizer *)synthesizer didStartSpeechUtterance:(AVSpeechUtterance *)utterance;
// 播放结束状态
- (void)speechSynthesizer:(AVSpeechSynthesizer *)synthesizer didFinishSpeechUtterance:(AVSpeechUtterance *)utterance;
// 播放暂停状态
- (void)speechSynthesizer:(AVSpeechSynthesizer *)synthesizer didPauseSpeechUtterance:(AVSpeechUtterance *)utterance;
// 跳出播放状态
- (void)speechSynthesizer:(AVSpeechSynthesizer *)synthesizer didContinueSpeechUtterance:(AVSpeechUtterance *)utterance;
// 退出播