播报音箱主要功能为语音播报,需要和云端保持连接,接收云端播报消息,设备端按照指定规则进行播报。常见的播报场景有支付到账信息、动态更新的定制化音频内容、用户操作回应和提醒等。播报音箱方案涉及云端、设备端的开发,属于端云一体化解决方案。本文聚焦于设备端,主要讲述基于IoT JS轻应用和HaaS600硬件平台实现播报音箱方案。
HaaS600是基于移远EC100Y-CN通信模组的LTE Cat 1开发板,专为M2M 和IoT应用而设计,可应用于共享控制、金融支付、智能语音、泛工业等场景的智能硬件产品开发(详情可参考HaaS600平台介绍)
使用JS轻应用的IoT API,传入三元组信息,即可快速建立和云端的连接,示例:
var iot = require('iot');
const productkey = '';
const devicename = '';
const devicesecret = '';
var iotdev = iot.device({
productKey: productkey,
deviceName: devicename,
deviceSecret: devicesecret,
success: function() {
console.log('success connect to aliyun iot server');
},
fail: function() {
console.log('fail to connect to aliyun iot server');
}
});
接收云端播报消息(类型为service),示例:
iotdev.on('service', function(serviceid, request) {
console.log('received cloud serviceid is ' + serviceid + '\r\n');
console.log('received cloud request is ' + request + '\r\n');
});
IoT轻应用提供音频播放组件audioplayer,使用相关API可实现本地和在线音频文件的播放及控制。示例:
var audioplayer = require('audioplayer');
var source = "/test.mp3"
audioplayer.play(source);
var sourceList = ["/test1.mp3", "/test2.mp3", "/test3.mp3"];
audioplayer.listPlay(sourceList);
单个文件的播报,例如广告、TTS合成语音等,可通过audioplayer.play()接口,传入音频文件地址(支持本地文件以及http、https网络音频)
多个文件拼接组合播报,例如金额的拼接,将需要拼接播放的音频文件存放在数组中,通过audioplayer.listPlay()接口,将音频文件进行拼接和播放。
var gpio = require('gpio');
var led_network = gpio.open({
id: 'led_network'
});
var key_function = gpio.open({
id: 'key_function'
});
var key_volumeup = gpio.open({
id: 'key_volumeup'
});
var key_volumedown = gpio.open({
id: 'key_volumedown'
});
key_function.onIRQ({
trigger: 'rising',
cb: function() {
console.log('key function pressed');
}
});
key_volumeup.onIRQ({
trigger: 'rising',
cb: function() {
console.log('key volumeup pressed');
}
});
key_volumedown.onIRQ({
trigger: 'rising',
cb: function() {
console.log('key volumedown pressed');
}
});
当系统空闲时自动进入低功耗状态。
var pm = require('pm');
pm.setAutosleepMode(1)
物模型:
{
speechs:["alipay","{$100}","yuan"],
id:"123",
timestamp:"1595765968612"
}
定义:
id: 消息id,用于判断是否是重复推送
timestamp:交易时间
speechs:表示需要拼接的内容,有3类
1. {$+数字}:表示按照金额进行播放
2. {N+数字}或{n+数字}:表示按照数字进行播放
3. 其它:表示需要播放的语料的标识 播放
物模型:
{
url:"http://*********",
id:"123",
}
定义:
url:音频内容url,设备端收到后通过该url下载并播放
id: 编号,用于判断是否是重复推送
{
speechs:[{"id":"test","url":"http://********"}],
jobcode:"123"
}
字段:
speechs:需要更新的语料列表,每个元素包括id和url,其中id表示语料标识、url是语料下载地址
jobcode:表示语料更新任务id,用于云端和设备同步语料更新任务执行状态
var iot = require('iot');
var iotdev = iot.device({
productKey: productkey,
deviceName: devicename,
deviceSecret: devicesecret,
success: function() {
console.log('success connect to aliyun iot server');
},
fail: function() {
console.log('fail to connect to aliyun iot server');
}
});
执行完成后,和云端的连接通道建立。
iotdev.on('service', function(serviceid, request) {
console.log('received cloud serviceid is ' + serviceid + '\r\n');
console.log('received cloud request is ' + request + '\r\n');
if (serviceid.indexOf("AudioPlayback") != -1) {
voiceboxPlayContent(request);
} else if (serviceid.indexOf("SpeechBroadcast") != -1) {
voiceboxPlayReceipt(request);
} else if (serviceid.indexOf("SpeechPost") != -1) {
voiceboxResUpdate(request);
}
});
数字拼接
按照普通数字发音规则进行拼接,例如手机号。
按照金额类数字发音规则进行拼接,例如收款金额。
本地语音拼接
通过音频标识查找本地文件。
拼接结果:
例如,
{
speechs:["alipay","{$100}","yuan"],
id:123,
timestamp:"1595765968612"
}
拼接后:
下载并更新本地语料文件
function voiceboxResUpdate(resource)
{
var resource = eval('(' + resource + ')');
var speechArray = resource.speechs;
for (var speechIndex = 0; speechIndex < speechArray.length; speechIndex++) {
var speech = speechArray[speechIndex];
console.log('update local speech id: ' + speech.id + ', url: ' + speech.url);
var resourcePath = toneDir + speech.id + tonenameSuffix;
http.download({
url: speech.url,
filepath: resourcePath,
method: 'GET',
headers: {
'Accept':'*/*'
},
success: function (data) {
if(data === defaultMessage) {
console.log('http: [success] http.download');
}
}
});
}
}
如需更多技术支持,可加入钉钉开发者群
更多轻应用的详细使用文档请参考:https://help.aliyun.com/document_detail/174810.html
更多技术与解决方案介绍,请访问阿里云AIoT首页https://iot.aliyun.com/