语音合成器的技术是iOS7推出的,可以实现无网络语音功能,支持多种语言
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.启动
1 [_synthesizer speakUtterance:utterance];