你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【2025·STM32峰会】GUI解决方案实训分享3-搭建空白TouchGFX例程并实现简单的功能(含硬件部分的串口打印)

[复制链接]
donatello1996 发布时间:2025-5-20 01:00
       实训的TouchGFX例程效果很炫酷,但是要学会用TouchGFX,还是必须要自行搭建空白例程从零开始学习的。- E4 X% f: g' ^0 ?/ _0 _4 [
由于线下实训已经提供了正点原子H7R7所需要的TPA文件,所以在初始化时不需要用到CubeMX,只需要直接选TPA文件创建空白TouchGFX例程即可:% q% T) h3 O+ X
23.JPG ; p3 @9 z2 B" w6 n& A- ?$ a
在空白例程中,我打算加入几个功能:1.通过图片按钮切换界面,并且按钮的按下和释放图像是不同的两个图像;2.加入TextArea用于显示硬件代码那边传过来的数值,硬件代码还没开始写,就定义一个tick事件回调函数,这个回调函数是几十毫秒执行一次,用于更新TextArea的数值;3.屏幕来回切换都使用按钮实现,并且动画设置两个不同的。8 C$ A$ P1 q# d$ D$ p
24.JPG 0 U- O# w# Q- Y7 I* G* R0 S. j+ x

' d2 V! L* e2 r" Q在创建添加任何控件之前,必须添加一个叫box的控件,可以理解为盒子或者容器,所有的交互控件,比如按钮和TextArea,都必须放在box上面:0 a0 c3 c( A8 ?  ?4 x" G- g
25.jpg 6 h7 C1 C( r6 c; l# s6 P. z
0 U, c. E% Z0 ?' G
首先是通过图片按钮切换界面这个功能,需要用到flexButton和Button的Interactions(交互),图片按钮也可以设置按下和释放:
# Z$ G" @, P  Q
26.jpg
* [' f* Y3 Z. E# B0 ^; \! v! G
* B/ X4 L! P" M4 [/ ?9 J9 G) B通过按钮(图片按钮)来切换界面,可以用TouchGFX自带的ChangeScreen事件,或者添加专属Callback回调函数,如果按钮只用来切换界面那就直接用ChangeScreen事件即可,如果在切换界面的同时还想要通过代码干别的事情,那就用Callback回调函数,但是有个注意点是,使用Callback回调函数来实现切换界面,在不使用Action控件的前提下,必须要注册一个假触发和假事件,如图,使用一个不存在的HardwareButton 0触发来触发ChangeScreen事件,由于硬件部分并没有搭建HardwareButton 0,所以这个触发是个假触发,永远不会发生:
& K0 F& h+ v2 `: x: U2 w$ i, k 27.jpg
8 i! V+ `0 t$ w! u; h3 _+ q# a" M' o9 A; A& h  K) n
在代码中注册fb_anon1的回调函数fb_anon1_Callback(),这个fb_anon1和相应回调函数的名字是可以自由取的,但是代码注册名和TouchGFX Designer注册名必须一致:
, Q* R# K- ^! \9 z 28.JPG 29.JPG application().gotoScreen2ScreenWipeTransitionEast()实现了从Screen1界面切换到Screen2界面的功能,getRootContainer().invalidate()是防止花屏的,刚刚提到了假触发的事情,因为前面注册假触发来触发ChangeScreen事件,所以才会注册application().gotoScreen2ScreenWipeTransitionEast()这个成员函数,切换界面的动作才能被fb_anon1按钮的回调函数调用。同理,Tick10和Tick1也是我注册的触发,意思是每10个节拍和每一个1节拍触发一次的事件,这个事件同样也能注册回调函数,我这里就是分别用两个TextArea来显示一个整数和浮点数的递增。
/ _) N. y9 ]# }! u% Q
: r) x4 m6 N  s# r, R' E6 b* p7 ]
值得注意的是,要用TextArea显示变量,还需要注册Wildcard,可以理解为通配符字符串:$ k. B3 L& z" I8 ^. ?
30.jpg 8 k" V2 T5 x& @3 @9 T: H, [( r

8 n, F. `2 ]6 D6 ^
在typographies选项卡里面还需要填写TextArea所用字体的显示范围,我这里填写0x20-0xfe,表示可以显示所有ASCII码:; A* L; k% H8 ?8 D& E
31.JPG ; J7 N! p. N! b4 t$ M, A. t- p' c

" A1 K+ b2 \5 M( k: p' ?
然后创建一个Screen2界面,同样是添加box和图片按钮flexButton,把这个flexButton的事件设置为切换为Screen1界面,那样,就实现两个界面通过按钮来回切换了:  W- j0 R  C6 W: x/ p
32.jpg
' i2 \" G1 D. }$ j2 J1 \/ I/ L5 Z1 H% q8 [
最后,在初始化代码处添加串口初始化代码以及重定义ioputchar代码,以实现串口打印:9 q# h+ i1 l( i. l- k; G% W
33.JPG 34.JPG 35.JPG & Q  w/ v+ u+ D) H* U8 @
' D6 B8 {7 m0 h9 [! R
在串口初始化完成之后打印一句UART1.\n:. T- q" A) t3 V6 M! p4 V7 F
36.JPG & z' B' N* _  [% ]5 n" }& P0 ^
  t1 T9 s% v; R0 Q0 C
模拟器运行效果:
0 D2 `0 n7 y$ o# b3 |- E+ p
gif3.gif 4 G# h5 z7 @6 |% j% G( \6 w0 o

3 O  Z5 J, |! i$ O4 {- {- N开发板实测运行效果视频我做成gif放在二楼。
* _; K; m% |. i! S# y5 n' G8 O
23.JPG
24.JPG
25.jpg
26.jpg
27.jpg
28.JPG
29.JPG
30.jpg
31.JPG
32.jpg
33.JPG
34.JPG
35.JPG
36.JPG
gif3.gif
收藏 评论2 发布时间:2025-5-20 01:00

举报

2个回答
lugl 回答时间:2025-5-20 07:16:28

楼主,你这作品,优秀,感谢分享!

BinWin 回答时间:2025-5-21 11:05:02

优秀的鸭皮

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版