HaaS600 Kit的JavaScript轻应用开发配置

简介: HaaS600 Kit 是一款基于 HaaS600系列模组评估的高性价比开发板。可应用于共享控制、金融支付、智能语音、泛工业等场景的智能硬件产品开发。

> 来源 | HaaS技术社区

1、前言


image

HaaS600 Kit 是一款基于 HaaS600系列模组评估的高性价比开发板。可应用于共享控制、金融支付、智能语音、泛工业等场景的智能硬件产品开发。

HaaS600套件包含以下物料:

  • 开发板 x 1
  • micro-USB线缆 x 1
  • 5V/2A电源适配器  x 1
  • 4G天线 x 1
  • GPS天线 x 1

HaaS600 Kit在出厂时已经烧录了轻应用固件,开发者不需要编译烧录。

2、系统环境

2.1、设备连接

按照下图所示将开发电脑跟设备的调试/用户串口通过MicroUSB连接,连接后,将在PC设备管理器中出现两个串口,分别用于调试和用户串口输入输出。

image

安装USB转串口驱动

2.2、系统环境

Windows

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

image.png

macOS

安装驱动后,在dev目录下可以看到以下虚拟串口:

image.png

Note:

1. 不同的电脑生成的串口号和名称不一样,以实际生成的为准。

2. 生成的两个串口,一个是debug串口(查看运行日志,只读),另一个是用户串口(JavaScript交互式解释器或其他用途)


3、打开示例应用

3.1、下载示例应用代码包

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

代码路径 amp-examples/board/HaaS600Kit/basic/gpio

LED闪灯用例的代码目录如下所示:

  1. app

  2. ├── app.json    # 应用与板级配置

  3. └── app.js      # 用户代码

  • 查看设备连接状态

  在命令行工具下使用该命令查看设备连接状态

  1. ./amp.exe seriallist

  2. COM194

  3. COM195

Note:如果返回值跟设备管理器中生成的一致,说明设备连接和命令行工具运行正常

命令行工具默认示例代码运行hello world程序,此处使用LED Blink来作为第一个轻应用示例来介绍。

使用下面的

app.js

app.json

文件替换命令行工具示例代码目录下的同名文件,如下:

LED Blink

app.json

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

  1. {

  2. "version": "1.0.0",

  3. "io": {

  4. "D13": {

  5. "type": "GPIO",

  6. "port": 33,

  7. "dir": "output",

  8. "pull": "pulldown"

  9.        }

  10.    },

  11. "debugLevel": "DEBUG"

  12. }

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

  1. var gpio = require('gpio');

  2. var led = gpio.open({

  3. id: 'D13'

  4. });

  5. var vol = 0;

  6. setInterval(function() {

  7. vol = 1 - vol;

  8. led.writeValue(vol);

  9. console.log('gpio: led set value ' + vol);

  10. vol = led.readValue();

  11. console.log('gpio: led get value ' + vol);

  12. }, 1000);

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

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

4.1、本地热更新

  • 切换到下载模式

下载/运行模式切换开关(MODE)拨到DL侧,并通过电源选择开关(POWER SWITCH)断电重启,稍等片刻待AMP_STU指示灯间歇性双闪,如下图,说明设备已经进入本地下载模式

image

  • 通过amp工具推送应用代码到设备
  1. ./amp.exe seriallist

  2. COM194

  3. COM195

  4. ./amp.exe serialput ./app COM194

Note:Windows环境下,热更新命令的串口号需要大写。

  • 切换到运行模式(RUN)并复位
  • 运行效果如图:

    测试使用的LED灯对应的丝印为"USER",然后进入绿色闪烁状态(如下图所示)。

image


5、硬件资源

5.1、硬件资源介绍

image

5.2、硬件资源映射表

功能/接口 PIN/IO/资源映射 轻应用 port 配置
I2C0 SDA(IO50) SCL(IO49) 0
ADC0 A0

0

ADC1 A1

1

UART0 默认板级log打印 0
UART1

TXD(IO54)

RXD(IO53)

1
UART2

TXD(IO52)  

RXD(IO51)

2
GPIO

IO51

IO52

IO17

IO16

IO59

IO121

IO54

IO53

IO124

IO122

IO34

IO36

IO35

IO33

IO57

IO0

IO1

D0

D1

D2

D3

D4

D5

D6

D7

D8

D9

D10

D11

D12

D13

D14

D15

D16

SPI0

MISO(IO35)

MOSI(IO36)

SCK(IO33)

0

6、功能

6.1、功能列表(部分)

  • 文件系统 FS
  • 系统信息 SYSTEM
  • 键值对存储 KV
  • 电源管理 PM
  • 硬件I/O
    • UART
    • GPIO
    • I2C
    • SPI
    • ADC
    • DAC
    • PWM
    • TIMER
    • RTC
    • WDG
  • 网络协议
    • UDP
    • TCP
    • MQTT
    • HTTP
  • 高阶功能
    • IoT  阿里云IoT平台连接组件
    • audioplayer 音频播放组件

6.2、app.json 参考示例

  1. {

  2. "version": "1.0.0",

  3. "io": {

  4. "I2C0": {

  5. "type": "I2C",

  6. "port": 0,

  7. "addrWidth": 7,

  8. "freq": 400000,

  9. "mode": "master",

  10. "devAddr": 72

  11.    },

  12. "ADC0": {

  13. "type": "ADC",

  14. "port": 0,

  15. "sampling": 12000000

  16.    },

  17. "ADC1": {

  18. "type": "ADC",

  19. "port": 1,

  20. "sampling": 12000000

  21.    },

  22. "UART1": {

  23. "type": "UART",

  24. "port": 1,

  25. "dataWidth": 8,

  26. "baudRate": 9600,

  27. "stopBits": 1,

  28. "flowControl": "cts",

  29. "parity": "none"

  30.    },

  31. "UART2": {

  32. "type": "UART",

  33. "port": 2,

  34. "dataWidth": 8,

  35. "baudRate": 115200,

  36. "stopBits": 1,

  37. "flowControl": "disable",

  38. "parity": "none"

  39.    },

  40. "SPI1": {

  41. "type": "SPI",

  42. "port": 1,

  43. "mode": "master",

  44. "freq": 3250000

  45.    },

  46. "PWM0": {

  47. "type": "PWM",

  48. "port": 31,

  49. "mode": "master",

  50. "freq": 3250000

  51.    },

  52. "PWM1": {

  53. "type": "PWM",

  54. "port": 32,

  55. "mode": "master",

  56. "freq": 3250000

  57.    },

  58. "D0": {

  59. "type": "GPIO",

  60. "port": 51,

  61. "dir": "output",

  62. "pull": "pulldown"

  63.    },

  64. "D1": {

  65. "type": "GPIO",

  66. "port": 52,

  67. "dir": "output",

  68. "pull": "pulldown"

  69.    },

  70. "D2": {

  71. "type": "GPIO",

  72. "port": 17,

  73. "dir": "irq",

  74. "pull": "pulldown",

  75. "intMode": "both"

  76.    },

  77. "D3": {

  78. "type": "GPIO",

  79. "port": 16,

  80. "dir": "irq",

  81. "pull": "pullup",

  82. "intMode": "both"

  83.    },

  84. "D4": {

  85. "type": "GPIO",

  86. "port": 59,

  87. "dir": "output",

  88. "pull": "pulldown"

  89.    },

  90. "D5": {

  91. "type": "GPIO",

  92. "port": 121,

  93. "dir": "output",

  94. "pull": "pulldown"

  95.    },

  96. "D6": {

  97. "type": "GPIO",

  98. "port": 54,

  99. "dir": "output",

  100. "pull": "pulldown"

  101.    },

  102. "D7": {

  103. "type": "GPIO",

  104. "port": 53,

  105. "dir": "output",

  106. "pull": "pulldown"

  107.    },

  108. "D8": {

  109. "type": "GPIO",

  110. "port": 124,

  111. "dir": "output",

  112. "pull": "pulldown"

  113.    },

  114. "D9": {

  115. "type": "GPIO",

  116. "port": 122,

  117. "dir": "output",

  118. "pull": "pulldown"

  119.    },

  120. "D10": {

  121. "type": "GPIO",

  122. "port": 34,

  123. "dir": "output",

  124. "pull": "pulldown"

  125.    },

  126. "D11": {

  127. "type": "GPIO",

  128. "port": 36,

  129. "dir": "output",

  130. "pull": "pulldown"

  131.    },

  132. "D12": {

  133. "type": "GPIO",

  134. "port": 35,

  135. "dir": "output",

  136. "pull": "pulldown"

  137.    },

  138. "D13": {

  139. "type": "GPIO",

  140. "port": 33,

  141. "dir": "output",

  142. "pull": "pulldown"

  143.    },

  144. "D14": {

  145. "type": "GPIO",

  146. "port": 57,

  147. "dir": "output",

  148. "pull": "pulldown"

  149.    },

  150. "D15": {

  151. "type": "GPIO",

  152. "port": 32,

  153. "dir": "output",

  154. "pull": "pulldown"

  155.    },

  156. "D16": {

  157. "type": "GPIO",

  158. "port": 31,

  159. "dir": "output",

  160. "pull": "pulldown"

  161.    },

  162. "D17": {

  163. "type": "GPIO",

  164. "port": 76,

  165. "dir": "output",

  166. "pull": "pulldown"

  167.    }

  168.  },

  169. "debugLevel": "DEBUG",

  170. "repl": "disable"

  171. }

6.3、更多示例代码


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

更多技术与解决方案介绍,请访问阿里云AIoT首页https://iot.aliyun.com/

相关文章
|
6天前
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
22 1
|
2月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
668 1
|
2月前
|
JavaScript 前端开发 安全
TypeScript的优势与实践:提升JavaScript开发效率
【10月更文挑战第8天】TypeScript的优势与实践:提升JavaScript开发效率
|
2月前
|
JavaScript 前端开发 IDE
深入理解TypeScript:提升JavaScript开发的利器
【10月更文挑战第8天】 深入理解TypeScript:提升JavaScript开发的利器
30 0
|
6天前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
21 2
|
13天前
|
JavaScript 前端开发 测试技术
探索现代JavaScript开发的最佳实践
本文探讨了现代JavaScript开发中的最佳实践,涵盖ES6+特性、现代框架使用、模块化与代码分割、测试驱动开发、代码质量与性能优化、异步编程、SPA与MPA架构选择、服务端渲染和静态站点生成等内容,旨在帮助开发者提升代码质量和开发效率。
|
16天前
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端开发
【10月更文挑战第36天】本文将引导您探索Node.js的世界,通过实际案例揭示其背后的原理和实践方法。从基础的安装到高级的异步处理,我们将一起构建一个简单的后端服务,并讨论如何优化性能。无论您是新手还是有经验的开发者,这篇文章都将为您提供新的视角和深入的理解。
|
21天前
|
Web App开发 存储 JavaScript
深入浅出Node.js后端开发
【10月更文挑战第31天】本文将引导你进入Node.js的奇妙世界,探索其如何革新后端开发。通过浅显易懂的语言和实际代码示例,我们将一起学习Node.js的核心概念、搭建开发环境,以及实现一个简单但完整的Web应用。无论你是编程新手还是希望拓展技术的开发者,这篇文章都将为你打开一扇通往高效后端开发的大门。
|
18天前
|
运维 监控 JavaScript
鸿蒙next版开发:分析JS Crash(进程崩溃)
在HarmonyOS 5.0中,JS Crash指未处理的JavaScript异常导致应用意外退出。本文详细介绍如何分析JS Crash,包括异常捕获、日志分析和典型案例,帮助开发者定位问题、修复错误,提升应用稳定性。通过DevEco Studio收集日志,结合HiChecker工具,有效解决JS Crash问题。
37 4
|
22天前
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端开发
【10月更文挑战第30天】本文将通过一个Node.js的简单示例,引导你进入Node.js的世界。我们将从基础概念讲起,然后一步步深入到代码实现,最后总结Node.js在后端开发中的优势和应用场景。无论你是前端开发者还是后端新手,这篇文章都将为你打开一扇了解Node.js的大门。
43 2
下一篇
无影云桌面