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

基于STM32的TouchGFX 控件附加 ClickListener 功能的方法介绍

[复制链接]
STMCU小助手 发布时间:2023-11-19 12:42
01引言
) v+ @, o5 y. t* P8 I  G2 NTouchGFX 是专用于 STM32 的图形界面设计软件,可用来低成本开发优秀的图形界面,TouchGFX 现已变的越来越流行。为了帮助客户更加深入地理解和使用 TouchGFX ,本文介绍了 TouchGFX Designer 中的 Mixin 功能,从基础示例 Button Example 出发,为文本框控件添加 ClickListener (Mixin 功能中的一项),并对源代码进行简单剖析。期望能帮助客户更深入地理解 STM32 TouchGFX 的相关功能。
5 _! t9 j+ i2 c8 L! }8 K
; Z" T; P6 O! R) o( X

1 F& z( X) D" W* p1 a& @. d3 d: J02TouchGFX ClickListener 模板的使用
& ?( x5 P- {* Q, d2.1. C++模板编程基础8 ?" N/ Q) ~+ g# d) C9 H0 D
在示例介绍之前,让我们先熟悉一下 C++模板编程的一些基础知识。模板编程属于通用编程的范畴,是为“尚未确定类型”所写的函数或类。是可以产生更干净、更快速、更精明的软件的一个强力手段。
' w6 p5 a5 {, D' s- }7 `) V

$ B: J" v0 R5 j+ M模板的优点:首先模板与某种特定类型无关,代码可重用性好;其次模板与平台无关,代码移植性好;另外模板代码在编译时才进行解释,在编译时确定检查数据类型,相比运行时检查,类型的安全性高。
- T6 B& U8 S$ z5 c3 k7 C2 @7 P" Y8 h2 E; n) H9 c) `
模板的缺点:一是代码易读性不是很好,调试不便;二是用户工程代码中需要包含模板代码(非二进制库),编译的时间较长,二进制扩展性差;另外有可能会造成二进制代码膨胀(编译后二进制代码臃肿),我们在设计模板时,需要尽可能将 C++模板中与参数⽆关的代码分离出来。
1 {; C4 f6 w/ t4 ^
  n# i" k1 r, J$ i& K3 e9 G

9 H! S& ^3 A+ t& Y0 d7 P2.2. TouchGFX Mixin 功能简介9 s9 Q0 n/ n( X- l
模板一般分为函数模板和类模板。函数模板我们这里不做赘述,重点关注 TouchGFX Mixins 类模板。TouchGFX 的 Mixins 类模板用于拓展控件的功能,目前 TouchGFX v4.20.0 中有四个 Mixin 功能,分别是 Draggable、ClickListener、FadeAnimator 和MoveAnimator,分别为控件增添相关功能。如图 1 (TouchGFX Designer Mixins 功能)所示,本文主要针对 ClickListener 做具体介绍。
7 T2 s" \, ^- {! g8 z) {  y  L( c4 ~6 C, C
微信图片_20231119124128.jpg

) x; C6 f. m, M5 d
图1. TouchGFX Designer Mixins 功能

5 z# J! |  a8 l, }0 p2 K

8 c4 A8 H9 Y* a" U0 H2.3. 基于 TouchGFX Button 例程使用 ClickListener 功能
. ?" _( O! _% T6 Q9 d. n
2.3.1. TouchGFX 例程的代码生成
/ y" K$ i7 x1 `/ V运行 TouchGFX Designer,选择 Examples;通过 Select Board Setup 选择STM32H735G DK 板;从众多例程中选择“Button Example”例程;将 Application name 改为 Button_Example,如下图图 2,然后点击 Create 创建工程。
4 E" j# j* o/ Z* x6 F. b& `6 }, n; ~3 l2 m' n
微信图片_20231119124125.jpg

1 t1 b! l, y6 e! k2 T
图2.TouchGFX Designer 生成 Button Example 例程
% x+ p: a3 T8 E# t/ ^/ ^
8 l1 e2 Y9 J8 M5 ?% o) W
进入 TouchGFX Designer 主界面后,会看到画布上有两个按钮和一个文本框,我们对界面不做更改,直接选择 Designer 右下角 (Run Target)生成代码。该操作将会复制TouchGFX 框架文件,生成配置文件、makefile、代码及资源文件(images、fonts、texts),然后编译链接、烧录目标板并运行。程序运行起来后,您可以熟悉一下该按钮例程应用。下面我们就针对该例程,为界面上的计数文本框控件注入 ClickListener 功能,应用实现“当点击计数文本框时,计数数字增加 2”的功能。) j. j  j( H! X/ I7 i* W+ ]

  [) @& g0 ^! W! M. O$ |
! j4 x% h+ T* i, `; P+ T% ^
2.3.2. 为计数文本框控件添加 ClickListener 功能
  z: a$ z4 P: e8 ]& L我们在 TouchGFX Designer 主屏界面,点击 countTxt 文本框,然后在右侧属性栏中找到 Mixins,勾选 ClickListener,如图 3 所示。然后重新生成代码。
8 A6 k% k+ x0 X1 k/ V/ j  Z% m3 W
8 ^& q, M+ ^+ V) {
微信图片_20231119124122.jpg
. P9 L+ G7 _, F: X
图3.TouchGFX Designer, 计数文本框 mixin ClickListener 功能
8 S$ j! ~5 |/ R
- \+ H" \. [" r, ?) L( E
我们可以使用 VS code 编辑代码,或使用其它如 STM32CubeIDE 等工具编辑代码。打开 MainView.hpp,为计数文本框,添加代码如下(黄底色部分):0 Q% d- v/ g5 O: V

$ B# J' L% S. p' P: ?6 k6 K6 W- w
微信图片_20231119124119.jpg
( D) b. o! x$ @2 h5 L- q- L. G4 v
微信图片_20231119124116.jpg
, v; K9 K6 ~  z' I8 Y
* z& F$ W7 e& s5 u
然后我们转到 MainView.cpp 文件,首先将 txtClickedCallback 对象与 MainView的 cntTextClickHandler(文本框点击处理函数)绑定,这是在 MainView 类的构造函数中初始化列表中实现的。将 txtClickedCallback 加入初始化列表中,参数使用指向MainView 中 cntTextClickHandler 函数的函数指针。我们还需要修改 setupScreen 函数,在这里为 countTxt 添加 ClickAction,参数使用 txtClickedCallback, 以实现在主屏界面创建时,将 countTxt 文本框的点击事件与 txtClickedCallback 对象绑定在一起。另外我们还需要实现 cntTextClickHandler,具体代码如下:" m7 p5 l& ?3 e( g& ]7 ~& l

  S/ Z) f0 ~' `4 [
微信图片_20231119124113.jpg

# s. l, n7 D9 o8 l& `) G

, ]' b& p4 o. q! ~5 h修改完成后,保存,编译,运行。您将会发现当每次点击 countTxt 文本框时,文本框计数会增加 2。至此,我们已经实现了为文本框控件加入 ClickListener 的功能。大家可以看到,在 TouchGFX 应用中使用 ClickListener 类模板做开发是十分便捷的,代码量也较小。下面我们对代码进一步解读。0 e: |! w2 S/ q2 k& V
, S. R! ]( S6 K9 t0 a. C! r, u9 l7 C
2.3.3. ClickListener 模板代码7 ?* j0 X" G8 A" G2 o' k% j
ClickListener 类模板是 TouchGFX 框架的一部分,封装在 ClickListener.hpp 中,代码如下:
( p! h, J' T8 U8 B# W* D7 ~) {9 f1 L, [* l. c5 s, _) f- \
微信图片_20231119124109.jpg

2 K' J) P7 h4 Q
微信图片_20231119124106.jpg

. [9 [+ t+ x! y& h0 g0 r4 R
4 }( w6 \8 k3 g
ClickListener 是一个标准的类模板。所谓类模板,就是“包含一个或多个尚未确定类型”的类。必须将具体类型当作模板参数传入,才可使用。当传入模板参数后,该类模板便以你所指定的参数类型,由编译器进行实例化。将具体类型传入到类模板进行实例化,我们会得到一个新的 ClickListener 类,转变为从传入参数(某待定的类)的派生类。
% r/ f) L% C; e9 f( X$ A% v/ I( S9 C" i
在生成的代码 MainViewBase.hpp 中(MainView 是 MainViewBase 的派生类),我们可以找到 countTxt 的声明:
# k) w+ A* ^. S/ v' V* T7 f: Q
% B; |) u- `2 D3 @2 A9 n0 Z. v' P
touchgfx::ClickListener< touchgfx::TextAreaWithOneWildcard > countTxt;
7 o& J# ^1 c0 \: ?+ \' A7 j

) \; Q1 [- _: R1 l$ p$ F这里,该模板示例类是从 TextAreaWithOneWildcard 类(即原计数文本框类型)继承下来的。如果您选择的不是为文本框增加 ClickListener 功能,而是其它控件,则新的ClickListener 实例类将派生自您所用的控件。本例中的继承关系如下:
# p6 e# B: h! ?& a2 p$ R; u
微信图片_20231119124102.jpg
; W! T7 A9 i" H* m' R- o7 M+ C
% {6 p$ p+ w' {
该 ClickListener 实例类是 TextAreaWithOneWildcard 类的派生类,不仅仅继承了TextAreaWithOneWildcard 的属性与方法,另外还添加了一个 GenericCallback 指针变量clickAction,该指针由附加的 setClickAction 方法赋值。由另一个方法 handleClickEvent使用,在 handleClickEvent 中在响应 Click 事件时,会调用该 clickAction。(关于callback 类的使用,我们这里不做赘述,如果您需要进一步了解,请参考 TouchGFX 相关文档)。  a) [" F$ E/ z7 v; t! p
* q* G. e1 E* Z2 `2 _
2.3.4. ClickListener 模板应用: N7 y2 r' I( i; U% s. j3 x
我们清楚了 ClickListener 类模板的原理后,回头来看例子中的 ClickListener 的应用代码,就会发现其逻辑十分清晰。
7 _! A; s. O, \7 S  i$ E

+ J) B/ Z1 v  h0 ~首先在 MainView.hpp 中声明了一个 Callback txtClickedCallback, 和一个事件处理函数 cntTextClickHandler。在 MainView.cpp 中初始化该 txtClickedCallback, 将其与cntTextClickHandler 关联,即实现当调用该 Callback 时,会转到 cntTextClickHandler 进行处理。
2 I/ k! l2 p" y! t$ T, s4 e

$ n- i+ c2 c5 ]5 y再在 setupScreen 函数中调用 ClickListener 类模板接口 setClickAction 将txtClickedCallback 的地址赋给 ClickListener 实例化类的 clickAction 指针。则ClickListener 实例化类(这里即 TextAreaWithOneWildcard 类的派生类)在处理ClickEvent 时就会执行到 txtClickedCallback 关联的处理函数 cntTextClickHandler
0 Q3 {- a$ c( ?# s3 U9 }, @+ ]) z- _( ]# W; C1 @) H
最后需要实现 MainView 类中的 Click 事件处理函数 cntTextClickHandler,这里的实现为:当 Click 事件类型为“Click 按键释放”时调用 increaseValue 函数两次。
8 U5 L5 I5 a6 v% q; d  x8 B+ G1 }

' }; ]5 ~" y' i3 A4 l' f8 v% [4 l03小结6 }9 L) }9 @' D" K4 {! U% i
TouchGFX 是 STM32 专用的界面设计工具,功能强大且易用。本文选择了 Mixins 功能进行简介,从基础示例 Button Example 出发,动手添加 ClickListener (Mixin) 功能,并从源代码的角度浅析了 ClickListener 类模板的使用,助力客户更深入地理解 STM32 TouchGFX。2 ^8 Y' _7 g- G
# ?1 K8 i- ^" t9 O0 V$ ~- p
转载自: STM32单片机
3 `0 t: J6 Z% M8 h: Z# b如有侵权请联系删除
3 l8 P5 x4 `+ t. T8 Y9 h1 K4 \! E' Z' a+ |
收藏 评论0 发布时间:2023-11-19 12:42

举报

0个回答

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版