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问- 信息…

python-录音文件转换成文字

大多数语音转文字工具都是要收费的,免费的很少,而且质量也不太高,python有自己的语音识别库,因此尝试使用一下。 先安装库: pip install pydub speechrecognition pip install pydub 安装 ffmpeg brew install ff…

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…

docker +tmux 远程本地gdb调试

文章目录 远程调试docker pull失败docker上容器运行程序失败宿主机远程调试docker中运行的程序环境准备调试步骤 本地调试bugpwngdbtmuxpwngdb和tmux优化~~感觉用了大佬的镜像后宿主机来做pwn题都不香了~~ 远程调试 但目前不知道如何实现可以边跟着脚本运行调试的方法 docker…

前端刻度条

前端刻度条可以通过CSS和JavaScript实现。以下是一个简单的示例&#xff1a; HTML: <div class"progress-bar"><div class"progress"></div> </div>CSS: .progress-bar {width: 200px;height: 20px;border: 1px solid #ccc;bac…

三维渲染中物体与背景间的自然过渡

在三维渲染中&#xff0c;实现物体与背景间的自然过渡是提升渲染图像真实感和美观度的关键环节。以下是几种实现这一自然过渡的主要技术和方法&#xff1a; 1. 景深效果 景深&#xff08;Depth of Field, DoF&#xff09;模拟真实相机的特性&#xff0c;使得焦点之外的物体模…

sqlalchemy使用on_duplicate_key_update在尝试插入重复键的数据时更新记录

sqlalchemy使用on_duplicate_key_update在尝试插入重复键的数据时更新记录 在SQLAlchemy中&#xff0c;在尝试插入重复键的数据时更新记录&#xff0c;可以使用on_duplicate_key_update方法。这个方法是在SQLAlchemy 1.4版本中引入的&#xff0c;它允许你定义在发生键重复时&a…

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

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

安卓逆向案例——XX电影网

安卓app逆向——XX电影网 请求数据 GET /user/qk_login?requestyiSK6f7UI8TdTk5tmbx6sl3qCEL8Mn38S6h9c%2BeVxcs%3D HTTP/1.1 pid: 236 ver: 100/152/2016020901 Did: b70efb1db740444f osv: 33 devicemodel: Xiaomi/Mi 10 osvr: 13 key: 88b517dde01a39730e28f8de8678fb6d …