iOS开发-语音合成:AVSpeechSynthesizer
2016-10-17 本文已影响1518人
Eiwodetianna
目前比较主流的语音识别和合成的工具“科大讯飞”很强大,使用起来也很简单,当然如果是简单的“文本到语音”的功能,在iOS中已经提供好了相关的API,开发者可以使用AV Foundation中的AVSpeechSynthesizer类来实现这个功能。
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;
// 退出播放状态
- (void)speechSynthesizer:(AVSpeechSynthesizer *)synthesizer didCancelSpeechUtterance:(AVSpeechUtterance *)utterance;
// 播放状态时,当前所播放的字符串范围,及AVSpeechUtterance实例(可通过此方法监听当前播放的字或者词)
- (void)speechSynthesizer:(AVSpeechSynthesizer *)synthesizer willSpeakRangeOfSpeechString:(NSRange)characterRange utterance:(AVSpeechUtterance *)utterance;
AVSpeechSynthesisUtterance
这个类的一个实例可以理解为合成的一段语音所需要的内容和设置,其中包含了文本内容,语速,音调等信息。播放合成一段最简单的“Hello!”语音如下:
// 创建 AVSpeechSynthesizer
AVSpeechSynthesizer *synthesizer = [[AVSpeechSynthesizer alloc] init];
// 创建 AVSpeechUtterance
AVSpeechUtterance *utterance = [[AVSpeechUtterance alloc] initWithString:@"Hello!"];
// 播放合成语音
[synthesizer speakUtterance:utterance];
当然你也可以播放多段语音并且加上一些语音的设置:
// 创建合成语音的语言
AVSpeechSynthesisVoice *voiceLanguage = [AVSpeechSynthesisVoice voiceWithLanguage:@"zh-CN"];
NSArray *speechStrings = @[@"锄禾日当午,汗滴禾下土。", @"谁知盘中餐,粒粒皆辛苦。"];
// 创建 AVSpeechSynthesizer
AVSpeechSynthesizer *synthesizer = [[AVSpeechSynthesizer alloc] init];
NSUInteger stringCount = speechStrings.count;
for (NSUInteger i = 0; i < stringCount; i++) {
AVSpeechUtterance *utterance = [[AVSpeechUtterance alloc] initWithString:_speechStrings[i]];
// 设置合成语音的语言
utterance.voice = voiceLanguage;
// 语速 0.0f~1.0f
utterance.rate = 0.5f;
// 声音的音调 0.5f~2.0f
utterance.pitchMultiplier = 0.8f;
// 使播放下一句的时候有0.1秒的延迟
utterance.postUtteranceDelay = 0.1f;
[_synthesizer speakUtterance:utterance];
}
// 播放合成语音
[synthesizer speakUtterance:utterance];
ps:“zh-CN” 指的是简体中文的语言代码,默认是不支持中文合成的,所以我们需要通过这行代码设置,你可以通过AVSpeechSynesisVoice的类方法获取其支持的各种语言代码:
[AVSpeechSynthesisVoice speechVoices];