发新帖本帖赏金 80.00元(功能说明)我要提问
返回列表
打印
[STM32H7]

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

[复制链接]
2481|18
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
本帖最后由 极致创客 于 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.0
  MDK5软件版本:5.37.0
  STM32CubeMX软件版本: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编译器下编译出错问题


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









6c136f96d3b1345d1b09a085774e3f30 (58.21 KB )

6c136f96d3b1345d1b09a085774e3f30

使用特权

评论回复

打赏榜单

21小跑堂 打赏了 80.00 元 2022-08-12
理由:恭喜通过原创文章审核!请多多加油哦!

评论
21小跑堂 2022-8-12 15:20 回复TA
手把手教你完成第一个TouchGFX的试验,配置过程完整详细,思路较为清晰,完成度较好,若配上最终实现效果的视频或动图更佳。 备注:这方面的资料或者说教程网络很完善,介于第一个在本论坛发表该类原创,同时对ST的开发板测评有一定帮助,稍微提高了点奖励~请作者大大再接再厉哦! 
沙发
skyred| | 2022-8-11 21:28 | 只看该作者
这个好高级,学习了
过两天还来

使用特权

评论回复
板凳
极致创客|  楼主 | 2022-8-12 15:23 | 只看该作者

使用特权

评论回复
地板
捉虫天师| | 2022-8-12 17:38 | 只看该作者
过程详细,思路清晰,楼主厉害

使用特权

评论回复
5
suncat0504| | 2022-8-17 09:31 | 只看该作者
学习了,谢谢楼主分享知识。

使用特权

评论回复
6
duo点| | 2022-8-17 11:06 | 只看该作者
这逻辑思维也太强了

使用特权

评论回复
7
tpgf| | 2022-9-8 11:38 | 只看该作者
多软件协同合作啊

使用特权

评论回复
8
jf101| | 2022-9-8 11:42 | 只看该作者
操作提示明确,思路清晰,适合新手一步一步开发!

使用特权

评论回复
9
晓伍| | 2022-9-8 11:48 | 只看该作者
被这个界面吸引到了 非常感兴趣啊

使用特权

评论回复
10
八层楼| | 2022-9-8 11:56 | 只看该作者
使用手册可以去哪里下载呢

使用特权

评论回复
11
观海| | 2022-9-8 12:08 | 只看该作者
btnClicked这个方法,只需要添加一个函数声明就可以吗

使用特权

评论回复
12
guanjiaer| | 2022-9-8 12:17 | 只看该作者
逻辑性非常的强啊

使用特权

评论回复
13
heimaojingzhang| | 2022-9-8 13:13 | 只看该作者
除了这俩编译器  还可以使用其他种类的编译器吗

使用特权

评论回复
14
lzbf| | 2022-10-20 11:47 | 只看该作者
stm32f103能运行touchgfx吗     

使用特权

评论回复
15
xxmmi| | 2022-10-20 22:18 | 只看该作者
btnClicked这个方法,只需要添加一个函数声明就可以吗

使用特权

评论回复
16
pixhw| | 2022-10-21 22:31 | 只看该作者
TouchGFX充分利用了STM32的硬件图形外设

使用特权

评论回复
17
sdlls| | 2022-10-22 09:06 | 只看该作者
TouchGFX应用程序的视觉外观不错。  

使用特权

评论回复
18
youtome| | 2022-10-22 14:58 | 只看该作者
想学一些简单的C++做GUI,推荐什么书?  

使用特权

评论回复
发新帖 本帖赏金 80.00元(功能说明)我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3

主题

88

帖子

2

粉丝