从2020年云栖大会HaaS团队第一次发布“HaaS物联网设备云端一体开发框架”至今,HaaS团队共发布了HaaS100/ EDU K1/ 200/ 506/ 610/ 531/ 600等HaaS智能硬件。
图1:HaaS各版本智能硬件的主要区别
那么用户拿到HaaS开发板之后,如何快速的让自己的HaaS硬件快速的上云,并且在云端可视化页面中和HaaS硬件交互呢?传统的做法是,开发者需要经历以下步骤:
大家看到这么长的开发流程是不是有心疼自己脑细胞,想放弃(让开发板吃灰)的念头?
那么能不能做点局部创新,让HaaS用户在收到开发板之后稍作修改就能快速体验到“HaaS云端一体”的解决方案呢?答案是肯定的。
为了让广大开发者用户在拿到HaaS硬件之后不让它吃灰,我们专门打造了“HaaS JS轻应用样板间”,基于此开发者用户们可以在10分钟内快速体验一把“HaaS云端一体”的解决方案。
图3:HaaS JS轻应用样板间快速体验流程(10分钟完成)
针对新手用户,只需要一块HaaS600开发板,一张支持4G Cat.1的sim卡即可快速体验HaaS云端一体案例。
/* HaaS600更新JavaScript轻应用代码方法 */
./amp serialput ../../../agriculture_demo/ /dev/tty.SLAB_USBtoUART
备注:代码路径和串口id以实际为准
备注:HaaS600-EC100Y和HaaS600-EC600S如何下载JS轻应用脚本请分别参考下述文档。
图4: HaaS600 GPS & 温度传感器数据展示
当您已经完成“新手篇”的任务之后,恭喜您已经成为HaaS JS轻应用的老鸟用户了。此时您一定会想HaaS600除了板子上自带的温度传感器和GPS数据,我还可以扩展其他外设传感器吗?这些新的传感器硬件怎么接?数据如何上云?在样板间中又该如何展示和交互呢?
针对老鸟用户,我们为大家搭建了一个智慧农业样板间的案例,该案例中我们新增了对更多传感器外设的支持,包括,
图5: 老鸟用户展示页面示例
3.2.2.1 BMP280温度、气压传感器
// 引入bmp280驱动,并初始化
var bmp280 = require('./bmp280.js');
bmp280.bmp280_init();
// 读取温度值
temperature = bmp280.bmp280TemperatureRead();
// 读取气压
pressure = bmp280.bmp280PressureRead()/100;
// 上报至阿里云平台
device.postProps(JSON.stringify({CurrentTemperature: temperature}));
device.postProps(JSON.stringify({Atmosphere: pressure}));
值得注意的是:BMP280 I2C Slava Address是由SDO pin的电平来决定的,如果SDO = 0, Slava Address为128,如果SDO = 1, 那么Slava Address为129。其中I2C Slava Address在app.json文件中配置。
3.2.2.2 继电器控制电机和风扇
// 引入gpio驱动,并初始化变量和端口
var fanSwitch = 0;
var waterSwitch = 0;
var gpio = require('gpio');
var relay1 = gpio.open({
id: 'D3'
});
var relay2 = gpio.open({
id: 'D2'
});
// 在“设置属性”的回调函数解析云端的property set命令。
device.onProps(function (res) {
var payload = JSON.parse(res.params);
if(payload.Coil !== undefined)
{
// 收到风扇控制的指令,控制风扇,并上报风扇的状态
fanSwitch = parseInt(payload.Coil);
relay2.writeValue(fanSwitch);
device.postProps(JSON.stringify({
Coil: fanSwitch
}));
}
if(payload.WaterOutletSwitch !== undefined)
{
// 收到电机控制的指令,控制电机,并上报电机的状态
waterSwitch = parseInt(payload.WaterOutletSwitch);
relay1.writeValue(waterSwitch);
device.postProps(JSON.stringify({
WaterOutletSwitch: waterSwitch
}));
}
});
3.2.2.3 PIR数据上报
// 引入adc驱动,并初始化变量和端口
var adc = require('adc');
var pir = adc.open({
id: 'ADC0',
success: function() {},
fail: function() {}
});
var pirStatus = 0;
var pirTempStatus = 0;
var pirCount = 0;
// 每隔50ms读取一次ADC信号
setInterval(function(){
var pinStatus = (pir.readValue() > 512) ? 1 : 0;
if(pirTempStatus == pinStatus) {
pirCount++;
// 做防抖处理,连续四次读到同样的信号,才确认
if(pirCount > 4) {
pirCount = 0;
if(pirTempStatus != pirStatus) {
pirStatus = pirTempStatus;
// 如果当前已连上云端,则上报PIR的状态
if(mqtt_connected) {
device.postProps(JSON.stringify({AlarmState: pirStatus}));
}
console.log('Pir status is ' + pirStatus);
}
}
} else {
pirTempStatus = pinStatus;
pirCount = 0;
}
}, 50);
3.2.2.4 GPS定位
// 步骤1:初始化GPS模块和UART,UART用于从GPS模块中读取数据
var GPS = require("./gps.js");
var gps = new GPS();
var uart1 = require('uart');
// gnss uart
var gnss = uart1.open({
id: 'UART1'
});
// 由步骤3中的gps.update()调用,将经纬度数据保存至变量geoLocation_data中
var geoLocation_data = {'lat':0, 'lon':0, 'alt':0}
gps.on("data", function (parsed) {
//console.log(parsed);
geoLocation_data['lat'] = gps.state["lat"];
geoLocation_data['lon'] = gps.state["lon"];
geoLocation_data['alt'] = gps.state["alt"];
console.log("geo data " + JSON.stringify(geoLocation_data, null, 4))
});
function ArrayToString(fileData) {
var dataString = "";
for (var i = 0; i < fileData.length; i++) {
dataString += String.fromCharCode(fileData[i]);
}
return dataString;
}
// 步骤2:UART的接收回调函数,读取GPS模块输出的数据,并存储到变量GGA中
var GGA;
gnss.on('data', function(data) {
var aaa = ArrayToString(data);
var bbb = aaa.split("$");
GGA = "$" + bbb[1];
});
// 步骤3:每隔5s,解析GGA成经纬度(WGS84坐标系)。如果当前已连上云平台,则上报至云平台。
setInterval(function(){
// 如果在室内测试,可以使用以下两行测试代码,代替gps.update(GGA)
//var gga_default = "$GNGGA,033122.000,3111.28510,N,12136.26122,E,1,13,1.0,1.3,M,11.7,M,,*4B"
//gps.update(gga_default);
// 必须在室外测试,GPS数据转成经纬度
gps.update(GGA);
if(mqtt_connected) {
device.postProps(JSON.stringify({
GeoLocation: {
Longitude: geoLocation_data['lon'],
Latitude: geoLocation_data['lat'],
Altitude: geoLocation_data['alt'],
CoordinateSystem: 1
}
}));
}
}, 5000);
网页已通过“逆地理编码”API将经纬度翻译成具体的地理位置。
3.2.2.5 视频直播
开发者如果想要在样板间中直播HaaS设备的实时状态,您可以购买网络摄像头,根据摄像头厂商的指导获取网络直播地址和access token并更新到样板间中,即可预览您设备的现场状态(备注:由于您私有的网络摄像头直播地址和access token仅用户您自己可见,因此未获得相关权限的其他用户是无法查看您私有摄像头的直播数据的。如果有信息泄漏顾虑的用户请放弃使用该功能)。
3.2.2.6 设备上云
var productKey = 'xxx'; /* your productKey */
var deviceName = 'xxx'; /* your deviceName */
var deviceSecret = 'xxx'; /* your deviceSecret */
# 本例使用pyserial-miniterm串口工具
pyserial-miniterm /dev/tty.SLAB_USBtoUART1 115200
(re)connected
至此基于HaaS600的“HaaS JS轻应用样板间”的设备端基础功能都搭建完毕了。后续我们还会基于更多的HaaS开发板和HaaS JavaScript/ Python轻应用打造更多样板间案例,让广大开发者快速体验HaaS云端一体的方案,欢迎大家体验试用,谢谢。