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

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编译器下编译出错问题


第一次发技术贴,不足之处还望各位大佬提意见。
---------------------
作者:极致创客
链接:https://bbs.21ic.com/icview-3245458-1-1.html
来源:21ic.com
此文章已获得原创/原创奖标签,著作权归21ic所有,任何人未经允许禁止转载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值