iOS开发-语音合成:AVSpeechSynthesizer

目前比较主流的语音识别和合成的工具“科大讯飞”很强大,使用起来也很简单,当然如果是简单的“文本到语音”的功能,在iOS中已经提供好了相关的API,开发者可以使用AV Foundation中的AVSpeechSynthesizer类来实现这个功能。

AVSpeechSynthesizer

这个类可以用来播放一个或者多个语音内容,播放的语音内容都是通过实例化AVSpeechUtterance而得到,对于一个或者多个AVSpeechUtterance实例,AVSpeechSynthesizer对象起到队列的作用,提供了API可以控制和监视正在进行的语音播放,首先引入头文件:

#import 

创建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];

你可能感兴趣的:(iOS开发-语音合成:AVSpeechSynthesizer)