极致创客 发表于 2022-8-10 23:33

基于STM32H7B3-DK的TouchGFX触控点亮LED

本帖最后由 极致创客 于 2022-8-11 00:01 编辑

#申请原创#@21ic小管家 @21小跑堂

基于STM32H7B3-DK的TouchGFX触控点亮LED

工程链接:https://pan.baidu.com/s/1JQXI0kRBPyi471RFqcUK6Q?pwd=myi1
提取码:myi1
1 使用TouchGFX Designer生成MDK5工程

开发环境
TouchGFX软件版本:4.20.0MDK5软件版本:5.37.0STM32CubeMX软件版本:6.6.1开发板:STM32H7B3-DK桌面系统:Window10

1.1 产生keil工程模板

为了快速GUI开发,使用TouchGFX生成基于STM32H7B3-DK的MDK5工程模板

打开TouchGFX,点击创建新工程



自动跳转开发板选择界面,按照1-5步骤新建工程,注意不要出现中文路径,不然会出现一些意外错误.



TouchGFX生成工程结构如下,(后续删除EWARM,gcc,STM32CubeIDE等与keil无关的文件夹)



生成的文件夹里面有一个STM32CubeMX的工程文件,由于默认配置中生成的是STM32CubeIDE工程代码,我们需要的是keil工程代码,所以需要切换IDE(除了这点,不改任何配置)



双击.ioc文件,如果出现如下提示,点击Migrate



点击工程管理,IDE选为MDK-ARM,之后点击产生代码



此时,keil工程模板基本建立,但此时如果直接打开keil工程,编译(此处选择V5编译器,因为V6编译器会出现
很多错误)会出现如下问题,是由于TouchGFX没有生成代码,导致确少界面相关源代码



只需要回到TouchGFX,点击产生代码



此时,keil界面会弹出工程变更信息,点击是



再次编译keil工程,无报错,如果有警告,再次编译后可消失,生成.hex文件



打开STM32CubeProgrammer,连接开发板,点击EL,选择外部flash烧录算法



之后点击下载,选择.hex文件,烧录



在开发板已经运行中烧录程序,如果出现如下错误,断开设备重新连接一次再烧录,烧录前出现白屏表示正常




使用由于生成的是空白模板,下载到开发板后为黑屏,此时回到TouchGFX,随便拖拽一个控件到界面,生成代码



之后在keil中编译,再次下载后正常显示



2 keil环境下使用外部烧录脚本(stdlr)烧录QSPI

    在GUI设计中需要大存储空间,这时候我们需要将代码和数据放在外扩的QSPI存储空间,尽可能的使用调试工
具一键烧录工具

软件: keil5,STM32CubeProgrammerv2.10.0


烧录方法

      Keil调试环境下,有两种方式进行外部QSPI存储空间的烧录。一种是基于FLM算法,在keil.BSP包中提供算法。
第二种方法是调用第三方的脚本进行烧录,这里使用ST公司的STM32CubeProgrammer所提供的相应的.stdlr脚本。


设置环境变量

1.打开环境变量设置步骤



2.添加环境变量为STM32_Programmer_CLI.exe所在的安装目录。默认目录如下:



3验证环境变量是否添加成功。打开CMD命令提示符,输入“STM32_Programmer_CLI -version”,显示如下即为设置成功。




Keil下载设置

Keil中,我们采用第三方的工具下载的方式进行下载,步骤如下

1. 配置下载工具如下图所示。最后第三步所填写的命令及参数如下:



    命令中的.\STM32H7B3I-DK\STM32H7B3I-DK.hex是工程生成的Hex文件,需要按照所在的工程进行修改。烧录
脚本stldr的目标也需要对应的按照实际进行修改。STM_Programmmer_CLI.exe会根据STM32H7B3I-DK.hex中的地
址信息决定将代码烧录到哪个地址,所以编译之前,必须在分散加载文件(*.sct)中说明将代码放到外部QSPI Flash的地址范围。



2下载结果

下载完成后按一次复位按钮就可正常显示



3 TouchGFX触控点亮LED

TouchGFX用MVP架构将UI界面,界面逻辑,硬件系统三者分离

View: 负责描述UI界面,比如包含哪些控件、控件如何布局等,Touchgfx Designer软件里的工作就是在构建View
Model: 保存与UI界面有关的数据;有个tick()函数,每秒执行60次,实现与硬件系统交互,相当于硬件与Touchgfx之间的桥梁
Presenter:在Model与View之间起传话筒的作用
System:Touchgfx以外所有的其它部分都属于System的范畴



我们也完全可以在View的点击事件回调函数里直接调用HAL_GPIO_TogglePin函数,但是这样会破坏MVP结构,不推荐这样做。
所以还是按官方的方法,一层一层剥套娃吧。之所以使用MVP架构是为了把代码功能分离开来,增强系统的可移植性和可阅读性。


1. 通过STM32CUBMX配置LED3

2. Touchgfx Designer里放一个按键,并为它添加交互函数btnClicked:



3打开keil,然后在Screen1View中实现btnClicked:





4由于presenter里没有btnClicked这个方法,所以需要为它添加一个:





5、同样,Model里也没有toggleLED方法,依然需要为它添加。





6编译无报错就可下载到开发板

补充说明
V6编译器下编译出错问题


第一次发技术贴,不足之处还望各位大佬提意见









skyred 发表于 2022-8-11 21:28

这个好高级,学习了
过两天还来

极致创客 发表于 2022-8-12 15:23

捉虫天师 发表于 2022-8-12 17:38

过程详细,思路清晰,楼主厉害

suncat0504 发表于 2022-8-17 09:31

学习了,谢谢楼主分享知识。

duo点 发表于 2022-8-17 11:06

这逻辑思维也太强了

tpgf 发表于 2022-9-8 11:38

多软件协同合作啊

jf101 发表于 2022-9-8 11:42

操作提示明确,思路清晰,适合新手一步一步开发!

晓伍 发表于 2022-9-8 11:48

被这个界面吸引到了 非常感兴趣啊

八层楼 发表于 2022-9-8 11:56

使用手册可以去哪里下载呢

观海 发表于 2022-9-8 12:08

btnClicked这个方法,只需要添加一个函数声明就可以吗

guanjiaer 发表于 2022-9-8 12:17

逻辑性非常的强啊

heimaojingzhang 发表于 2022-9-8 13:13

除了这俩编译器还可以使用其他种类的编译器吗

lzbf 发表于 2022-10-20 11:47

stm32f103能运行touchgfx吗   

xxmmi 发表于 2022-10-20 22:18

btnClicked这个方法,只需要添加一个函数声明就可以吗

pixhw 发表于 2022-10-21 22:31

TouchGFX充分利用了STM32的硬件图形外设

sdlls 发表于 2022-10-22 09:06

TouchGFX应用程序的视觉外观不错。

youtome 发表于 2022-10-22 14:58

想学一些简单的C++做GUI,推荐什么书?
页: [1]
查看完整版本: 基于STM32H7B3-DK的TouchGFX触控点亮LED