网站首页

人工智能P2P分享搜索全网发布信息网站地图标签大全

当前位置:诺佳网 > 电子/半导体 > 嵌入式技术 >

无门槛!巧用合宙Air780E云喇叭,实现多音色『打

时间:2023-01-29 10:33

人气:

作者:admin

标签: 开发板  音频 

导读:和工程师做朋友!合宙的新品活动可谓一波接一波,上周三首发ESP32-S3开发板团购仅需19.9元,2000库存几乎个把小时就被拼手速的工程师一扫而光。今天要跟大家分享的是——合宙Air780...

今天要跟大家分享的是——合宙Air780E开发板Air780E音频扩展板喇叭套装都是首发9.9元包邮抢到的。通过合宙提供的Air780E云端音频配置平台,开发者可以轻松实现趣味TTS+AMR+MP3语音播放功能。

接下来具体分享一下体验云喇叭功能的过程,最终让Air780E开发板+音频扩展板实现视频中多音色打麻将对话功能。在熟练使用云端工具配置的基础上,还可以进一步自己编程来实现更为个性有趣的应用。

一、焊接和连线


先按照下图,在正确的一面,为开发板焊上排针,在扩展板上焊上母座:

44c591e6-96e8-11ed-ad0d-dac502259ad0.jpg

44ddd1a2-96e8-11ed-ad0d-dac502259ad0.jpg

然后插上SIM卡,连接到喇叭,把开发板和扩展板对插起来:

44ef2006-96e8-11ed-ad0d-dac502259ad0.jpg

这里的SIM卡支持,可是全网通的,中国移动、联通、电信通杀,全都支持。

另外一点要表扬合宙的,合宙出的开发板,都贴心的提供了扩展板,可以很方便的进行应用。

二、下载固件


为了使用云喇叭功能,需要刷入专门的固件。官方提供了固件的源码,以及编译好的固件。

方便起见,这里直接使用官方提供的固件。

固件下载地址:

http://tools.openluat.com/tools/yunlaba

4500be2e-96e8-11ed-ad0d-dac502259ad0.png

本文编写时的固件文件为:

45126bce-96e8-11ed-ad0d-dac502259ad0.png


烧录完成后,就可以开始好好玩了。

三、开机启动


Type-C数据线,给开发板供电,板子上的红灯就会亮起来:

45310ae8-96e8-11ed-ad0d-dac502259ad0.jpg

因为插了SIM卡,需要联网才能使用,所以稍微等一会,等它联网成功。

没想到,等了半天,它居然一声不吭,就是红灯亮着,在那里闷头闷脑的发闷气。

是有哪里不对吗?

赶紧看手册,了解到了详情:

4540ee7c-96e8-11ed-ad0d-dac502259ad0.png

按照说明,要按一下板子上的开机键:

458797e6-96e8-11ed-ad0d-dac502259ad0.png

按就按,谁怕谁呀!

按完后,还真害怕了。大半夜的,突然一下响起来,声儿还贼大,差点把已经睡觉的家人给吵醒了。

按完后,板子开始正常启动了,绿灯亮了:

459e745c-96e8-11ed-ad0d-dac502259ad0.jpg

正常情况下,喇叭开始响起来:

播报"欢迎使用合宙云端音频播放设备"

播报"服务器连接成功"

如果联网有问题,或者服务器无法连接,也会播放对应的声音。

现在板子启动起来了,可以开始好好玩了。

四、喇叭云起来


Air780E开发板+音频扩展板,就是想通过云让喇叭响起来,使用云喇叭工具即可。

合宙云喇叭在线工具:
http://tools.openluat.com/tools/yunlaba

直接访问该界面,就能够给开发板发送语音信息,让喇叭响起来。

打开该界面后,按照如下的步骤使用:

45aff484-96e8-11ed-ad0d-dac502259ad0.png

点击发送音频数据到设备后,正常情况下,会提示发送成功:

45bd05ac-96e8-11ed-ad0d-dac502259ad0.png

稍后,音频扩展板的喇叭就会响起来了。

如果要让发送的语音音色音速等更丰富,可以先设置语音参数,再生成发送:

45d1878e-96e8-11ed-ad0d-dac502259ad0.png

可以多多尝试,找到自己喜欢的或者觉得不错的参数搭配。

五、给设备发送数据


接下来可以探究云喇叭工具如何给设备发送数据——既然云喇叭在线工具是通过网页操作的,而且它又没有直接连接到喇叭,那么一定有什么方式让两者互通。

通过浏览器的开发者调试工具,可以查看端倪。

点击发送音频数据到设备,会在调试工具的网络界面中,看到如下的请求:

45de0bd0-96e8-11ed-ad0d-dac502259ad0.png

从上图可以看到,云喇叭在线工具给http://tools.openluat.com/api/site/yunlaba_mqtt 这个地址,POST发送了一些数据。

看名字,应该是发送给MQTT服务了,然后在开发板上,通过MQTT服务,获取网页工具发送的数据,再进行播放。

如果有兴趣,可以查看固件对应的源码,其逻辑正是如此。

进一步的,可以查看实际发送了什么数据:

45edd60a-96e8-11ed-ad0d-dac502259ad0.png

从上图中,可以看到,具体发送的数据如下:

45fbb22a-96e8-11ed-ad0d-dac502259ad0.png

这是个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:文本内容,会根据语音参数生成语音信息。

其中,语音参数配置的序号,是指我根据自己的多次测试尝试,选定了几组语音配置信息:

4607943c-96e8-11ed-ad0d-dac502259ad0.png

你可以自己尝试,选择几组合适的语音配置信息。

而文本内容部分,就是要发送的语音对应的文本了,注意不要包含空格、单双引号等。

将上述脚本保存为send_mqtt.sh,然后执行:

./send_mqtt.sh 8615510********
先赚他个100亿再说

注意将IMEI号替换为自己的开发板的。

发送成功后,喇叭就会根据设置,响起来了。

六、喇叭一响,麻将打起!



在上一步的研究基础上,只要我们可以用不同的语音配置,将不同的语音信息发送给开发板,那么喇叭就能够以不同的声音播放不同的内容了。

虽然,这些语音信息,也可以提前全部录制出来,直接发给开发板播放,但是如果能够进行动态的生成播放,那还是更加吸引人的。

为了更好玩,我从一段打麻将的小视频中,提取了对应的对话信息,并经过一定的处理,最终让Air780E开发板+音频扩展板播放出来。

一共有5个角色,分别标识为:

前男(苦命男):也就是主角男

前女(女王女):也就是主角男的老婆

左女(阴险女):打麻将的女性

后男(腼腆男):主角男对面的腼腆闷骚男

右男(道貌岸然男):另外一位打麻将的男性

将该视频中的对话信息提取到Excel文件中,文末【阅读原文】链接获取源文件:

462e9104-96e8-11ed-ad0d-dac502259ad0.gif

并将最后的输出信息,拷贝到文本文件对话.txt中来:

11哎呀,婆娘,你怎么又来了嘛

21好不容易打回清净麻将啊

30我来看会热闹

44保长才趣哇

54人家皮蛋来耍嘛就让她耍会嘛

63人家也想来看会玩意儿嘛

73等人家皮蛋在这儿

80你看嘛,她们都想我来

91那是嘛,你来我就输了

101肯定想你来啥

……

在上一步的send_mqtt.sh中,设置了5组语音参数配置,刚好就是对应5位角色:

前男(苦命男):1

前女(女王女):0

左女(阴险女):2

后男(腼腆男):3

右男(道貌岸然男):4

因此,在提取信息到Excel中的时候,会设置对应的语音配置编号。

文末【阅读原文】链接获取源文件:

463bd224-96e8-11ed-ad0d-dac502259ad0.png

这个编号,在后面的程序中,也会进行调用,从而使用对应的语音配置输出信息。

最后,再编写对应的脚本:

手机横屏/上下滑动查看完整内容:

#!/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开发板+音频扩展板,那么可以进行更为精细的控制,让一桌麻将打得更为生动;在其他场合应用,也会更为有趣。

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信