admin管理员组文章数量:1665616
1 需求背景
在用户交互软件开发过程中,经常遇到语音提示需求。语音提示是比较直接的交互方式,能够有效的提高用户体验。目前比较常见的解决方案有百度语音平台、讯飞语音平台,这些平台一般都是通过API调用在线服务。优点是转化的语音比较准确,真人发音,有多种语音包选择,缺点是依附互联网,断网无法使用,需要收费,有使用数量限制。当然啦,可以选择这些平台的离线sdk开发,不同的平台提供的sdk平台不同,对于嵌入式arm平台目前没看到支持的。当然啦,对于提示语音比较少又比较固定的,那么直接采用先录制好语音,使用的时候直接播发语音文件的方式也是简单快捷的解决方案。
对于嵌入式arm平台,采用linux系统,在无网络语音提示不定的情况下只能采取TTS引擎来解决。多方查找最后发现一款开源的中文TTS软件Ekho(余音)比较合适。
2 Ekho简介
Ekho(余音)是一个免费、开源的中文语音合成软件。它目前支持粤语、普通话(国语)、广东台山话、诏安客语、藏语、雅言(中国古代通用语)和韩语(试验中),英语则通过eSpeak或Festival间接实现。Ekho支持Linux、Windows和Android平台。Ekho下载连接:
3 Ekho安装
3.1 下载Ekho
3.2 安装Ekho
先安装第三方依赖文件,注意,最新版的ekho是依赖espeak-ng库而非espeak,后者已经停止维护。
sudo apt-get install espeak-ng libespeak-ng-dev libsndfile1-dev libpulse-dev libncurses5-dev libestools-dev festival-dev libvorbis-dev libmp3lame-dev libdotconf-dev texinfo pulseaudio libpulse-ocaml-dev
3.3 编译安装
tar xJvf ekho-xxx.tar.xz
cd ekho-xxx
./configure
make -j4
sudo make install
注意:其中xxx请替换为具体的文件路径。
4 测试Ekho效果
直接生成语音播放
ekho "你好呀"
如果能正常不能播放出声音,那么可能系统的声卡设置有问题,请查看。还有一种原因可能是pulseaudio服务没有启动
pulseaudio -start
再次执行ekho “你好呀!”,就能听到一段机械的语音啦。
生成语音文件
ekho "你好。请继续保持努力!" -o holdon.wav
最后设置开机自动启动pulseaudio服务,这一步骤按需设置
pulseaudio --start --log-target=syslog
在/etc/rc.local 文件中加入pulseaudio --start --log-target=syslog,设置每次开机自动启动。
版权声明:本文标题:linux系统实现TTS(文字转语音)功能 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dianzi/1730052036a1220872.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论