WT588F34B单曲更换语音功能的实现与应用
2022-04-22 19:49:00
WT588F34B是一款内置了32M Flash的大容量语音芯片,可以通过Flash烧写器去更换语音文件,但此时的更换语音只能存在于生产端,那么我们能不能够实现产品在客户端能够更换语音,实现产品的迭代升级。于是在旧WT588F34B的程序上进行一个升级,实现单曲语音的更换。
实现原理:
既然是要能够实现单曲声音的更换,那必然需要规划一个文件系统来去记录声音的信息,既然是要单曲更换,那么在实际的情况中必然存放着不是连续的音频文件,这样我们就需要一个音频信息的存放区域。
在我们芯片Flash的操作中,一个扇区是4K,意味着是我们整个单曲更换的最小单位是4K,但是单客户的音频文件都是很小的时候,远远达不到4K,这样大大浪费了我们Flash的空间,空间利用率大大降低,于是有提出了一个想法,是不是可以划分为两个部分,一个是支持单曲更换的音频区域,一个是不支持单曲更换的音频区域,有客户来选择单曲存放的音频数量,这样也就提升我们的一个空间利用率,可以存放更大、更多的音频文件。为了保障这个扇区的可靠性,我们还增加了一个Word,对这个扇区进行一个校验。
*
那么要怎样去播放这些离散的音频文件呢?
其实做法也很简单,我们创建一个扇区,里面记录的便是每一个扇区时那一个音频文件的数据,在播放时,我们需要去这个扇区中寻找我们想要播放的地址,找到对应地址再进行一个寻址的计算,找到音频存放的扇区,开始进行播放,当这个扇区播放结束时,进行下一个扇区的地址寻找,这样就能够实现离散扇区的连续播放。
当播放的问题解决了之后,就是一个数据的更换了。
在上面提出了播放的原理后,数据更换的方式比较直白,只需要在记录单曲音频的扇区找到想要更换的地址的对应的扇区,对该扇区的擦除和写入,如果现有的音频数据长度超过原来的,那便在记录单曲音频的扇区寻找一个无音频数据的扇区进行写入、不足原来的数据长度则需要对剩下的数据空间清空,这样就是数据更换的原理。
但是在更换的过程中,遇到一个问题,Flash的写入只能有一变为零,这就导致了我们无法随意对记录单曲音频的扇区进行修改,必须先将这个扇区进行一个备份一份,4K的一个数据量,我们也不可能利用芯片的寄存器去存放这些数据,于是有了一个新的想法,在我们FLASH中在创造一个扇区去作为原来数据的一个备份区,在数据更换的时候起到暂存的作用。
那么这个备份区的作用是不是仅仅如此呢?
答案是不止如此的!当我们在数据更换时,如果遇到突发的情况,更换失败了,那样音频数据必然是不完整的,按照原来的播放方式是不能正常播放,于是有了一个大胆的想法,在备份区备份的是不完整的扇区,不对要更换的地址进行保存,然后在更换过程备份区备份好之后,我们对原先扇区进行一个“破坏”,这样存在的数据校验就不能通过,在原先扇区校验通过不了的情况下,启用备份区,进行一个播放,这样便保证了芯片能够正常工作。
当然客户执行更换的操作时,并没有这么麻烦,当然下面会讲到这个。
芯片的功能和特点:
1.16位DSP语音芯片、32Mhz内部振荡;
2.工作电压2.4~3.6V;
3.16bit的PWM/DAC输出、可直接驱动8R 0.5W喇叭;
4.支持6K~32Khz的WAV文件;
5.客户可以通过MCU或配套下载器在线更换芯片内部语音内容;
6.支持模拟SPI通讯;
7.支持最大4通道16K采样率混音;
8.支持最高16通道midi播放(8K采样率);
9.具有硬件SPI接口、UART接口、IIC、内置比较器等接口。可以为客户定制各类功能。
10.芯片主控程序和内置存储数据均可擦除再烧写。
引脚功能图:
*
Pad Name |
Pad No. |
ATTR. |
Description描述 |
VDD-SPI |
1 |
Power |
FLASH 电源脚(2.4V-3.6V) |
PC7 |
2 |
I/O |
接SPI-flash的CLK |
PC6 |
3 |
I/O |
接SPI-flash的DI |
PC2 |
4 |
I/O |
接SPI-flash的CS |
PC1 |
5 |
I/O |
四线SPI的CS |
PB2 |
6 |
I/O |
四线SPI的SO (BUSY语音播放忙信号输出脚) |
PI0 |
7 |
I/O |
四线SPI的SLK |
PI1 |
8 |
I/O |
四线SPI的SI |
GND |
9 |
Power |
地线脚 |
PWMN |
10 |
Out |
PWM 输出脚 |
PWMP |
11 |
Out |
PWM 输出脚 |
VDD |
12 |
Power |
电源正极(2.4V-3.6V) |
SPI-DO |
13 |
I/O |
SPI-flash的D0 |
SPI-CS |
14 |
I/O |
SPI-flash的CS |
SPI-DI |
15 |
I/O |
SPI-flash的DI |
SPI-CLK |
16 |
I/O |
SPI-flash的CLK |
SPI通信协议:
SPI是串行通讯协议,也就是说数据是一位一位的传输的。MISO引脚和MOSI引脚上的数据的MSB位必须与SPSCK的第一个边沿同步,在SPI传输过程中,在同步时钟信号周期开始时(上升沿)数据上线,然后在同步时钟信号的下降沿时,SPI的接收方捕捉位信号,在时钟信号的一个周期结束时(上升沿),下一位数据信号上线,再重复上述过程,先发高位,直到一个字节的8位信号传输结束。由此可以实现控制语音播放、停止、循环等。详细说明可见下面介绍。
*
SPI控制模式由芯片CS、SCK和SI进行控制操作,每发一个字节数据前,CS先拉低4ms至20ms,推荐使用5ms,然后再发送CLK,接收数据高位在先,在时钟的下降接收数据。时钟周期介于160us~2ms之间,推荐周期使用200us。发数据时先发高位,再发低位。数据中的指令根据指令表来发送
1)播放命令码:
指令头 |
参数1 |
参数2 |
功能 |
描述 |
A0 |
Adr-H |
Adr-L |
地址播发 |
指定地址播放,Adr-H高8bit地址,Adr-L低8bit地址 |
AA |
Ab |
\ |
循环播放 |
Ab= 00:取消单曲循环 Ab= 01:单曲循环 Ab= 02:播放两次 Ab= 03:播放三次(以此类推) 可打断AB连码指令; |
AB |
Adr-H |
Adr-L |
连码播放 |
Adr-H,Adr-L高低地址为一组,最多可以同时发20组地址; 可打断AA循环指令; |
AE |
Cd |
\ |
音量调节 |
Cd=00:静音 Cd=01:音量1 Cd=3F:音量63(最大音量); |
AF |
\ |
\ |
停止播放 |
停止播放; |
2)更换指令码
指令头 |
参数1 |
参数2 |
功能 |
描述 |
E0 |
Numb-H |
Numb-L |
单段更换 |
指定语音段更换,Numb-H高8位数据,Numb-L低8位数据; |
EA |
55 |
AA |
全部更换 |
全部更换flash资料 |
EE |
00 |
00 |
查询指令 |
查询主控忙闲状态,在EE后面的2个CLK芯片会回复 回复00或FF:忙 回复01:闲 回复02:空间已满 |
DF |
\ |
\ |
更换中每一个包的起始命令 |
查询主控忙闲状态,在DF后面的2个CLK进行回复上一个包的校验数据(一个包256byte,一定要发送完256byte) |
EF |
00 |
00 |
更换结束命令 |
查询主控忙闲状态,在DF后面的2个CLK进行回复上一个包的校验数据
|
3)Flash控制码
指令头 |
参数1 |
参数2 |
功能 |
描述 |
FD |
\ |
\ |
释放Flash |
释放Flash |
FC |
\ |
\ |
配置Flash |
配置Flash |
应用电路:
*
更换协议说明:
*
bin文件制作或T3Z文件制作
制作bin文件:登陆网页上位机网址后,加载要播放的语音文件或使用文字转换音频功能加载语音后制作bin文件。WT588网页制作客户登录网址:http://WT588f.waytronic.com:8083/user/register。bin文件制作步骤可参考《WT588F网页上位机操作说明2020-8-31》或视频解说,可联系业务员提供。
访问API接口,可加载本地语音或采用文字转语音功能生成语音文件,将语音文件转换为bin文件或T3Z文件(可用于单段语音修改),可用于单段语音或全部语音的远程更换。
应用场景
我们的WT588F34B,能够支持大容量的语音存放,并且能过更换语音,适用于需要频繁更改语音播报的产品,能够实现在线更新语音包,增加产品活力。
1、公交车到站提醒系统
使用WT588F34芯片去进行到站语音的播报,不仅可以存放更多的一个公交站地点语音,而且在不同的场景下,比如节日祝福、防疫宣传等等,可以通过MCU去进行语音更换,进行一个适应的语音播报。不需要繁琐的将整个设备拆除更新语音。
2、打卡设备
现在市面上存在的高端打卡设备往往具有播报打卡人的名字,而中低端设备更多的是使用文字显示,而我们的WT588F34B正好可以在中低端设备上增加语音播报,增加产品亮点,竞争力。录入、修改打卡人,MCU同步对我们WT588F34B芯片的语音更换,达到正常的打卡人播放。