GUI Guider(V1.7.2) 设计UI在嵌入式系统上的应用(N32G45XVL-STB)

目录

概述

1 使用GUI Guider 设计UI

1.1 创建页面

1.2 页面切换事件实现

1.3 生成代码和仿真

1.3.1 生成和编译代码

1.3.2  仿真UI 

2 GUI Guider生成的代码结构

2.1 代码结构介绍

2.2 Project目录下的文件

3 板卡上移植UI

3.1 加载代码至工程目录

3.2 主函数中调用UI

4 测试


GUI Guider 设计UI在嵌入式系统上的应用(N32G45XVL-STB)

概述

本文主要介绍使用GUI Guider工具设计UI,该UI的底层实现方式是基于lvgl。文中详细介绍了使用GUI Guider创建项目的全部过程,包括生成代码,编译和仿真。重点介绍了如何将GUI Guider 生成的UI代码移植到嵌入式系统中,笔者使用N32G45XVL-STB板块,通过实操的方式介绍了完整的实现过程。

1 使用GUI Guider 设计UI

1.1 创建页面

打开GUI-Guider-1.7.2-GA软件,并创建工程,LCD选择480x320。完成项目创建后。窗口两个页面,其UI如下:

1)页面-1:

功能介绍:在该页面上设计一个表盘和一个button,表盘上动态显示数值的变化。button实现页面切换功能。

2)页面-2:

功能介绍:在该页面上设计一个图表和一个button,图标上动态显示数值的变化的波形。button实现页面切换功能。

1.2 页面切换事件实现

 在GUI Guider上可通过配置button事件对象,实现页面切换功能,其配置方法如下:

step-1) 鼠标右键点击button按钮

step-2) 配置跳转的页面

step-3) 使用同样方法配置第二个页面的跳转screen

通过以上步骤完成UI的设计,接下来进行代码生成和仿真。

1.3 生成代码和仿真

1.3.1 生成和编译代码

 在GUI Guider上,点击如下Item,生成代码

如果代码生成成功,可以在log栏看见如下信息:

 完成代码生成过程后,就可以编译代码,点击如下item就可以编译代码

如果编译代码成功,就会生成.exe文件,此时就可以仿真UI

1.3.2  仿真UI 

点击如下Item运行代码

如果.exe文件能正常运行时,可以看见如下UI

 运行一段时间之后的UI图像:

2 GUI Guider生成的代码结构

2.1 代码结构介绍

点击GUI Guider的Code Editor,可以代码的整体结构

Custom 文件夹下的代码功能: 

1)实现和UI触发事件相关的功能,本例中有两个页面的UI,

页面一: 速度表值变化

页面二: 数据值变化

Generated文件夹下的代码功能:

1)该文件下的.c文件分为3个类型

events_init.c: 事件初始化函数类

gui_guider.c: GUI初始化入口函数库

setup_scr_xxxx.c : 页面的UI布局函数库

widgets_init.c:  更新UI数据函数库 

2.2 Project目录下的文件

该目录下的文件夹很多,对于做移植而言,我们不要知道每个文件里的内容,只需要掌握使用方法即可。如果打算深入理解GUI Guider实现结构,如果时间允许,可做详细study。

这里重点介绍3个目录:

1)custom:  user功能代码目录

2)generated: UI功能代码目录

3)lvgl-simulator: 仿真程序目录,通过study该目录下的代码,可以了解UI的调用层级关系

3 板卡上移植UI

在移植GUI Guider生成的UI代码之前,必须保证板卡上已经完整移植了lvgl代码,且能正常工作。

3.1 加载代码至工程目录

step-1: 复制文件

将custom和generated下的文件全部复制到工程目录下

step-2: 添加文件至项目

在keil的项目文件下创建generated文件目录,然后将custom和generated中的所有.c加载到该目录中

step-3: Keil配置文件路径

在keil中将custom和generated中的.h文件路径配置到项目中,便于编译代码

3.2 主函数中调用UI

在调用GUI Guider生成的代码之前,必须保证lvgl已经被初始化。

代码第25行: 创建guider_ui对象

代码第28行: UI架构初始化

代码第29行: 用户UI和事件等初始化

源代码:

lv_ui guider_ui;
void lv_mainstart(void)
{setup_ui(&guider_ui);custom_init(&guider_ui);
}

4 测试

完成以上步骤之后,GUI Guider的UI框架已经全部移植完毕。在main.c中调用lv_mainstart()函数,编译代码,并将执行文件下载到板卡中。其运行结果如下:

1)speed UI 测试

2) wave UI测试

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/31720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【环境变量问题:计算机删除环境变量的恢复方法;此环境变量太大。此对话框允许将值设置为最长2047个字符】

不小心误删了win10系统环境变量可以试试下文方法恢复。 本方法针对修改环境变量未重启的用户可以使用,如果修改环境变量,然后还重启了,只能说重新来。 方法一:使用命令提示符恢复 被修改的系统Path只是同步到了注册表中&#x…

2024软考系规考前复习20问!看看你能答上来多少

今天给大家整理了——2024系统规划与管理师考前20问,这是一份很重要的软考备考必看干货,包含很多核心知识点。有PDF版,可打印下来,过完一遍教材后,来刷一刷、背一背,说不定可以帮你拿下不少分。 第1问- 信息…

2024.6.23周报

目录 摘要 ABSTRACT 一、文献阅读 一、题目 二、摘要 三、网络架构 四、创新点 五、文章解读 1、Introduction 2、Method 3、实验 4、结论 二、代码实验 总结 摘要 本周阅读了一篇题目为NAS-PINN: NEURAL ARCHITECTURE SEARCH-GUIDED PHYSICS-INFORMED NEURAL N…

解决电脑关机难题:电脑关不了机的原因以及方法

在使用电脑的日常生活中,有时会遇到一些烦人的问题,其中之一就是电脑关不了机。当您尝试关闭电脑时,它可能会停留在某个界面,或者根本不响应关机指令。这种情况不仅令人困惑,还可能导致数据丢失或系统损坏。 在本文中…

DS:堆的应用——两种算法和TOP-K问题

欢迎来到Harper.Lee的学习世界!博主主页传送门:Harper.Lee的博客主页想要一起进步的uu可以来后台找我哦! 一、堆的排序 1.1 向上调整——建小堆 1.1.1 代码实现 //时间复杂度:O(N*logN) //空间复杂度:O(logN) for (…

计算机网络知识点汇总

计算机网络知识点汇总 第1章计算机网络体系结构 1.1 计算机网络概述 1.1.1 计算机网络的概念 ​ 计算机网络是由若干个结点(node)和连接这些结点的链路(link)组成。网络中的结点可以是就三级、集线器、交换机、或者路由器等,网络之间通过路由器进行互联&#xf…

Nodejs 第七十九章(Kafka进阶)

kafka前置知识在上一章讲过了 不再复述 kafka进阶 1. server.properties配置文件 server.properties是Kafka服务器的配置文件,它用于配置Kafka服务的各个方面,包括网络设置、日志存储、消息保留策略、安全认证 #broker的全局唯一编号,不能…

MySQL数据库初体验+数据库管理(其一)

【1】 操作系统介绍: Linux操作系统有 RedHat CentOS Debian Ubuntu OpenSUSE 信创标准 国产系统 : 华为(欧拉) 阿里(龙蜥) 腾讯 (tencentOS) 麒麟&#xf…

【日记】梦到兄长要给鳄鱼换牙齿……(421 字)

正文 今天中午睡了一个小时多一点,做了一个很奇怪的梦。梦见兄长要给一条鳄鱼换牙齿,还说早上不好操作,要三天之后的中午或晚上,颇有一种翻黄历寻个良辰吉日之感。但我没那样大的耐性,便捏住鳄鱼的嘴,左摔右…

实战18:基于tkinter+jupyter notebook开发的情感分析系统

项目演示: 完整代码: import pandas as pd import numpy as np from collections import Counter import re import jieba from tqdm import tqdm from sklearn.metrics import roc_curve, auc import joblib import gensim from sklearn.svm import SVC from gensim.mode…

STM32小项目———感应垃圾桶

文章目录 前言一、超声波测距1.超声波简介2.超声波测距原理2.超声波测距步骤 二、舵机的控制三、硬件搭建及功能展示总结 前言 一个学习STM32的小白~ 有问题请评论区或私信指出 提示:以下是本篇文章正文内容,下面案例可供参考 一、超声波测距 1.超声波…

Studying-代码随想录训练营day16| 513找到左下角的值、112.路径总和、106从中序与后序遍历序列构造二叉树

第十六天,二叉树part03💪💪💪,编程语言:C 目录 513找到左下角的值 112.路径总和 113.路径总和II 106从中序与后序遍历序列构造二叉树 105.从前序与中序遍历序列构造二叉树 总结 513找到左下角的值…

[240621] Anthropic 发布了 Claude 3.5 Sonnet AI 助手 | Socket.IO 拒绝服务漏洞

目录 Anthropic 发布 Claude 3.5 Sonnet AI 助手Scoket.IO 拒绝服务漏洞(CVE-2024-38355) Anthropic 发布 Claude 3.5 Sonnet AI 助手 Claude 3.5 Sonnet: 更智能、更快速、更安全的 AI 助手 一、 引言 Anthropic 发布了 Claude 3.5 Sonnet&#xff0…

慢阻肺患者为何容易营养不良?朗格力教你轻松改善

#肺科营养#朗格力#班古营养#复合营养素#肺部营养#肺部健康# 慢阻肺是我国常见的、高患病率的慢性呼吸系统疾病,会对肺结构和功能产生影响,从而引起各种不良反应,其中营养不良是常见并发症之一。慢阻肺为什么会发生营养不良?营养不良又是怎么伤害慢阻肺的呢?为什么像班古精准…

鸿蒙开发:【进程模型概述】

进程模型概述 系统的进程模型如下图所示: 应用中(同一包名)的所有PageAbility、ServiceAbility、DataAbility、FormAbility运行在同一个独立进程中,即图中绿色部分的“Main Process”。 WebView拥有独立的渲染进程,即…

什么是光子带隙光纤?

长期以来,光纤通信的发展受到纤芯材料特性的限制,特别是损耗特性。二氧化硅在可见光至近红外波长范围内损耗低,与激光器工作波长相匹配,因此成为长途电信应用中光纤纤芯的首选材料。 这类光纤的纤芯是实心的,传输原理是基于全内反射(Total Internal Reflection, TIR),其…

ServBay 下一代Web开发环境

ServBay是一个集成式、图形化的本地化Web开发环境。开发者通过ServBay几分钟就能部署一个本地化的开发环境。解决了Web开发者(比如PHP、Nodejs)、测试工程师、小型团队安装和维护开发测试环境的问题,同时可以快速的进行环境的升级以及维护。S…

Docker:认识Docker Host/Container/none网络

文章目录 Docker Host网络认识Docker Host网络实际操作网络模式区别使用场景 Docker Container网络认识Docker Container网络操作实例使用场景 Docker None网络使用场景 Docker Host网络 认识Docker Host网络 Docker容器运行默认会分配独立的Network Namespace隔离子系统&…

不破不立,B站终于跳出“舒适圈”?

哔哩哔哩已经很久没有这么振奋人心的时刻了。 6月19日,哔哩哔哩当日股价涨超18%,最高达到145.6元每股,时隔11个月,再次回归高位。从时间线上看,这次的股价大涨明显与哔哩哔哩刚(以下简称“B站”&#xff0…

基于单电阻采样的电流重构

1. 单电阻采样电流重构原理 图1(a)所示是电压型三相逆变器,定义三相开 关信号为 Sa 、Sb 、Sc 。当 Sa = 1 表示A相上桥臂导 通,下桥臂关断;Sa = 0 表示相反。三相逆变器采用 SVPWM调制方式控制,有8种开关工作状态,包括 6个非零电压矢量V1 ~ V6 和2个零电压矢量V0 、V7…