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日志并进行多维度分析。
相关文章
|
2月前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
333 2
|
7天前
|
存储 缓存 JavaScript
如何优化Node.js应用的内存使用以提高性能?
通过以上多种方法的综合运用,可以有效地优化 Node.js 应用的内存使用,提高性能,提升用户体验。同时,不断关注内存管理的最新技术和最佳实践,持续改进应用的性能表现。
|
26天前
|
数据可视化 JavaScript 前端开发
数据可视化进阶:D3.js在复杂数据可视化中的应用
【10月更文挑战第26天】数据可视化是将数据以图形、图表等形式呈现的过程,帮助我们理解数据和揭示趋势。D3.js(Data-Driven Documents)是一个基于JavaScript的库,使用HTML、SVG和CSS创建动态、交互式的数据可视化。它通过数据驱动文档的方式,将数据与DOM元素关联,提供高度的灵活性和定制性,适用于复杂数据的可视化任务。 示例代码展示了如何使用D3.js创建一个简单的柱状图,展示了其基本用法。D3.js的链式调用和回调函数机制使代码简洁易懂,支持复杂的布局和交互逻辑。
67 3
|
2月前
|
JavaScript 前端开发 开发者
探索JavaScript原型链:深入理解与实战应用
【10月更文挑战第21天】探索JavaScript原型链:深入理解与实战应用
31 1
|
24天前
|
前端开发 JavaScript
JavaScript新纪元:ES6+特性深度解析与实战应用
【10月更文挑战第29天】本文深入解析ES6+的核心特性,包括箭头函数、模板字符串、解构赋值、Promise、模块化和类等,结合实战应用,展示如何利用这些新特性编写更加高效和优雅的代码。
41 0
|
2月前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:原理、应用与代码演示
【10月更文挑战第12天】深入理解JavaScript中的闭包:原理、应用与代码演示
|
2月前
|
监控 JavaScript 前端开发
深入了解Vue.js:构建现代前端应用的利器
【10月更文挑战第11天】深入了解Vue.js:构建现代前端应用的利器
16 0
|
5月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
97 2