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

简介: HaaS EDU K1是HaaS Education Kit1的缩写,是基于四核高性能HaaS1000芯片打造的、集颜值和内涵于一身的物联网教育开发板。作为云端一体全链路解决方案的软硬件积木平台,深度集成了AliOS Things物联网操作系统、HaaS轻应用、小程序和阿里云物联网平台等技术和服务,让开发者可以轻松的学习和开发云端一体全链路实战项目,解决实际场景或孵化创新应用。
来源 | HaaS技术社区

HaaS EDU K1是HaaS Education Kit1的缩写,是基于四核高性能HaaS1000芯片打造的、集颜值和内涵于一身的物联网教育开发板。作为云端一体全链路解决方案的软硬件积木平台,深度集成了AliOS Things物联网操作系统、HaaS轻应用、小程序和阿里云物联网平台等技术和服务,让开发者可以轻松的学习和开发云端一体全链路实战项目,解决实际场景或孵化创新应用。

image.png


HaaS EDU K1说明书

1、硬件与系统环境

1.1、硬件连接与启动


●USB Type-C供电
●电源开关拨到ON


1.2、系统环境


Windows
在设备管理器中可以看到以下串口:
不同PC的串口号不一致

image.png


macOS
在dev目录下可以看到以下串口:

crw-rw-rw- 1 root wheel 18, 4 9 21 16: 23 /dev/tty.usbserial-AU 03OJU 1

1.3、获取轻应用固件


直接使用官方标准固件

📎haaseduk1-firmwre.zip


烧录说明:将固件包解压,进入aos_burn_tool目录,打开cmd或者powershell终端,执行以下命令
python flash_program.py --bin=ota_rtos.bin
HaaS EDU K1和 HaaS100 支持多种固件烧录方式,windows用户也可参考《HaaS100快速开始》使用GUI工具烧录步骤进行固件更新。


自己编译固件
参考《HaaS EDU K1快速开始》第一部分进行搭建开发环境,在2.2 选择解决方案和开发板获取 alios3.3 源码,选择编译 amp_demo。
可通过配置文件 solutions/amp_demo/package.yaml 使能或关闭S轻应用各组件

1.4、开发工具

📎amp-clitool.zip


2、打开示例应用


下载示例应用代码包
这里通过一个简单的LED闪灯的用例来介绍。
下载应用代码包,LED闪灯用例的代码目录如下所示:

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


参考硬件资源介绍,在 app.json 中配置好三个LED对应的port口如下。

  1. {
  2. "version": "1.0.0",
  3. "io": {
  4. "L1":{
  5. "type": "GPIO",
  6. "port": 36,
  7. "dir": "output",
  8. "pull": "pulldown"
  9. },
  10. "L2":{
  11. "type": "GPIO",
  12. "port": 35,
  13. "dir": "output",
  14. "pull": "pulldown"
  15. },
  16. "L3":{
  17. "type": "GPIO",
  18. "port": 34,
  19. "dir": "output",
  20. "pull": "pulldown"
  21. }
  22. },
  23. "debugLevel": "DEBUG"
  24. }


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

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


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


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


本地更新
●打开命令行工具
●推送脚本到设备
○执行推送命令

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

执行推送命令的时候需要关闭日志串口
○复位开发板
○等待脚本传输完成,打开日志串口观察脚本运行情况


附录


硬件资源介绍
整机接口

image.png


扩展接口

image.png

更多详细硬件资源请参考《HaaS EDU K1硬件介绍

功能列表(部分)
●文件系统 FS
●系统信息 SYSTEM
●键值对存储 KV
●硬件I/O
○UART
○GPIO
○I2C
○SPI
○ADC
○PWM
●网络协议
○UDP
○TCP
○MQTT
○HTTP
●高阶功能
○IoT 阿里云IoT平台连接组件


app.json 参考示例

开发者支持

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

image.png

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

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