linux系统实现TTS(文字转语音)功能

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,设置每次开机自动启动。

  • 4
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值