iOS- AVSpeechSynthesizer——iOS7语音合成器

本文介绍了如何使用iOS7引入的AVSpeechSynthesizer进行语音合成,支持离线操作并涵盖多种语言。通过实例化AVSpeechSynthesizer和AVSpeechSynthesisVoice对象,设置语言和发音速度,可以实现文本的中文或英文朗读。在有特定内容需求时,可考虑专业配音,而无限内容则适合采用此语音合成技术。
摘要由CSDN通过智能技术生成

语音合成器的技术是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];

 

 

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

 

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值