AVSpeechSynthesizer 将文本翻译成语音

2019-09-26  本文已影响0人  智狸

AV Foundation中提供了一个AVSpeechSynthesizer类来向app中添加朗诵文本的功能.

这个类用来播放一个或者多个语音内容,每条语音内容都是一个AVSpeechUtterance对象.

(快速记忆:一个语音合成器(SpeechSynthesizer)播放需要一段语音内容(SpeechUtterance))

春天到了,让代码为我们读几句春天的诗句.

定义一个包含诗句的数组,

self.verses = @[

@"最是一年春好处,绝胜烟柳满皇都",

@"陌上花开,可缓缓归矣",

@"沾衣欲湿杏花雨,吹面不寒杨柳风",

@"竹外桃花三两枝,春江水暖鸭先知",

@"几处早莺争暖树,谁家新燕啄春泥",

@"乱花渐欲迷人眼,浅草才能没马蹄"

];

初始化一个AVSpeechSynthesizer对象,

self.synthesizer = [[AVSpeechSynthesizer alloc]init];

给每句诗生成一个对应的AVSpeechUtterance对象,并传递给self.synthesizer进行播放,

for (int i = 0; i < self.verses.count; i++) {     AVSpeechUtterance *utterance = [[AVSpeechUtterance alloc]initWithString:self.verses[i]];  

utterance.voice = [AVSpeechSynthesisVoice voiceWithLanguage:@"zh-CN"];

utterance.rate = 0.4;

utterance.pitchMultiplier = 0.8;

utterance.postUtteranceDelay = 0.1;

[self.synthesizer speakUtterance:utterance];

}

(1) voice属性指定了要朗诵的语言类型,中文or英文or其他,下文会给出一个支持的语言列表,

(2) rate属性指定播放语音时的速率,最小值和最大值分别是AVSpeechUtteranceMinimumSpeechRate和AVSpeechUtteranceMaximumSpeechRate,

(3) pitchMultiplier属性设置声调,属性值介于0.5(低音调)~2.0(高音调)之间,

(4) postUtteranceDelay告诉synthesizer本句朗读结束后要延迟多少秒再接着朗读下一秒,对应的属性还有preUtteranceDelay

此外,AVSpeechSynthesizerDelegate中还提供了一些监听朗读状态的方法.

swift语言的AVSpeechSynthesizer介绍请戳这里: swift版介绍传送门

支持的语言列表:

Arabic (ar-SA)

Chinese (zh-CN, zh-HK, zh-TW)

Czech (cs-CZ)

Danish (da-DK)

Dutch (nl-BE, nl-NL)

English (en-AU, en-GB, en-IE, en-US, en-ZA)

Finnish (fi-FI)

French (fr-CA, fr-FR)

German (de-DE)

Greek (el-GR)

Hebrew (he-IL)

Hindi (hi-IN)

Hungarian (hu-HU)

Indonesian (id-ID)

Italian (it-IT)

Japanese (ja-JP)

Korean (ko-KR)

Norwegian (no-NO)

Polish (pl-PL)

Portuguese (pt-BR, pt-PT)

Romanian (ro-RO)

Russian (ru-RU)

Slovak (sk-SK)

Spanish (es-ES, es-MX)

Swedish (sv-SE)

Thai (th-TH)

Turkish (tr-TR)

上一篇下一篇

猜你喜欢

热点阅读