【兆易创新GD32H759I-EVAL开发板】 移植LVGL

2024-05-16 06:36

本文主要是介绍【兆易创新GD32H759I-EVAL开发板】 移植LVGL,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么最终选择了 LVGL?

经过比较多种主流的界面设计软件,emWin 开发方便 ,但是没有开放源码  所以感觉不太自由;

TouchGFX目前仅限于STM32用, 应用范围小;

ThreadX 的配套GUI  GUIX   这个用起来感觉确实很方便,其实很想用, 但是由于对ThreadX还不太熟悉,所以GD32移植ThreadX还是有点麻烦,所以暂时放弃,但是 不得不说ThreadX 系统的性能还是很厉害的,它的中断响应速度在目前流行的多数嵌入式系统中是数一数二的,

国产的周立功也推出了GUI界面库以及配套设计,AWTK全称为Toolkit AnyWhere,是周立功倾心打造的一套基于C语言开发的GUI框架。旨在为用户提供一个功能强大、高效可靠、简单易用、可轻松做出炫酷效果的GUI引擎。其特点是支持跨平台同步开发,一次编程,到处编译,跨平台使用。但是目前感觉用的人不多,根据官方介绍 ,对系统资源也是有些要求的,

QT for MCU  对资源受限的单片机来说 还是不太流畅

GuiLite 是简单,易学的GUI库,代码量少,例子很多, 但是没有图形化设计软件;

所以最终综合考虑 ,LVGL 可以在多平台运行, 也有图形化设计软件,就选择了它

移植LVGL  基本的思路是

1使用GUI Guider 设计好LVGL的界面, 这个软件是 NXP官方为自家芯片的图形化界面设计而推出的, 也支持PC端模拟设计, 可以生成lvgl图形的源码;

2创建目标板的工程,调试好液晶屏的驱动程序 RGB,SPI等任何接口都可以

3界面移植工作

        1)移植LVGL 源码,不包含设计的GUI界面;(先把文件加入工程中)

        2)移植GUI Guider生成的界面代码(先把文件加入工程中)

        3)对LVGL界面库的代码进行配置,主要是修改一些头文件里的 宏定义(修改文h件)

        4)对GUI Guider的代码移植后 要在主函数中进行 配置和调用 (修改c文件)

        5) 有时候要根据GUI Guider界面所用到的控件和资源 对 LVGL的配置文件进行二次调整

        移植时注意 建议尽量按照官方指导的文件结构去移植,

GD32H7 移植要点

1 搞明白TLI的用法。

 TLI实际上是rgb接口液晶屏的控制器,除了要定义基本的rgb接口输出时要设置参数之外。

里面有两个图层控制单元,图层0和图层1可以进行简单的图层混合操作。

在使用时可以使用一个图层,也可以使用两个图层。但是即使不用的图层也会参与到后期的2个图层的混合过程中,最后输出混合的图像。不使用的图层可以设置一个默认的图层参数。图层没有使用时,这个默认参数就会被激活。

 TLI的工作过程是将 初始化时指定的显存区域的 图像内容 输出到GRB接口上。

暂时先用一个图层。

2移植 LVGL  的要点

1 .定义显存,定义显存位置,因为这个板子的屏幕也不小。,所以就算是单个整屏显存也要占用250kb左右的大小。使用双显存的话,需要将显存的位置定义在外部的任务中。

将显存定义在外部任务中有几种方式。

1) 不使用自定义sct文件,在Keil的工程中配置好外部显存的地址。然后在代码中指定分配地址,或者在代码属性中设置分配地址

2)使用自定义的sct文件, 在代码中指定 显存的位置

如 Arm V6下 :

先在sct中定义 SDRAM 的分配区,然后再代码中定义:

__ALIGNED(32) lv_color_t buf_disp[LV_HOR_RES_MAX * LV_VER_RES_MAX] __attribute__((section("SDRAM")));

2 .实现刷屏函数

static void disp_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t * color_p);

这个的函数实现 是lvgl的一个重点,涉及到系统工作效率

方式1  内存到内存 想 准备好的显示内容  逐个字节搬运至 指定的TLI显存地址中

方式2  使用IPA的DMA

方式3 使用DMA-DMA


/*Flush the content of the internal buffer the specific area on the display*You can use DMA or any hardware acceleration to do this operation in the background but*'lv_disp_flush_ready()' has to be called when finished.*/
static void disp_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t * color_p)
{SCB_CleanInvalidateDCache();/*The most simple case (but also the slowest) to put all pixels to the screen one-by-one*/
#if (USE_IPA_INT == 0)uint32_t time_out;
#endifuint16_t offline;offline = LV_HOR_RES_MAX - (area->x2 - area->x1 + 1);IPA_CTL = 0x0;IPA_FMADDR = (uint32_t)color_p;IPA_DMADDR = (uint32_t)buf_disp + 2*(LV_HOR_RES_MAX*area->y1+area->x1);IPA_FLOFF = 0;IPA_DLOFF = offline;IPA_FPCTL = FOREGROUND_PPF_RGB565;IPA_IMS = (uint32_t)((area->x2 - area->x1 + 1) << 16) | (uint16_t)(area->y2 - area->y1 + 1);#if (USE_IPA_INT == 1)
g_disp_drv = disp_drv;  // 将disp_drv的值赋给全局变量g_disp_drv,可能是用于设定显示驱动的参数
/* enable IPA interrupt */
// IPA_CTL_FTFIE :传输完成中断使能位 软件置位和清除 0:传输完成中断禁止 1:传输完成中断使能
//IPA_CTL_TAEIE : 传输访问错误中断使能位
//IPA_CTL_WCFIE : 配置错误中断使能位
IPA_CTL |= IPA_CTL_FTFIE | IPA_CTL_TAEIE | IPA_CTL_WCFIE;  // 将IPA_CTL_FTFIE,IPA_CTL_TAEIE,IPA_CTL_WCFIE这些标志位设置到IPA_CTL中,启用对应的IPA中断
IPA_CTL |= IPA_CTL_TEN;  // 将IPA_CTL_TEN设置到IPA_CTL中,可能为启用IPA的工作(例如开启传输等)
g_ipa_flag = 1;  // 将全局变量g_ipa_flag设置为1,表示IPA已经被设定并启用#elseIPA_CTL |= IPA_CTL_TEN;/* Wait until transfer is done */while (IPA_CTL & IPA_CTL_TEN){if(time_out++ >= 0XFFFFFFFF) break;}/* IMPORTANT!!!* Inform the graphics library that you are ready with the flushing*/lv_disp_flush_ready(disp_drv);
#endif}#if (USE_IPA_INT == 1)// /*!
//     \brief      this function handles IPA exception
//     \param[in]  none
//     \param[out] none
//     \retval     none
// */
// void IPA_IRQHandler(void)
// {
//     if(RESET != ipa_interrupt_flag_get(IPA_INT_FLAG_FTF)){
//         if(0U != (IPA_CTL & IPA_CTL_FTFIE)){
//             IPA_CTL &= (uint32_t)(~IPA_CTL_FTFIE);
//             ipa_interrupt_flag_clear(IPA_INT_FLAG_FTF);//             if(1U == g_ipa_flag){
//                 g_ipa_flag = 0U;
//                 /* IMPORTANT!!!
//                  * Inform the graphics library that you are ready with the flushing*/
//                 lv_disp_flush_ready(g_disp_drv);
//             }
//         }
//     }
// }
/*!\brief      this function handles IPA exception\param[in]  none\param[out] none\retval     none
*/
void IPA_IRQHandler(void)
{// 检查是否有IPA FTF(Frame Transfer Finish)中断标志被置位if(RESET != ipa_interrupt_flag_get(IPA_INT_FLAG_FTF)){// 如果IPA 控制寄存器中启用了FTF中断(Frame Transfer Finish Interrupt Enable)if(0U != (IPA_CTL & IPA_CTL_FTFIE)){// 关闭FTF中断使能,防止中断重入问题IPA_CTL &= (uint32_t)(~IPA_CTL_FTFIE);// 清除FTF中断标志位,以便能够检测下一个FTF事件ipa_interrupt_flag_clear(IPA_INT_FLAG_FTF);// 如果全局的g_ipa_flag标志位被设定,说明正在等待处理某些操作if(1U == g_ipa_flag){// 将g_ipa_flag标志位清零,表示当前的操作已完成g_ipa_flag = 0U;/* 重要!!!* 通知图形库刷新操作已经完成,可以进行下一个渲染周期。* lv_disp_flush_ready是一个在图形库中定义的函数,它的调用* 通知图形库当前的绘制操作已经完成,图形库可以对显示进行更新* 或者处理其他图形任务。*/lv_disp_flush_ready(g_disp_drv);}}}
}#endif

这篇关于【兆易创新GD32H759I-EVAL开发板】 移植LVGL的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994141

相关文章

五大特性引领创新! 深度操作系统 deepin 25 Preview预览版发布

《五大特性引领创新!深度操作系统deepin25Preview预览版发布》今日,深度操作系统正式推出deepin25Preview版本,该版本集成了五大核心特性:磐石系统、全新DDE、Tr... 深度操作系统今日发布了 deepin 25 Preview,新版本囊括五大特性:磐石系统、全新 DDE、Tree

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系

开发板NFS挂载文件目录

文章目录 序NFS1. 安装 NFS 服务器和客户端在服务器上(NFS 服务器端)在客户端上(NFS 客户端) 2. 配置 NFS 服务器创建共享目录编辑 `/etc/exports` 文件启动 NFS 服务 3. 在客户端挂载 NFS 共享创建挂载点挂载 NFS 共享验证挂载 4. 设置开机自动挂载5. 解决权限问题 序 本节主要实现虚拟机(服务器)与开发板(客户端)通过N

UMI复现代码运行逻辑全流程(一)——eval_real.py(尚在更新)

一、文件夹功能解析 全文件夹如下 其中,核心文件作用为: diffusion_policy:扩散策略核心文件夹,包含了众多模型及基础库 example:标定及配置文件 scripts/scripts_real:测试脚本文件,区别在于前者倾向于单体运行,后者为整体运行 scripts_slam_pipeline:orb_slam3运行全部文件 umi:核心交互文件夹,作用在于构建真

安卓开发板_联发科MTK开发评估套件串口调试

串口调试 如果正在进行lk(little kernel ) 或内核开发,USB 串口适配器( USB 转串口 TTL 适配器的简称)对于检查系统启动日志非常有用,特别是在没有图形桌面显示的情况下。 1.选购适配器 常用的许多 USB 转串口的适配器,按芯片来分,有以下几种: CH340PL2303CP2104FT232 一般来说,采用 CH340 芯片的适配器,性能比较稳定,价

RT-Thread(Nano版本)的快速移植(基于NUCLEO-F446RE)

目录 概述 1 RT-Thread 1.1 RT-Thread的版本  1.2 认识Nano版本 2 STM32F446U上移植RT-Thread  2.1 STM32Cube创建工程 2.2 移植RT-Thread 2.2.1 安装RT-Thread Packet  2.2.2 加载RT-Thread 2.2.3 匹配相关接口 2.2.3.1 初次编译代码  2.2.3.

风格控制水平创新高!南理工InstantX小红书发布CSGO:简单高效的端到端风格迁移框架

论文链接:https://arxiv.org/pdf/2408.16766 项目链接:https://csgo-gen.github.io/ 亮点直击 构建了一个专门用于风格迁移的数据集设计了一个简单但有效的端到端训练的风格迁移框架CSGO框架,以验证这个大规模数据集在风格迁移中的有益效果。引入了内容对齐评分(Content Alignment Score,简称CAS)来评估风格迁移

龙芯+FreeRTOS+LVGL实战笔记(新)——05部署主按钮

本专栏是笔者另一个专栏《龙芯+RT-Thread+LVGL实战笔记》的姊妹篇,主要的区别在于实时操作系统的不同,章节的安排和任务的推进保持一致,并对源码做了改进和优化,各位可以先到本人主页下去浏览另一专栏的博客列表(目前已撰写36篇,图1所示),再决定是否订阅。此外,也可以前往本人在B站的视频合集(图2所示)观看所有演示视频,合集首个视频链接为: 借助RT-Thread和LVGL

2024年AI芯片峰会——AI芯片架构创新专场

概述 2024年9月7日于北京举行。 官方链接: 大会官网 正文 对存内计算的思考——戴瑾 面向边缘端大语言模型的RPP架构芯片与落地实践——李原 LLM推理端的特征 边缘计算的特征 来源《联想集团边缘计算白皮书》出炉 Llama2计算过程举例 RPP架构 RPP软件栈 RPP的PPA AI 芯片架构创新开启打算里第二增长曲

【ShuQiHere】从残差思想到 ResNet:深度学习的突破性创新

【ShuQiHere】引言 在深度学习的迅速发展中,卷积神经网络(CNN)凭借其在计算机视觉领域的出色表现,已经成为一种主流的神经网络架构。然而,随着网络层数的增加,研究人员逐渐发现了一个关键问题:梯度消失 😖 和 梯度爆炸 💥,这使得训练非常深的网络变得极其困难。为了解决这一问题,残差思想 💡 被提出,并在 2015 年由 Kaiming He 等人正式引入 ResNet 中。这一创新不