HaaS轻应用(JavaScript)快速开始 @ HaaS610

简介: HaaS610 开发板是由阿里云、广和通、旗点科技联合推出的一款基于 fibocom 4G Cat.1 产品 L610 openCPU 模组物联网开发板。具备 Arduino 接口, 可以支配 Arduino 接口配件板,搭配 GPS 定位、WiFi、六轴定位传感器、温度传感器、8MB Flash、麦克 风、喇叭、LCD 显示屏、摄像头、2Kb EEPROM、4*4 矩阵按键组使用。
来源 | HaaS技术社区

1、开发板简介

image.png

HaaS610 开发板是由阿里云、广和通、旗点科技联合推出的一款基于 fibocom 4G Cat.1 产品 L610 openCPU 模组物联网开发板。具备 Arduino 接口, 可以支配 Arduino 接口配件板,搭配 GPS 定位、WiFi、六轴定位传感器、温度传感器、8MB Flash、麦克 风、喇叭、LCD 显示屏、摄像头、2Kb EEPROM、4*4 矩阵按键组使用。

HaaS610 开发板具有以下特点:

  • 基于fibocom 4G Cat1 产品 L610 openCPU 模组,无需MCU,减少硬件成本。
  • 内置RTOS,提供操作系统能力。
  • 内置MQTT、HTTP、mbedtls 等开源库,方便应用开发。
  • 丰富的io资源、支持LCD屏幕、摄像头等。
  • 集成阿里云轻应用框架,可运行在轻量级嵌入式设备上的JavaScript应用。
  • 集成阿里云iot sdk包,可轻松接入阿里云物联网平台。

2、硬件资源介绍

image.png
image.png
image.png

3、开发环境搭建

L610仅支持在windows环境下进行开发。

3.1、连接设备

image.png

通过 MicroUSB 线连接 PC 和模组的USB下载口,将拨动开关拨到 V50_USB 丝印侧,通过USB为开发板供电。

3.2、驱动安装

L610模组 USB 驱动

📎FIBOCOM L610 USB Driver_Windows.zip

L610模组正常上电开机 USB 口会虚拟出7个串口

image.png

  • Port0 口: 发 AT 命令及外置 PPP 拨号;Port1 口: Diag 口,主要用于 NvEditor 以及发 DIAG 指令用;
  • Port2 口: MOS 数据输出,用于场测协议栈数据输出;
  • Port3 口: 抓 ARMTRACER log,通过 AT^TRACECTRL=0,1,2 设置
  • Port4 口:当 debug 跳线调的不支持 debug 口时, 则需要用此 USB 口抓 AP log, 该口无法抓 dump log。
  • Port5 口:可用于发 AT 命令;
  • Port6 口:可用于客户输出自定义 log;

3.3、日志抓取

HaaS610 usb转串口驱动

image.png

连接HaaS610Kit 的 USB2 ,注意不是USB下载口,打开我的电脑——管理——设备管理器,应该两个串口,分别是用于开发板调试的 Debug 串口和 UART1用户串口。一般情况下 Enhanced接口是 Debug 串口,Standard接口为 UART1 用户串口。

image.png

日志接收工具

📎cooltools-win32_custom_P3.R2.0.0005.7z

下载软件并解压,双击 coolwatcher_debughost.exe 打开日志工具 CoolWatcher。

lastcomport 填入我们刚才查看的设备管理器中 Enhanced COM 对应的COM号,例如我的电脑是 52,单击OK。

image.png

顺利的话应该可以看到左下角有 COM OPEN OK的提示。

image.png

选择Activate Tracer

image.png

日志抓取的开始、暂停、清除按键

image.png

填写要过滤的关键字,HaaS610Kit 的关键字是 AOS,然后按下回车键即可看到我们 AOS 相关的日志。

image.png

3.4、热更新

📎amp-clitool.zip

下载解压 amp-clitool 工具,将JS应用代码拷贝到 amp-clitool 工具的目录下,然后用户可以选择任意一种热更新方式(本地或在线)下载应用代码到开发板。

本地更新

运行命令行工具

windows系统 进入 amp-clitool 工具下的 amp-clitool\dist\amp-win 目录,右键选择 powershell

image.png

推送脚本到设备

image.png

  1. . /amp.exe serialput ./app COMXX -m duktape -b 115200
  2. /* serialput 是选择本地热更新 */
  3. /* app 是 JavaScript应用脚本目录 */
  4. /* COMXX 是日志串口号,此处填写自己的串口号 */
  5. /* -m duktape HaaS610 选择JS Engine 为 duktape */
  6. /* -b 115200 HaaS610 串口波特率为 115200 */

执行推送命令的时候需要关闭日志串口

  • 复位开发板
  • 等待脚本传输完成,打开日志串口观察脚本运行情况

image.png

4、示例代码

app.js中的用例逻辑如下:

首先根据uart3的配置创建对应的uart实例,然后启动定时器,周期性的通过uart3 发送字符串。 同时 uart3 把接收到数据通过日志打印,再发送出来,如果收到 'exit' 字符退出本次uart收发测试。

  1. var uart = require( 'uart');
  2. var msgbuf2 = [ 0x41, 0x42, 0x43, 0x44, 0x61, 0x62, 0x63, 0x64, 0x2B, 0X2B];
  3. function ArrayToString(fileData){
  4. var dataString = "";
  5. for ( var i = 0; i < fileData.length; i++) {
  6. dataString += String.fromCharCode(fileData[i]);
  7. }
  8. return dataString;
  9. }
  10. var serial3 = uart.open({
  11. id: 'serial3'
  12. });
  13. var cnt = 100;
  14. var intervalHandled = setInterval( function(){
  15. cnt--;
  16. if(cnt <= 0){
  17. clearInterval(intervalHandled);
  18. }
  19. serial3.write(msgbuf2);
  20. }, 2000);
  21. serial3.on( 'data', function(data) {
  22. console.log(data);
  23. console.log(ArrayToString(data));
  24. serial3.write(data);
  25. if (ArrayToString(data) === "exit") {
  26. console.log( 'uart: test finish')
  27. serial3.close();
  28. }
  29. });
  30. console.log( 'uart: test start')

uart 对应的 port口在 app.json 如下。

  1. {
  2. "version": "1.0.0",
  3. "io": {
  4. "serial1":{
  5. "type": "UART",
  6. "port": 0,
  7. "dataWidth": 8,
  8. "baudRate": 115200,
  9. "stopBits": 1,
  10. "flowControl": "disable",
  11. "parity": "none"
  12. },
  13. "serial2":{
  14. "type": "UART",
  15. "port": 1,
  16. "dataWidth": 8,
  17. "baudRate": 115200,
  18. "stopBits": 1,
  19. "flowControl": "disable",
  20. "parity": "none"
  21. },
  22. "serial3":{
  23. "type": "UART",
  24. "port": 2,
  25. "dataWidth": 8,
  26. "baudRate": 9600,
  27. "stopBits": 1,
  28. "flowControl": "disable",
  29. "parity": "none"
  30. }
  31. },
  32. "debugLevel": "DEBUG",
  33. "repl": "enable"
  34. }

开发者支持

如需更多技术支持,可加入钉钉开发者群,或者关注微信公众号。

image.png

更多技术与解决方案介绍,请访问HaaS官方网站https://haas.iot.aliyun.com

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
1月前
|
开发框架 前端开发 JavaScript
使用JavaScript、jQuery和Bootstrap构建待办事项应用
使用JavaScript、jQuery和Bootstrap构建待办事项应用
13 0
|
1月前
|
自然语言处理 JavaScript 前端开发
探索JavaScript中的闭包:理解其原理与实际应用
探索JavaScript中的闭包:理解其原理与实际应用
19 0
|
1月前
|
JavaScript 前端开发 算法
js开发:请解释什么是虚拟DOM(virtual DOM),以及它在React中的应用。
虚拟DOM是React等前端框架的关键技术,它以轻量级JavaScript对象树形式抽象表示实际DOM。当状态改变,React不直接操作DOM,而是先构建新虚拟DOM树。通过高效diff算法比较新旧树,找到最小变更集,仅更新必要部分,提高DOM操作效率,降低性能损耗。虚拟DOM的抽象特性还支持跨平台应用,如React Native。总之,虚拟DOM优化了状态变化时的DOM更新,提升性能和用户体验。
23 0
|
9天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
28天前
|
开发框架 JavaScript 前端开发
描述JavaScript事件循环机制,并举例说明在游戏循环更新中的应用。
JavaScript的事件循环机制是单线程处理异步操作的关键,由调用栈、事件队列和Web APIs构成。调用栈执行函数,遇到异步操作时交给Web APIs,完成后回调函数进入事件队列。当调用栈空时,事件循环取队列中的任务执行。在游戏开发中,事件循环驱动游戏循环更新,包括输入处理、逻辑更新和渲染。示例代码展示了如何模拟游戏循环,实际开发中常用框架提供更高级别的抽象。
12 1
|
1月前
|
JavaScript 前端开发
HTML JS 应用
HTML JS 应用
19 3
|
1月前
|
JavaScript 前端开发 算法
Vue.js的单向数据流:让你的应用更清晰、更可控
Vue.js的单向数据流:让你的应用更清晰、更可控
|
Web App开发 前端开发 JavaScript
如何用JavaScript判断前端应用运行环境(移动平台还是桌面环境)
如何用JavaScript判断前端应用运行环境(移动平台还是桌面环境)
351 0
如何用JavaScript判断前端应用运行环境(移动平台还是桌面环境)
|
2月前
|
JavaScript
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
27 0