全部产品

语音播报音箱

更新时间:2020-11-11 23:04:12

介绍

播报音箱主要功能为语音播报,需要和云端保持连接,接收云端播报消息,设备端按照指定规则进行播报。常见的播报场景有支付到账信息、动态更新的定制化音频内容、用户操作回应和提醒等。播报音箱方案涉及云端、设备端的开发,属于端云一体化解决方案。本文聚焦于设备端,主要讲述基于IoT轻应用和HaaS600硬件平台实现播报音箱方案。

硬件

HaaS600是基于移远EC100Y-CN通信模组的LTE Cat 1开发板,专为M2M 和IoT应用而设计,可应用于共享控制、金融支付、智能语音、泛工业等场景的智能硬件产品开发(详情可参考HaaS600平台介绍

应用场景

捕获555

软件框架

软件框架

应用开发

连接

使用轻应用的IoT API,传入三元组信息,即可快速建立和云端的连接,示例:

var iot = require('iot');
const productkey = '<product-key>';
const devicename = '<device-name>';
const devicesecret = '<device-secret>';
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);
  1. 单个文件的播报,例如广告、TTS合成语音等,可通过audioplayer.play()接口,传入音频文件地址(支持本地文件以及http、https网络音频)

  2. 多个文件拼接组合播报,例如金额的拼接,将需要拼接播放的音频文件存放在数组中,通过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: 编号,用于判断是否是重复推送

本地语料更新(SpeechPost)

{
  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');
        }
      }
    });
  }
}

参考

HaaS轻应用使用文档

HaaS600硬件平台