SwiftUI——系统自带的文本转语音功能(TTS)

作为独立开发者,有些时候需要大量读音的时候,就可以使用一些语音合成技术,虽然讯飞、谷歌的语音合成技术似乎更好一点,但是需要联网从云端获取,这有时候会影响软件的效率和成本。好在iOS自带语音合成技术,支持的语言包括各个地区口音的英语、中文(普通话)、日语、法语等。

在SwiftUI中使用非常滴方便,如下(我这是为了演示,用的时候可以写一个函数,别像我这么写):

import SwiftUI
import AVFoundation

struct ContentView: View {
    var body: some View {
        Button("Play Voice", action: {
			//需要阅读的文本
            let utterance = AVSpeechUtterance(string: "你好")
            //指定发音
            utterance.voice = AVSpeechSynthesisVoice(language: "zh-CN")
            //控制速度
            utterance.rate = 0.4

            let synthesizer = AVSpeechSynthesizer()
            synthesizer.speak(utterance)
        })
    }
}

指定发音部分的语言代码可以查阅这个网址:http://www.lingoes.cn/zh/translator/langcode.htm

需要注意的是,控制速率的部分可能会修改了代码没有变化,有时候关闭Xcode重开还是一样,但是久一点就又好了。。。

上一篇:Knative Serverless 之道:如何 0 运维、低成本实现应用托管?


下一篇:app测试常问面试题