RT-Thread 瑞萨 智能家居网络开发:RA6M3 HMI Board 以太网+GUI技术实践

简介: RT-Thread 瑞萨 智能家居网络开发:RA6M3 HMI Board 以太网+GUI技术实践

不用放大了, 我在包里找到张不小的……

以太网HMI线下培训-环境准备

这是社群的文档:【腾讯文档】以太网线下培训(HMI-Board)

https://docs.qq.com/doc/DY0FIWFVuTEpORlNn

先介绍周六的培训是啥,然后再介绍一下要准备的一些东西


R A 6 M 3 H M I − B o a r d \textcolor{#4183c4}{RA6M3 HMI-Board}RA6M3HMIBoard

本次培训将使用,由RT-Thread与瑞萨电子及LVGL官方合作推出的一款高性价比图形评估套件。它采用了瑞萨电子的高性能RA6M3芯片,具备2D的图形加速和JPEG编解码功能。配合RT-Thread软件生态系统,可帮助开发人员轻松创建GUI智能硬件产品。

这是官方公众号里的:

1月20号,RT-Thread 瑞萨电子共同举办 智能家居网络开发:RA6M3 HMI Board 以太网+GUI技术实践线下培训。本期培训, 开发者将了解以太网在嵌入式行业的应用,上手LVGL GUI图形界面开发,

从0到1的去学习如何进行智能家居网络开发。同时我们还特设现场交流环节,RT-Thread及瑞萨电子资深技术工程师将现场与开发者交流、答疑解惑。

环境准备

●电脑(需要带网口/自备带网口的拓展坞)

好像我的轻薄本不太行,要看看之前的装备了

●Win10/11 系统

开发工具

●RT-Thread Studio/Keil MDK5(固件开发、编译)

R T − T h r e a d S t u d i o 开发工具 \textcolor{#4183c4}{RT-Thread Studio开发工具}RTThreadStudio开发工具

S q u a r e L i n e S t u d i o 图形工具 \textcolor{#4183c4}{SquareLine Studio图形工具}SquareLineStudio图形工具

资料链接

●RT-Thread Studio下载链接:

RT-Thread Studio下载链接

●SquareLine Studio下载链接:

SquareLine Studio 下载链接

●MQTTX 下载链接: (https://packages.emqx.net/MQTTX/v1.9.6/MQTTX-Setup-1.9.6-x64.exe

MQTTX官网

其他的我先去看看:

安装好RT-Thread Studio 后我们需要安装HMI-Board的开发板支持包:

接下来安装烧写工具:

确认工具链5.4.1版本已安装(没安装请按照下图点击后安装):


HMI-Board 以太网数据监视器

Why Rt-Thread

  • 标准
  • Nano
  • smart

标准:

MQTT

GUI

LVGL 嵌入式图形库

Squareline

现场实践中……

HMI-Board以太网数据监视器

开发工具

●RT-Thread Studio/Keil MDK5(固件开发、编译)

●SquareLine Studio(LVGL UI设计工具)

资料链接

●RT-Thread Studio下载链接:

https://download_redirect.rt-thread.org/download/studio/RT-Thread_Studio_2.2.7-setup-x86_64.exe

●SquareLine Studio下载链接:https://static.squareline.io/downloads/SquareLine_Studio_Windows_v1_3_2.zip

●MQTTX 下载链接:

https://packages.emqx.net/MQTTX/v1.9.6/MQTTX-Setup-1.9.6-x64.exe

●项目代码链接:

https://gitee.com/Rbb666/hmi-board-eth-monitor

实践环节一:以太网外设的使用

安装好RT-Thread Studio 后我们需要安装HMI-Board的开发板支持包:

接下来安装烧写工具:

创建 HMI-Board 模板工程:

在 RT-Thread Setting 中的Hardware中使能 Ethernet (以太网)外设:

然后ctrl+s 保存配置到工程,接下来点击编译选项进行工程的编译:

最后点击下载选项,烧录固件到开发板中:

电脑端设置

1.打开控制面板

2.进入:控制面板→网络和 Internet→网络和共享中心

3.选择当前电脑连接的wi-fi

4.选择属性,点击允许其他网络用户通过Internet连接

5.!!!复位下开发板,然后进行下面步骤 !!!

查看网络

烧录好固件后,打开串口终端,可以输入ifconfig命令查看是否获取到IP地址。

获取到IP地址后,可以输入 ping www.baidu.com 测试网络是否可以用。

实践环节二:MQTT 软件包的使用

基于刚刚创建好的示例工程:

在 RT-Thread Setting 中搜索 Kawaii-mqtt 软件包,并使能mqtt test功能,

然后ctrl+s 拉取软件包到工程内:

示例代码:

将下面代码粘贴覆盖 packages/kawaii-mqtt-latest/test/test.c

实在不行是可以手动拖的。

#include <stdio.h>
#include <stdint.h>
#include <rtthread.h>
#include <rtdevice.h>
#include <board.h>
#include "mqttclient.h"
static void sub_topic_handle1(void* client, message_data_t* msg)
{
    (void) client;
    KAWAII_MQTT_LOG_I("-----------------------------------------------------------------------------------");
    KAWAII_MQTT_LOG_I("%s:%d %s()...\ntopic: %s\nmessage:%s", __FILE__, __LINE__, __FUNCTION__, msg->topic_name, (char*)msg->message->payload);
    KAWAII_MQTT_LOG_I("-----------------------------------------------------------------------------------");
}
static int mqtt_publish_handle1(mqtt_client_t *client)
{
    mqtt_message_t msg;
    memset(&msg, 0, sizeof(msg));
    msg.qos = QOS0;
    msg.payload = (void *)"this is a kawaii mqtt test ...";
    return mqtt_publish(client, "pub5323", &msg);
}
static char cid[64] = { 0 };
static void kawaii_mqtt_demo(void *parameter)
{
    mqtt_client_t *client = NULL;
    
    rt_thread_delay(6000);
    
    mqtt_log_init();
    client = mqtt_lease();
    rt_snprintf(cid, sizeof(cid), "rtthread-5323", rt_tick_get());
    mqtt_set_host(client, "broker.emqx.io");
    mqtt_set_port(client, "1883");
    mqtt_set_user_name(client, "RT-Thread");
    mqtt_set_password(client, "012345678");
    mqtt_set_client_id(client, cid);
    mqtt_set_clean_session(client, 1);
    KAWAII_MQTT_LOG_I("The ID of the Kawaii client is: %s ",cid);
    mqtt_connect(client);
    
    mqtt_subscribe(client, "sub5323", QOS0, sub_topic_handle1);
    
    while (1) {
        mqtt_publish_handle1(client);
                               
        mqtt_sleep_ms(4 * 1000);
    }
}
int ka_mqtt(void)
{
    rt_thread_t tid_mqtt;
    tid_mqtt = rt_thread_create("kawaii_demo", kawaii_mqtt_demo, RT_NULL, 2048, 17, 10);
    if (tid_mqtt == RT_NULL) {
        return -RT_ERROR;
    }
    rt_thread_startup(tid_mqtt);
    return RT_EOK;
}
MSH_CMD_EXPORT(ka_mqtt, Kawaii MQTT client test program);

编译,烧录固件到开发板中,使用 ifconfig 命令查看是否获取到IP地址:

输入 ka_mqtt 命令,等待连接MQTT服务器成功:

上位机软件配置

安装软件

安装MQTTX-Setup-1.9.6-x64.exe 软件

导入配置

打开MQTTX软件,按照下图选择导入tools/mqtt_tool 目录下的:RT-Threads.json 文件

注意:其中Client ID需要修改为和其他人不同的数值,需要点击右侧的图标

注意:订阅和发布的topic需要和开发板上的topic保持一致(sub/pub+手机号后四位)

{

“temp”: 23,

“humi”: 20,

“lux”: 120

}

使用MQTT工具向开发板订阅的Topic发送数据:

开发板串口终端接收到此消息,并打印:

实践环节三:LVGL 以太网数据监视器

导入工程有以下两种方式,请任选其一即可(推荐方式一):

方式一:使用RT-Thread Studio

  • 1、打开RT-Thread Studio 选择导入:
  • 2、选择导入RT-Thread Studio项目到工作空间
  • 3、选择fimeware目录下进行导入
  • 4、点击编译按钮,等待编译完成
  • 5、烧录固件

方式二:使用Keil MDK5

  • 1、双击project.uvprojx 文件打开项目
  • 2、点击编译按钮,等待编译完成
  • 3、点击下载按钮进行固件的烧录

Demo使用介绍

克隆该https://gitee.com/Rbb666/hmi-board-eth-monitor仓库,进行

实践环节四:使用Squareline Studio开发UI

创建LVGL工程,配置如下:

UI项目资源导出设置:

选择ui文件导出路径:

修改以下选项为 lvgl.h

导出UI文件,选择hmi-board-lvgl\board\lvgl\demo\squareline路径:

点击导出,即可导出LVGL文件:

QA

问题1:

解决办法:

node-red 可视化界面(选做)

Node-RED是一个物联网编程工具,它以新颖和有趣的方式,将硬件设备、应用接口和在线服务连接到一起。

它不仅提供了一个基于浏览器的编程环境和丰富的节点类型,使流程的创建变得非常容易,而且还为流程的运行提供了运行环境,实现了一键部署的能力。

安装node-red

Windows 环境:

1、安装nodejs服务:

安装tools/node-red 目录下的node-v18.18.1-x64.msi软件。

2、安装node-red服务:打开powershell,输入以下命令

npm install -g --unsafe-perm node-red

3、在终端输入node-red,打开服务

4、打开http://127.0.0.1:1880/ 网址,即可进入node-red界面

5、进入右上角的节点管理

6、安装插件:控制板中的搜索框中输入dashboard,安装对应插件:

导入配置

导入tools/node-red 目录下的flows.json文件:

进行节点的导入:

导入成功后见下图:

使用方式

配置订阅和发布的topic:

全部配置好后,点击右上角的部署:

在dashboard界面点击可以进入web界面:

或者进入网址:http://127.0.0.1:1880/ui/

Deubg窗口:

相关实践学习
RocketMQ一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
1天前
|
存储 安全 物联网
网络安全与信息安全:防御前线的技术与意识
【5月更文挑战第9天】 在数字化时代,网络安全和信息安全已成为维护个人隐私、企业数据和国家安全的基石。本文将深入探讨网络安全漏洞的概念、加密技术的重要性以及提升安全意识的必要性。通过对这些关键领域的分析,我们将了解如何构建一个更加坚固的信息安全防线,并掌握保护信息不受未授权访问、泄露或破坏的策略和技术。
|
3天前
|
负载均衡 网络协议
虚拟网络技术:bond技术
虚拟网络技术:bond技术
7 0
|
4天前
|
传感器 机器人 语音技术
未来智能家居中的人工智能技术应用
智能家居作为未来生活的重要组成部分,正日益受到人们的关注。本文将探讨人工智能技术在智能家居领域的应用,包括语音识别、智能家电控制、环境感知等方面的创新与发展。
14 1
|
4天前
|
运维 安全 网络协议
即时通讯安全篇(十四):网络端口的安全防护技术实践
网络端口因其数量庞大、端口开放和关闭的影响评估难度大,业务影响程度高、以及异常识别技术复杂度高等特点给网络端口安全防护带来了一定的挑战,如何对端口风险进行有效治理几乎是每个企业安全团队在攻击面管理工作中持续探索的重点项。
16 0
|
4天前
|
安全 物联网 网络安全
网络安全与信息安全:防御前线的关键技术与策略
【5月更文挑战第6天】在数字化时代,网络安全与信息安全已成为保护个人隐私、企业资产和国家安全不可或缺的一环。本文深入探讨了网络安全漏洞的概念、加密技术的进展以及提升安全意识的重要性。通过分析当前网络环境中存在的风险和挑战,文章提出了一系列创新的防御措施和最佳实践,旨在帮助读者构建一个更加安全的网络环境。
|
5天前
|
机器学习/深度学习 存储 算法
m基于Yolov2深度学习网络的螺丝检测系统matlab仿真,带GUI界面
MATLAB 2022a中展示了YOLOv2算法的螺丝检测仿真结果,该系统基于深度学习的YOLOv2网络,有效检测和定位图像中的螺丝。YOLOv2通过批标准化、高分辨率分类器等优化实现速度和精度提升。核心代码部分涉及设置训练和测试数据,调整图像大小,加载预训练模型,构建YOLOv2网络并进行训练,最终保存检测器模型。
22 3
|
6天前
|
SQL 安全 算法
网络安全与信息安全:防御前线的技术与意识
【5月更文挑战第4天】在数字化时代,网络安全和信息安全已成为维护网络环境稳定的关键。本文深入探讨了网络安全漏洞的成因、加密技术的应用以及提升安全意识的重要性,旨在为读者提供全面的安全防护策略。通过对常见安全威胁的分析,我们展示了如何运用现代加密技术和安全机制来保护数据和隐私。同时,文章强调了培养个人和组织的安全意识对于构建安全防线的核心作用。
16 0
|
7天前
|
存储 安全 网络安全
网络安全与信息安全:防御前线的技术与意识
【5月更文挑战第3天】 在数字化时代,网络安全和信息安全已成为维护社会稳定、保护个人隐私和企业资产的重要领域。本文深入探讨了网络安全漏洞的成因与影响,加密技术的最新发展以及提升安全意识的必要性。通过对现有威胁的分析,我们强调了构建多层次防御策略的重要性,并提出了相应的技术解决方案和管理措施。
|
8天前
|
存储 SQL 安全
网络安全与信息安全:防御前线的关键技术与策略
【5月更文挑战第2天】 在数字化时代,数据成为了新的货币,而网络安全则是保护这些宝贵资产不受威胁的盾牌。本文将深入探讨网络安全漏洞的本质,分析加密技术如何成为防御体系的核心,并强调提升个人和企业的安全意识在构建坚固防线中的重要性。通过技术性解析和实践策略的分享,旨在为读者提供一套综合性的网络与信息安全解决方案。
|
9天前
|
安全 网络安全
网络安全攻防实战演练:技术探索与实践
【5月更文挑战第1天】网络安全攻防实战演练,通过模拟攻击与防御,提升组织应对网络安全威胁的能力。演练包括准备、攻击、防御和总结四个阶段,涉及环境搭建、攻击技术应用、防御措施执行及后期评估。此类演练有助于检验安全防护能力,提升应急响应速度,暴露系统隐患,加强团队协作,是保障网络安全的关键实践。