iOS开发-AVFAudio之AVSpeechSynthesizer语音合成(文本转语音)功能

iOS开发-AVFAudio之AVSpeechSynthesizer语音合成(文本转语音)功能

之前开发中遇到需要文本转语音。好在系统提供了实现该功能的API,即AVFAudio中的AVSpeechSynthesizer。
可以使用AVFAudio提供的 AVSpeechSynthesizer 实现文本转语音(语音合成)功能,这个类用来播放一个或多个语言内容,这些语音内容都是 AVSpeechUtterance 的类的实例。

一、AVSpeechSynthesizer

AVSpeechSynthesizer是从文本话语中生成合成语音并能够监视或控制正在进行的语音的对象。

通过播放出一些文本,可以创建一个包含文本的 AVSpeechUtterance 实例并将其传递给 AVSpeechSynthesizer实例,通过 speakUtterance: 进行播放。

AVSpeechSynthesizer会维护一个队列,如果当前没有任务执行就会立刻开始合成,如果当前正在执行合成任务,则会将其添加到队列中,并按照接收到的顺序合成它们。

可以AVSpeechSynthesizerDelegate的方法判断是否播放,是否播放完成。

二、AVSpeechSynthesizer语音合成代码

代码如下

#import "INAVSpeechPresenter.h"
#import <AVFAudio/AVSpeechSynthesis.h>

@implementation INAVSpeechPresenter

- (void)didStart:(UIButton *)sender {
    
    
    if(sender.selected == NO) {
    
    
        if([self.avSpeech isPaused]) {
    
    
            //如果暂停则恢复,会从暂停的地方继续
            [self.avSpeech continueSpeaking];
            sender.selected = !sender.selected;
        }else{
    
    
            // 初始化对象
            AVSpeechUtterance *utterance = [[AVSpeechUtterance alloc]initWithString:@"收款9865.05元"];//需要转换的文字
            utterance.rate = 0.2;// 设置语速,范围0-1,注意0最慢,1最快;AVSpeechUtteranceMinimumSpeechRate最慢,AVSpeechUtteranceMaximumSpeechRate最快
            AVSpeechSynthesisVoice*voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"zh-CN"];//设置发音,这是中文普通话
            utterance.voice = voice;
            [self.avSpeech speakUtterance:utterance];//开始
            sender.selected = !sender.selected;
        }
    } else {
    
    
        //[av stopSpeakingAtBoundary:AVSpeechBoundaryWord];//感觉效果一样,对应代理>>>取消
        [self.avSpeech pauseSpeakingAtBoundary:AVSpeechBoundaryWord];//暂停
        sender.selected = !sender.selected;
    }
}

#pragma mark - AVSpeechSynthesizerDelegate
- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didStartSpeechUtterance:(AVSpeechUtterance*)utterance{
    
    
    NSLog(@"---开始播放");
}

- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didFinishSpeechUtterance:(AVSpeechUtterance*)utterance{
    
    
    NSLog(@"---完成播放");
}

- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didPauseSpeechUtterance:(AVSpeechUtterance*)utterance{
    
    
    NSLog(@"---播放中止");
}

- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didContinueSpeechUtterance:(AVSpeechUtterance*)utterance{
    
    
    NSLog(@"---恢复播放");
}

- (void)speechSynthesizer:(AVSpeechSynthesizer*)synthesizer didCancelSpeechUtterance:(AVSpeechUtterance*)utterance{
    
    
    NSLog(@"---播放取消");
}

#pragma mark - SETTER/GETTER
- (AVSpeechSynthesizer *)avSpeech {
    
    
    if (!_avSpeech) {
    
    
        _avSpeech = [[AVSpeechSynthesizer alloc] init];
        _avSpeech.delegate = self;
    }
    return _avSpeech;
}

@end

三、小结

iOS开发-AVFAudio之AVSpeechSynthesizer语音合成(文本转语音)功能。AVSpeechSynthesizer 实现文本转语音(语音合成)功能,这个类用来播放一个或多个语言内容,这些语音内容都是 AVSpeechUtterance 的类的实例。

学习记录,每天不停进步。

猜你喜欢

转载自blog.csdn.net/gloryFlow/article/details/131991707