今天要跟大家分享的是——合宙Air780E开发板、Air780E音频扩展板喇叭套装,都是首发9.9元包邮抢到的。通过合宙提供的Air780E云端音频配置平台,开发者可以轻松实现趣味TTS+AMR+MP3语音播放功能。
接下来具体分享一下体验云喇叭功能的过程,最终让Air780E开发板+音频扩展板实现视频中多音色打麻将对话功能。在熟练使用云端工具配置的基础上,还可以进一步自己编程来实现更为个性有趣的应用。
一、焊接和连线
先按照下图,在正确的一面,为开发板焊上排针,在扩展板上焊上母座:
然后插上SIM卡,连接到喇叭,把开发板和扩展板对插起来:
这里的SIM卡支持,可是全网通的,中国移动、联通、电信通杀,全都支持。
另外一点要表扬合宙的,合宙出的开发板,都贴心的提供了扩展板,可以很方便的进行应用。
二、下载固件
为了使用云喇叭功能,需要刷入专门的固件。官方提供了固件的源码,以及编译好的固件。
方便起见,这里直接使用官方提供的固件。
固件下载地址:
http://tools.openluat.com/tools/yunlaba
本文编写时的固件文件为:
烧录完成后,就可以开始好好玩了。
三、开机启动
用Type-C数据线,给开发板供电,板子上的红灯就会亮起来:
因为插了SIM卡,需要联网才能使用,所以稍微等一会,等它联网成功。
没想到,等了半天,它居然一声不吭,就是红灯亮着,在那里闷头闷脑的发闷气。
是有哪里不对吗?
赶紧看手册,了解到了详情:
按照说明,要按一下板子上的开机键:
按就按,谁怕谁呀!
按完后,还真害怕了。大半夜的,突然一下响起来,声儿还贼大,差点把已经睡觉的家人给吵醒了。
按完后,板子开始正常启动了,绿灯亮了:
正常情况下,喇叭开始响起来:
播报"欢迎使用合宙云端音频播放设备"
播报"服务器连接成功"
如果联网有问题,或者服务器无法连接,也会播放对应的声音。
现在板子启动起来了,可以开始好好玩了。
四、喇叭云起来
Air780E开发板+音频扩展板,就是想通过云让喇叭响起来,使用云喇叭工具即可。
合宙云喇叭在线工具:
http://tools.openluat.com/tools/yunlaba
直接访问该界面,就能够给开发板发送语音信息,让喇叭响起来。
打开该界面后,按照如下的步骤使用:
点击发送音频数据到设备后,正常情况下,会提示发送成功:
稍后,音频扩展板的喇叭就会响起来了。
如果要让发送的语音音色音速等更丰富,可以先设置语音参数,再生成发送:
可以多多尝试,找到自己喜欢的或者觉得不错的参数搭配。
五、给设备发送数据
接下来可以探究云喇叭工具如何给设备发送数据——既然云喇叭在线工具是通过网页操作的,而且它又没有直接连接到喇叭,那么一定有什么方式让两者互通。
通过浏览器的开发者调试工具,可以查看端倪。
点击发送音频数据到设备,会在调试工具的网络界面中,看到如下的请求:
从上图可以看到,云喇叭在线工具给http://tools.openluat.com/api/site/yunlaba_mqtt 这个地址,POST发送了一些数据。
看名字,应该是发送给MQTT服务了,然后在开发板上,通过MQTT服务,获取网页工具发送的数据,再进行播放。
如果有兴趣,可以查看固件对应的源码,其逻辑正是如此。
进一步的,可以查看实际发送了什么数据:
从上图中,可以看到,具体发送的数据如下:
这是个JSON格式的数据,格式如下:
tpoic:
表示信息发布的主题,具体为:test20220929/IMEI号,后面的IMEI号,就是开发板上Air780E的IMEI,也就是网页工具上填写的。
text:
表示要发布的语音信息,如果设置了语音参数,就会带有一定的参数标记。
了解到以上信息后,可以基本确定一点——如果我们也能按照要求,给上述地址发送对应的JSON格式的数据,那么也能在程序中,直接使用云喇叭工具提供的后台服务,来控制我们自己的喇叭了。
要发送JSON数据给直接的服务网址,可以用Python、nodejs、PHP、Go、Java等语言编程进行,也可以直接使用命令行的curl命令来发送数据。
下面是一个最简单的发送信息的shell脚本:
该脚本需要在Linux或者macOS环境中运行。如果是在Windows环境,则可以在WSL中运行。
手机横屏/上下滑动查看完整内容:
#!/bin/bash
# Air780E模组的IMEI
imei=$1
# 0-4,自己测试选定的几组语音参数
idx=$2
# 要发送的文本内容,不能包含空格,单双引号
msg=$3
if [[ $idx -eq 0 ]];then
# 女1
class="[m53][n0][s7][t7][v1]"
fi
if [[ $idx -eq 1 ]];then
# 男1
class="[m51][n0][s6][v1]"
fi
if [[ $idx -eq 2 ]];then
# 男2
class="[m52][n0][s5][v1]"
fi
if [[ $idx -eq 3 ]];then
# 女2
class="[m53][n0][s6][t5][v1]"
fi
if [[ $idx -eq 4 ]];then
# 男3
class="[m55][n0][s6][v1]"
fi
curl -v 'http://tools.openluat.com/api/site/yunlaba_mqtt' \
-H 'Accept: application/json, text/plain, */*' \
-H 'Accept-Language: zh,en-US;q=0.9,en;q=0.8,zh-CN;q=0.7,it;q=0.6,ru;q=0.5,zh-TW;q=0.4' \
-H 'Cache-Control: no-cache' \
-H 'Content-Type: application/json' \
-H 'Cookie: _clck=awncqb|1|f7t|0' \
-H 'DNT: 1' \
-H 'Origin: http://tools.openluat.com' \
-H 'Pragma: no-cache' \
-H 'Proxy-Connection: keep-alive' \
-H 'Referer: http://tools.openluat.com/tools/yunlaba' \
-H 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36 Edg/108.0.1462.46' \
--data-raw '{"topic":"test20220929/'$imei'","text":"'{$class}{$msg}'"}' \
--compressed \
--max-time 2 \
--insecure
在上述脚本中,首先接收3个参数:
imei:IMEI号,对应网页中的IMEI号;
idx:语音参数配置的序号;
msg:文本内容,会根据语音参数生成语音信息。
其中,语音参数配置的序号,是指我根据自己的多次测试尝试,选定了几组语音配置信息:
你可以自己尝试,选择几组合适的语音配置信息。
而文本内容部分,就是要发送的语音对应的文本了,注意不要包含空格、单双引号等。
将上述脚本保存为send_mqtt.sh,然后执行:
./send_mqtt.sh 8615510********
先赚他个100亿再说
注意将IMEI号替换为自己的开发板的。
发送成功后,喇叭就会根据设置,响起来了。
六、喇叭一响,麻将打起!
在上一步的研究基础上,只要我们可以用不同的语音配置,将不同的语音信息发送给开发板,那么喇叭就能够以不同的声音播放不同的内容了。
虽然,这些语音信息,也可以提前全部录制出来,直接发给开发板播放,但是如果能够进行动态的生成播放,那还是更加吸引人的。
为了更好玩,我从一段打麻将的小视频中,提取了对应的对话信息,并经过一定的处理,最终让Air780E开发板+音频扩展板播放出来。
一共有5个角色,分别标识为:
前男(苦命男):也就是主角男
前女(女王女):也就是主角男的老婆
左女(阴险女):打麻将的女性
后男(腼腆男):主角男对面的腼腆闷骚男
右男(道貌岸然男):另外一位打麻将的男性
将该视频中的对话信息提取到Excel文件中,文末【阅读原文】链接获取源文件:
并将最后的输出信息,拷贝到文本文件对话.txt中来:
11哎呀,婆娘,你怎么又来了嘛
21好不容易打回清净麻将啊
30我来看会热闹
44保长才趣哇
54人家皮蛋来耍嘛就让她耍会嘛
63人家也想来看会玩意儿嘛
73等人家皮蛋在这儿
80你看嘛,她们都想我来
91那是嘛,你来我就输了
101肯定想你来啥
……
在上一步的send_mqtt.sh中,设置了5组语音参数配置,刚好就是对应5位角色:
前男(苦命男):1
前女(女王女):0
左女(阴险女):2
后男(腼腆男):3
右男(道貌岸然男):4
因此,在提取信息到Excel中的时候,会设置对应的语音配置编号。
文末【阅读原文】链接获取源文件:
这个编号,在后面的程序中,也会进行调用,从而使用对应的语音配置输出信息。
最后,再编写对应的脚本:
手机横屏/上下滑动查看完整内容:
#!/bin/bash
# Air780E开发板方言打麻将
send_cmd(){
curl -v 'http://tools.openluat.com/api/site/yunlaba_mqtt' \
-H 'Accept: application/json, text/plain, */*' \
-H 'Accept-Language: zh,en-US;q=0.9,en;q=0.8,zh-CN;q=0.7,it;q=0.6,ru;q=0.5,zh-TW;q=0.4' \
-H 'Cache-Control: no-cache' \
-H 'Content-Type: application/json' \
-H 'Cookie: _clck=awncqb|1|f7t|0' \
-H 'DNT: 1' \
-H 'Origin: http://tools.openluat.com' \
-H 'Pragma: no-cache' \
-H 'Proxy-Connection: keep-alive' \
-H 'Referer: http://tools.openluat.com/tools/yunlaba' \
-H 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36 Edg/108.0.1462.46' \
--data-raw '{"topic":"test20220929/'$1'","text":"'{$2}'"}' \
--compressed \
--insecure 2>&1 | grep HTTP
echo ""
}
# Air780E模组的IMEI
imei=$1
send_text=""
send_count=0
while read line;
do
send_count=$(echo $line | cut -d " " -f 1)
idx=$(echo $line | cut -d " " -f 2)
msg=$(echo $line | cut -d " " -f 3)
echo i=$send_count idx=$idx msg=$msg
if [[ $idx -eq 0 ]];then
# 女1
class="[m53][n0][s7][t7][v1]"
fi
if [[ $idx -eq 1 ]];then
# 男1
class="[m51][n0][s6][v1]"
fi
if [[ $idx -eq 2 ]];then
# 男2
class="[m52][n0][s5][v1]"
fi
if [[ $idx -eq 3 ]];then
# 女2
class="[m53][n0][s6][t5][v1]"
fi
if [[ $idx -eq 4 ]];then
# 男3
class="[m55][n0][s6][v1]"
fi
send_text="$send_text$class$msg"
if [[ $((send_count%5)) -eq 0 ]];then
echo ""
echo $send_text
send_cmd $imei "$send_text"
send_text=""
sleep 1
fi
done < 对话.txt
if [[ "$send_text" != "" ]];then
echo $send_text
send_cmd $imei "$send_text"
fi
上述脚本的主要逻辑如下:
循环读取 对话.txt 的每一行内容;
根据预先设置好的角色语音配置序号,生成对应的带标记的预发送信息;
累加要发送的信息,每满5条,就调用一次发送接口发送信息。
将脚本保存为duihua_damajiang.sh,然后执行该脚本:
./duihua_damajiang.sh 8615510********
注意将IMEI号替换为自己的开发板的。
运行后,待对话信息发送成功后,喇叭响起来,一圈麻将就打起来了。
七、总结
Air780E开发板+音频扩展板,将云语音应用的门槛大幅降低,可以说无门槛入门了。
在熟练使用云端工具配置的基础上,还可以进一步自己编程来实现更为个性化的功能。
如果你有多套Air780E开发板+音频扩展板,那么可以进行更为精细的控制,让一桌麻将打得更为生动;在其他场合应用,也会更为有趣。
-
音频
+关注
关注
29文章
2831浏览量
81297 -
开发板
+关注
关注
25文章
4921浏览量
97124
发布评论请先 登录
相关推荐
评论