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

相关文章
|
5天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
|
8天前
|
JavaScript 前端开发 API
Vue.js:打造高效前端应用的最佳选择
【10月更文挑战第9天】Vue.js:打造高效前端应用的最佳选择
11 2
|
8天前
|
设计模式 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
在本文中,我们将深入探讨JavaScript中的一个重要概念——闭包。闭包是一种强大的编程工具,它允许函数记住并访问其所在作用域的变量,即使该函数在其作用域之外被调用。通过详细解析闭包的定义、创建方法以及实际应用场景,本文旨在帮助读者不仅理解闭包的理论概念,还能在实际开发中灵活运用这一技巧。
|
9天前
|
缓存 JavaScript 前端开发
深入了解JavaScript的闭包:概念与应用
【10月更文挑战第8天】深入了解JavaScript的闭包:概念与应用
|
5天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:原理、应用与代码演示
【10月更文挑战第12天】深入理解JavaScript中的闭包:原理、应用与代码演示
|
6天前
|
监控 JavaScript 前端开发
深入了解Vue.js:构建现代前端应用的利器
【10月更文挑战第11天】深入了解Vue.js:构建现代前端应用的利器
10 0
|
6天前
|
前端开发 JavaScript 开发者
深入了解Webpack:现代JavaScript应用的打包利器
【10月更文挑战第11天】 深入了解Webpack:现代JavaScript应用的打包利器
|
6天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript闭包:原理与应用
【10月更文挑战第11天】深入理解JavaScript闭包:原理与应用
9 0
|
9天前
|
自然语言处理 JavaScript 前端开发
深入理解JavaScript中的闭包:概念与应用
【10月更文挑战第8天】深入理解JavaScript中的闭包:概念与应用
|
9天前
|
JavaScript 前端开发 开发者
深入理解JavaScript中的闭包:原理与应用
【10月更文挑战第8天】深入理解JavaScript中的闭包:原理与应用