iOS7- AVSpeechSynthesizer(语音合成器)

 语音合成器的技术是iOS7推出的,可以实现无网络语音功能,支持多种语言


参考:http://vit0.com/blog/2014/07/18/ios-7-yu-yin-he-cheng-qi-avspeechsynthesizer/


 1. 定义一个成员变量,记录语音合成器 AVSpeechSynthesizer 

#import <AVFoundation/AVFoundation.h>  

@interfaceViewController ()

{

    // 合成器

    AVSpeechSynthesizer *_synthesizer;

    

    // 实例化说话的语言,说中文、英文

    AVSpeechSynthesisVoice *_voice;

}


 2. 定义语音对象 AVSpeechSynthesisVoice,指定说话的语言

    zh_CN 中文

    en-US 英文

- (void)viewDidLoad
{
    [super viewDidLoad];

    // 实例化说话的语言,说中文
    _voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"en-US"];
    
    // 要朗诵,需要一个语音合成器
    _synthesizer = [[AVSpeechSynthesizer alloc] init];
}


 3. 实例化发声对象 AVSpeechUtterance,指定要朗读的内容

// 朗诵文本框中的内容
// 实例化发声的对象,及朗读的内容
AVSpeechUtterance *utterance = [AVSpeechUtterance speechUtteranceWithString:_textView.text];


 4.指定语音,和朗诵速度           

    中文朗诵速度:0.1还能够接受

    英文朗诵速度:0.3还可以

utterance.voice = _voice;

utterance.rate = 0.3;


 5.启动                

[_synthesizer speakUtterance:utterance];

 

 提示:在制作应用程序时,如果朗诵的内容有限,需要提供专业的配音音频

 如果朗诵的内容无限,使用此方法是最佳选择!

你可能感兴趣的:(iOS7- AVSpeechSynthesizer(语音合成器))