RISC-V大赛开发套件详解(三):D1哪吒开发板Haas-UI Wi-Fi配网

简介: RISC-V大赛开发套件详解(三):D1哪吒开发板Haas-UI Wi-Fi配网

编辑语:

为助力“玄铁杯”RISC-V应用创新大赛的顺利进行,协助参赛者快速上手操作大赛提供的RISC-V开发套件,OCC推出RISC-V大赛开发套件解析系列内容,从硬件特点到例程开发为开发者详细解读大赛开发套件。


上期我们介绍了D1 Yocto,为简化Linux开发者的开发过程提供了帮助。本期内容我们将开启D1 哪吒开发板的上层应用开发,为大家介绍D1 哪吒开发板的HaaS UI实战。本文是该系列实战的首篇文章,主要为大家讲解D1 哪吒开发板如何基于HaaS UI实现Wi-Fi配网。


01 概述

本文介绍D1 哪吒开发板上,基于HaaS-UI的Wi-Fi配网功能。


02 相关文件介绍

Wi-Fi涉及到的文件较多,下文将分模块展开描述。


2.1 wpa_supplicant

/usr/bin/wpa_supplicant wifi管理主程序


2.2 JS 播放器

haas-ui-demo/src/libs/TstWpaWorker.jshaas-ui-demo/src/libs/__wifi.jshaas-ui-demo/src/libs/wpa_supplicant.js JS Wi-Fi库


haas-ui-demo/src/pages/cases/components/wificonf.vue Wi-Fi配置界面


2.3 Yocto描述

openembedded-core/meta/recipes-connectivity/wpa-supplicant/wpa-supplicant_2.9.bb D1 wpa_supplicant服务的补充描述


meta-d1/recipes-connectivity/wpa-supplicant/wpa-supplicant_2.9.bbappend wpa_supplicant服务的描述


03 框架介绍

Wi-Fi服务框架采用通用的C/S架构,服务端提供离线语音功能和在线语音等功能。客户端可以接收服务端发出的事件,也可以向服务端发送控制命令。如下图框架:Wi-Fi服务wpa_supplicant为一个进程,单独运行;Wi-Fi Client(JS)为一个进程,HaaS-UI中运行。两者通过D-Bus通信。

image.gif图片.png


  • D-Bus介绍

D-Bus是一种高级的进程间通信机制,它由freedesktop.org项目提供,使用AFL和GPL双许可证发行。D-Bus 提供system守护进程(用于“添加新硬件设备”或“打印队列更改”等事件)和per-user-login-session守护进程(用于用户应用程序之间的一般 IPC 需求)。此外,消息总线建立在通用的一对一消息传递框架之上,任何两个应用程序都可以使用该框架进行直接通信(无需通过消息总线守护进程)。


目前,通信应用程序在一台计算机上,或者通过未加密的 TCP/IP 进行,适合在具有共享 NFS 主目录的防火墙后面使用。D-Bus最主要的用途是在Linux桌面环境为进程提供通信,同时能将Linux桌面环境和Linux内核事件作为消息传递到进程。


D-Bus的主要概率为总线,注册后的进程可通过总线接收或传递消息,进程也可注册后等待内核事件响应,例如等待网络状态的转变或者计算机发出关机指令。目前,D-Bus已被大多数Linux发行版所采用,开发者可使用D-Bus实现各种复杂的进程间通信任务。在RVB-D1 开发板JS轻应用平台中,服务使用D-Bus通信机制对外提供事件信号(Signal)和方法(Method Call)。服务使用的是D-Bus的系统总线(System Bus)。


  • wpa_supplicant介绍

wpa_supplicant是适用于Linux、BSD、Mac OS X和Windows的WPA请求程序,支持 WPA 和 WPA2 (IEEE 802.11i / RSN)。它适用于台式机/笔记本电脑和嵌入式系统。


Supplicant 是客户端工作站中使用的IEEE 802.1X/WPA组件。它使用 WPA Authenticator 实现密钥协商,并控制 wlan 驱动程序的漫游和 IEEE 802.11 身份验证/关联。


wpa_supplicant 被设计为在后台运行并充当控制无线连接的后端组件的“守护程序”程序。wpa_supplicant 支持单独的前端程序,并且 wpa_supplicant 包含基于文本的前端 (wpa_cli) 和 GUI (wpa_gui)。wpa_supplicant 使用灵活的构建配置,可用于选择包含哪些功能。这允许最小的代码大小(从 WPA/WPA2-Personal 的 ca. 50 kB 二进制文件和 WPA/WPA2-Enterprise 的 130 kB 二进制文件,无需调试代码到具有大多数功能和完整调试支持的 450 kB)。


04 HaaS UI界面操作

4.1 Wi-Fi联网步骤

进入到HaaS-UI的“WiFi”界面:

图片.png


点击右上角的开关

图片.png


选择ssid为"test"的热点,进入键盘

图片.png


输入passwd

图片.png


连接中:

图片.png


连接完成:

图片.png


4.2 操作GIF图

002.gif


05 下期预告

实现Wi-Fi配网后,我们将开启更多基于HaaS UI的功能开发,下期内容要为大家介绍的是如何在D1 哪吒开发板上开发HaaS UI的语音AI功能。欢迎大家持续关注本系列内容。

相关文章
|
4月前
|
前端开发 编解码 数据格式
浅谈响应式编程在企业级前端应用 UI 开发中的实践
浅谈响应式编程在企业级前端应用 UI 开发中的实践
浅谈响应式编程在企业级前端应用 UI 开发中的实践
|
4月前
|
Android开发 缓存 双11
android的基础ui组件,Android开发社招面试经验
android的基础ui组件,Android开发社招面试经验
android的基础ui组件,Android开发社招面试经验
|
13天前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
15天前
|
前端开发 JavaScript C#
C#开发者的新天地:Blazor如何颠覆传统Web开发,打造下一代交互式UI?
【8月更文挑战第28天】Blazor 是 .NET 生态中的革命性框架,允许使用 C# 和 .NET 构建交互式 Web UI,替代传统 JavaScript。本文通过问答形式深入探讨 Blazor 的基本概念、优势及应用场景,并指导如何开始使用 Blazor。Blazor 支持代码共享、强类型检查和丰富的生态系统,简化 Web 开发流程。通过简单的命令即可创建 Blazor 应用,并利用其组件化和数据绑定特性快速搭建界面。无论对于 .NET 还是 Web 开发者,Blazor 都是一个值得尝试的新选择。
30 1
|
2月前
|
数据可视化 前端开发 开发者
花样玩转“所见即所得”的可视化开发UI
【7月更文挑战第12天】WYSIWYG)的可视化开发UI带来的便利与创新: 降低开发门槛: 即使无编程基础也能通过直观操作快速构建界面。 提高开发效率: 实时预览减少代码与预览间的频繁切换。 促进团队协作: 设计师与开发者可在同一界面交流修改。 增加创意实现: 自由尝试布局、颜色与交互方式以验证想法。 此类工具(如Adobe XD、Figma、Sketch等)正变革软件开发方式,带来更高效、具创意及易操作的体验。
|
2月前
|
前端开发 JavaScript SEO
开发与运维开发问题之fx(props) = UI如何解决
开发与运维开发问题之fx(props) = UI如何解决
|
2月前
uniapp 安装插件 uView (多平台快速开发的UI框架)
uniapp 安装插件 uView (多平台快速开发的UI框架)
75 0
|
3月前
|
机器学习/深度学习 移动开发 文字识别
视觉智能开放平台产品使用合集之h5页面使用人脸活体检测,是否需要自己开发UI
视觉智能开放平台是指提供一系列基于视觉识别技术的API和服务的平台,这些服务通常包括图像识别、人脸识别、物体检测、文字识别、场景理解等。企业或开发者可以通过调用这些API,快速将视觉智能功能集成到自己的应用或服务中,而无需从零开始研发相关算法和技术。以下是一些常见的视觉智能开放平台产品及其应用场景的概览。
|
4月前
|
JavaScript API
鸿蒙开发接口UI界面:【@ohos.mediaquery (媒体查询)】
鸿蒙开发接口UI界面:【@ohos.mediaquery (媒体查询)】
49 1
|
4月前
UI开发第四篇——实现像handcent sms或者chomp sms那样的气泡
UI开发第四篇——实现像handcent sms或者chomp sms那样的气泡
30 2