iOS- AVSpeechSynthesizer——iOS7语音合成器


语音合成器的技术是iOS7推出的,可以实现无网络语音功能,支持多种语言
 
 1. 定义一个成员变量,记录语音合成器 AVSpeechSynthesizer  
 
#import <AVFoundation/AVFoundation.h> 
 
 1 @interfaceViewController ()
 2 
 3 {
 4 
 5     // 合成器
 6 
 7     AVSpeechSynthesizer *_synthesizer;
 8 
 9     
10 
11     // 实例化说话的语言,说中文、英文
12 
13     AVSpeechSynthesisVoice *_voice;
14 
15 }
 
 2. 定义语音对象 AVSpeechSynthesisVoice,指定说话的语言  
 
    zh_CN 中文
 
    en-US 英文
 
 1 - (void)viewDidLoad
 2 {
 3     [super viewDidLoad];
 4 
 5     // 实例化说话的语言,说中文
 6     _voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"en-US"];
 7     
 8     // 要朗诵,需要一个语音合成器
 9     _synthesizer = [[AVSpeechSynthesizer alloc] init];
10 }
 
 
 3. 实例化发声对象 AVSpeechUtterance,指定要朗读的内容  
 
1      // 朗诵文本框中的内容
2     // 实例化发声的对象,及朗读的内容
3     AVSpeechUtterance *utterance = [AVSpeechUtterance speechUtteranceWithString:_textView.text];
  
 4.指定语音,和朗诵速度                    
 
    中文朗诵速度:0.1还能够接受
 
    英文朗诵速度:0.3还可以
 
1  utterance.voice = _voice;
3   utterance.rate = 0.3;
 
 5.启动                            
 
1    [_synthesizer speakUtterance:utterance];
 
 提示:在制作应用程序时,如果朗诵的内容有限,需要提供专业的配音音频
 
 如果朗诵的内容无限,使用此方法是最佳选择!


你可能感兴趣的:(技术,语言,ios7,语音合成)