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

简介: HaaS100开发板阿里云IoT团队推出的物联网通用性云端一体开发板,不但硬件资源丰富,而且还支持HaaS轻应用开发,可以方便的使用JavaScript或Python进行物联网应用开发。
来源 | HaaS技术社区

1、HaaS100介绍

HaaS100开发板阿里云IoT团队推出的物联网通用性云端一体开发板,不但硬件资源丰富,而且还支持HaaS轻应用开发,可以方便的使用JavaScript或Python进行物联网应用开发。

image.png

HaaS100简介

HaaS100硬件规格

2、硬件与系统环境

2.1、硬件连接与启动

  • 电源适配器供电

  • 使用MicroUSB数据线连接开发板与PC

2.2、系统环境

Windows

安装USB转串口驱动,在设备管理器中可以看到以下串口:

不同PC的串口号不一致

image.png

macOS

安装USB转串口驱动,在dev目录下可以看到以下串口:

javascript

Editor

crw-rw-rw- 1 root wheel 18, 4 9 21 16: 23 /dev/tty.SLAB_USBtoUART

2.3、获取轻应用固件

  • 使用官方标准固件

haas100固件

烧录说明:将固件包解压,进入aos_burn_tool目录,打开cmd或者powershell终端,执行以下命令

python flash_program.py --bin=ota_rtos.bin
  • 自己编译固件

  1. git clone https: //github.com/alibaba/AliOS-Things
  2. cd solutions /amp_demo/
  3. aos make -b haas100

2.5、开发工具

参见 Visual Studio Code (AliOS Studio) 或者 命令行工具 章节

3、打开示例应用

下载示例应用代码包

这里通过一个简单的LED闪灯的用例来介绍。

下载应用代码包,LED闪灯用例的代码目录如下所示:

  1. app
  2. ├── app.json # 应用与板级配置
  3. └── app.js # 用户代码

参考硬件资源介绍,已经在app.json中配置好LED3对应的port口为36。

  1. {
  2. "version": "1.0.0",
  3. "io": {
  4. "led": {
  5. "type": "GPIO",
  6. "port": 36,
  7. "dir": "output",
  8. "pull": "pulldown"
  9. }
  10. },
  11. "debugLevel": "DEBUG"
  12. }

在app.js中的用例逻辑如下:首先根据LED灯的配置创建一个GPIO实例,然后启动定时器,周期性的通过GPIO读写接口开关LED灯。

  1. import * as gpio from 'gpio'
  2. var led = gpio.open({
  3. id: 'led',
  4. success: function () {
  5. console.log( 'gpio: open led success')
  6. },
  7. fail: function () {
  8. console.log( 'gpio: open led failed')
  9. }
  10. });
  11. var vol = 0;
  12. setInterval( function() {
  13. vol = 1 - vol;
  14. led.writeValue(vol);
  15. console.log( 'gpio: led set value ' + vol);
  16. }, 1000);

4、应用代码更新到目标硬件

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

本地更新

  • 打开命令行工具

  • 推送脚本到设备

  • 执行推送命令

  1. /* app是JavaScript应用脚本目录 */
  2. /* COMXX是日志串口号,此处填写自己的串口号 */
  3. /* -b 1500000 HaaS100串口波特率为1.5M */
  4. . /amp.exe serialput ./app COMXX -m quickjs -b 1500000

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

  • 复位开发板

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

ae7600895812f82858df798046e55b45.gif

附录

排针接口

image.png

板载LED灯序号示意图

image.png

硬件资源映射表

功能/接口

PIN/IO/资源映射

轻应用 Port 配置

I2C1

SDA2 SCL2

port=0

I2C2

SDA3 SCL3

port=1

ADC0

ADC0

port=0

ADC1

ADC1

port=1

ADC2

ADC2

port=2

PWM0

PWM0

port=0

PWM1

PWM1

port=1

PWM2

PWM2

port=2

PWM3

PWM3

port=3

UART0

默认板级log打印

port=0

UART2

UART2_TXD

UART2_RXD

port=2

GPIO

GPIO41

GPIO40

GPIO47

GPIO46

port=33

port=32

port=39

port=38

SPI

SPI0_MISO

SPI0_MOSI

SPI0_CLK

SPI0_CS0

port=0

功能列表(部分)

  1. 文件系统 FS

  2. 系统信息 SYSTEM

  • 键值对存储 KV

  • 硬件I/O

  • UART

  • GPIO

  • I2C

  • SPI

  • ADC

  • PWM

  • 网络协议

  • UDP

  • TCP

  • MQTT

  • HTTP

  • 高阶功能

  • IoT 阿里云IoT平台连接组件

app.json 参考示例

  1. {
  2. "io":{
  3. "D1":{
  4. "type": "GPIO",
  5. "port": 32,
  6. "dir": "output",
  7. "pull": "pulldown"
  8. },
  9. "D2":{
  10. "type": "GPIO",
  11. "port": 33,
  12. "dir": "output",
  13. "pull": "pulldown"
  14. },
  15. "D3":{
  16. "type": "GPIO",
  17. "port": 38,
  18. "dir": "output",
  19. "pull": "pulldown"
  20. },
  21. "D4":{
  22. "type": "GPIO",
  23. "port": 39,
  24. "dir": "output",
  25. "pull": "pulldown"
  26. },
  27. "I2C1":{
  28. "type": "I2C",
  29. "port": 0,
  30. "addrWidth": 7,
  31. "freq": 100000,
  32. "mode": "master",
  33. "devAddr": 118
  34. },
  35. "I2C2":{
  36. "type": "I2C",
  37. "port": 0,
  38. "addrWidth": 7,
  39. "freq": 100000,
  40. "mode": "master",
  41. "devAddr": 118
  42. },
  43. "ADC0":{
  44. "type": "ADC",
  45. "port": 0,
  46. "sampling": 12000000
  47. },
  48. "ADC1":{
  49. "type": "ADC",
  50. "port": 1,
  51. "sampling": 12000000
  52. },
  53. "ADC2":{
  54. "type": "ADC",
  55. "port": 2,
  56. "sampling": 12000000
  57. },
  58. "PWM0":{
  59. "type": "PWM",
  60. "port": 0
  61. },
  62. "PWM1":{
  63. "type": "PWM",
  64. "port": 1
  65. },
  66. "PWM2":{
  67. "type": "PWM",
  68. "port": 2
  69. },
  70. "PWM3":{
  71. "type": "PWM",
  72. "port": 3
  73. },
  74. "UART2":{
  75. "type": "UART",
  76. "port": 2,
  77. "dataWidth": 8,
  78. "baudRate": 115200,
  79. "stopBits": 1,
  80. "flowControl": "disable",
  81. "parity": "none"
  82. },
  83. "SPI0":{
  84. "type": "SPI",
  85. "port": 0,
  86. "mode": "master",
  87. "freq": 3250000
  88. }
  89. },
  90. "debugLevel": "DEBUG"
  91. }

开发者支持

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

image.png

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

相关文章
|
2月前
|
监控 JavaScript 算法
如何使用内存监控工具来定位和解决Node.js应用中的性能问题?
总之,利用内存监控工具结合代码分析和业务理解,能够逐步定位和解决 Node.js 应用中的性能问题,提高应用的运行效率和稳定性。需要耐心和细致地进行排查和优化,不断提升应用的性能表现。
191 77
|
1天前
|
敏捷开发 人工智能 JavaScript
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
Figma-Low-Code 是一个开源项目,能够直接将 Figma 设计转换为 Vue.js 应用程序,减少设计师与开发者之间的交接时间,支持低代码渲染和数据绑定。
19 3
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
|
2月前
|
存储 缓存 监控
如何使用内存监控工具来优化 Node.js 应用的性能
需要注意的是,不同的内存监控工具可能具有不同的功能和特点,在使用时需要根据具体工具的要求和操作指南进行正确使用和分析。
75 31
|
2月前
|
JavaScript 前端开发 API
深入理解Node.js事件循环及其在后端开发中的应用
本文旨在揭示Node.js的核心特性之一——事件循环,并探讨其对后端开发实践的深远影响。通过剖析事件循环的工作原理和关键组件,我们不仅能够更好地理解Node.js的非阻塞I/O模型,还能学会如何优化我们的后端应用以提高性能和响应能力。文章将结合实例分析事件循环在处理大量并发请求时的优势,以及如何避免常见的编程陷阱,从而为读者提供从理论到实践的全面指导。
|
2月前
|
JavaScript
如何使用内存快照分析工具来分析Node.js应用的内存问题?
需要注意的是,不同的内存快照分析工具可能具有不同的功能和操作方式,在使用时需要根据具体工具的说明和特点进行灵活运用。
52 3
|
2月前
|
Web App开发 JSON JavaScript
Node.js 中的中间件机制与 Express 应用
Node.js 中的中间件机制与 Express 应用
|
2月前
|
JavaScript 前端开发 安全
JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择
本文深入探讨了JavaScript与TypeScript的对比,分析了两者的特性及在实际项目中的应用选择。JavaScript以其灵活性和广泛的生态支持著称,而TypeScript通过引入静态类型系统,提高了代码的可靠性和可维护性,特别适合大型项目。文章还讨论了结合使用两种语言的优势,以及如何根据项目需求和技术背景做出最佳选择。
66 4
|
2月前
|
机器学习/深度学习 人工智能 JavaScript
JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景
本文探讨了JavaScript和TypeScript的未来发展趋势及其在Web开发中的应用前景。JavaScript将注重性能优化、跨平台开发、AI融合及WebAssembly整合;TypeScript则强调与框架整合、强类型检查、前端工程化及WebAssembly的深度结合。两者结合发展,特别是在Vue 3.0中完全采用TypeScript编写,预示着未来的Web开发将更加高效、可靠。
51 4
|
2月前
|
前端开发 JavaScript 关系型数据库
基于 Vue2.0 + Nest.js 全栈开发的后台应用
Vue2 Admin 是一个基于 Vue2 和 Ant Design Pro 开发的前端项目,配合 Nest.js 构建的后端,提供了一个完整的全栈后台应用解决方案。该项目支持动态国际化、用户权限管理、操作日志记录等功能,适合全栈开发者学习参考。线上预览地址:https://vue2.baiwumm.com/,用户名:Admin,密码:abc123456。
|
2月前
|
JavaScript 前端开发 API
Vue.js 3:深入探索组合式API的实践与应用
Vue.js 3:深入探索组合式API的实践与应用