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

相关文章
|
7天前
|
JavaScript 前端开发 API
详解队列在前端的应用,深剖JS中的事件循环Eventloop,再了解微任务和宏任务
该文章详细讲解了队列数据结构在前端开发中的应用,并深入探讨了JavaScript的事件循环机制,区分了宏任务和微任务的执行顺序及其对前端性能的影响。
|
8天前
|
JavaScript 开发者
深入理解Node.js事件循环及其在后端开发中的应用
【8月更文挑战第57天】本文将带你走进Node.js的事件循环机制,通过浅显易懂的语言和实例代码,揭示其背后的工作原理。我们将一起探索如何高效利用事件循环进行异步编程,提升后端应用的性能和响应速度。无论你是Node.js新手还是有一定经验的开发者,这篇文章都能给你带来新的启发和思考。
|
7天前
|
自然语言处理 JavaScript 前端开发
JS中this的应用场景,再了解下apply、call和bind!
该文章深入探讨了JavaScript中`this`关键字的多种应用场景,并详细解释了`apply`、`call`和`bind`这三个函数方法的使用技巧和差异。
|
12天前
|
自然语言处理 前端开发 JavaScript
探索JavaScript中的闭包及其实际应用
本文深入探讨了JavaScript中闭包的概念、特性及其在实际项目中的应用。通过具体示例,详细讲解了闭包的创建方法和用途,揭示了闭包在数据保护和模块化开发中的重要性。同时,还讨论了闭包可能带来的内存管理问题及优化策略,为前端开发者提供了全面的闭包知识和实践指导。
|
21天前
|
自然语言处理 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
本文深入探讨了JavaScript中闭包的概念,从定义、作用域链和实际应用等方面进行了详细阐述。通过生动的比喻和实例代码,帮助读者理解闭包在函数执行上下文中的重要性,以及如何在实际开发中有效利用闭包解决复杂问题。同时,文章也指出了过度使用闭包可能导致的潜在问题,并给出了相应的优化建议。
|
1月前
|
JavaScript API 数据库
深入理解Node.js事件循环及其在后端开发中的应用
【9月更文挑战第3天】本文将深入浅出地介绍Node.js的事件循环机制,探讨其非阻塞I/O模型和如何在后端开发中利用这一特性来处理高并发请求。通过实际的代码示例,我们将看到如何有效地使用异步操作来优化应用性能。文章旨在为读者揭示Node.js在后端开发中的核心优势和应用场景,帮助开发者更好地理解和运用事件循环来构建高性能的后端服务。
|
7天前
|
JavaScript 前端开发 开发者
深入浅出 Vue.js:构建响应式前端应用
Vue.js 是一个流行的前端框架,以其简洁、高效和易学著称。它采用响应式和组件化设计,简化了交互式用户界面的构建。本文详细介绍 Vue.js 的核心概念、基本用法及如何构建响应式前端应用,包括实例、模板、响应式数据和组件等关键要素,并介绍了项目结构、Vue CLI、路由管理和状态管理等内容,帮助开发者高效地开发现代化前端应用。
|
1月前
|
缓存 JavaScript 前端开发
JavaScript模块化开发:ES6模块与CommonJs的对比与应用
JavaScript模块化开发:ES6模块与CommonJs的对比与应用
21 2
|
2月前
|
JavaScript 前端开发 开发者
|
2月前
|
C# 开发者 测试技术
震惊!Xamarin 竟能如此构建跨平台应用程序,代码共享、界面设计与性能优化全攻略大揭秘!
【8月更文挑战第31天】在移动应用开发领域,跨平台工具日益受到青睐。Xamarin 是一款强大的工具,支持使用 C# 开发适用于 iOS、Android 和 Windows 的应用。通过安装 Visual Studio 或 Visual Studio for Mac,并创建 Xamarin 项目,开发者可以利用丰富的功能和工具进行开发。Xamarin 的主要优势在于代码共享,能够显著提高开发效率。
50 0
下一篇
无影云桌面