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

【STM32H7S78-DK评测】TouchGFX (QR Code)二维码生成器

[复制链接]
BinWin 发布时间:2024-8-22 20:35
        Touch GFX4.24中新增了几个功能,其中之一就是二维码生成器。据描述,该控件支持最高177*177个模块的二维码。支持动态生成,是个很大的亮点。基于此功能,做个小程序来学习如何使用。
. g) j- d% ?+ y7 A1 Q8 `. T7 g$ w( D+ G* f
        完成效果如下
' ?- s2 b) P% n2 s9 x1 a) A! Y         a.png
) `. b3 h% k3 r# B2 t1 L9 h9 L         点击12个按键输入字符,执行OK后二维码便刷新为输入的字符内容。执行CLR后清除输入的字符串。检查也很简单,任何扫一扫功能的APP都能识别出来。实现这个功能需要以下过程
. k; g) m9 M9 F- Y" {         首先生成一个TouchGFX工程,搜索开发板,基于STM32H7S78-DK板卡创建模板工程。这个工程包含了GUI程序的基础外设配置和驱动实现,可以直接编译下载。
% K4 h+ L: ?3 g          c.png
9 Y% O( u+ R* C4 H- x% p" Y& V4 K' d# P         事实上,使用完整的输入法才能键入所有字符,这里只添加了加个按键,支持少数字符的输入,演示作用。添加含LABEL的按钮14个。设置好格式。字体不变,按下效果变化。
/ |; D  u& Z5 R' T- r         d.png
$ Q+ X7 N" S( T' p) M9 u  k8 N        要输入内容,那么按键按下后要执行文本更新,每个按键都给按下事件。
+ X$ G3 \$ I0 X  v" B/ D# K/ h/ P         e.png
- K; p' D! w: s) o" V        还要添加个textArea用来显示文本内容,设置缓存大小。2 G" j" [8 Y. Z
         f.png
& R# P6 K" D, @- C: f# ~5 g       最重要的角色就是这面图片已经出现的二维码控件。调整适合大小
9 B' f- A' _# ~& X4 P- R4 H       g.png
, I: W0 z* B5 E$ h. o! h6 f       完成以上,就完成了一大半的工作,这便是TouchGFX做GUI应用的优势体现。接下来要修改代码。以下就是清空字符和更新二维码的主要代码。" A1 m, ^( a$ \" t
      
  {% T& S; l) ^' R3 W
  1. if (&src == &buttonWithLabelOK)
    7 `/ N4 ]0 p. `9 ?. S
  2.     {! q: t% i4 F; W( H& ]/ g7 r. k
  3.         //Interaction13  P9 ~& \$ |' x) P  U
  4.         //When buttonWithLabelOK clicked call virtual function
      p5 G+ V) e" |& f
  5.         //Call function_ok
    5 o0 q# m+ Y& }1 j/ y; y% b
  6.         //function_ok();  h6 L/ K$ A! b+ |. h
  7.         qrCode1.convertStringToQRCode((char*)str);
    - b- Q% s; H5 o2 y# o
  8.         qrCode1.invalidate();
    6 j- K  l8 m9 s; y8 i# q
  9.         return;9 t" N9 {/ I" |+ z
  10.     }
    9 J0 m, W& ^; V. O8 K0 i1 e
  11.     if (&src == &buttonWithLabelCLR)
    ; e. E6 o- W9 v* x. G& j1 W' H
  12.     {( Q! q) u3 V2 ]2 f; f. D( ?; S( B5 C, |
  13.         //Interaction14$ T; F% y# J- D3 ~
  14.         //When buttonWithLabelCLR clicked call virtual function
    7 i! |/ p( n+ O, f+ Q
  15.         //Call function_clr
    $ v) ?0 H, V7 u. n
  16.         //function_clr();
    % N- l1 {# J. D6 t

  17. ) F; x9 w  k2 X1 y
  18.             memset(textArea1Buffer,'\0',128);
    ) s7 E" H  T6 b
  19.             textArea1.invalidate();
    8 Y9 \$ @" F" L! [& b- a1 W( u+ y
  20.             count = 0;
    ; f1 j6 _( |* q' Q4 \, J3 ?
  21.             return;
    # y. c8 f: y5 p4 B
  22.     }
复制代码
        测试结果如下
" w5 W- ]7 m9 u" g# d. u          h.png i.png
$ Z8 K8 H7 r; s$ l8 X2 X         首次上传B站,没有经验哈哈 QR Cod演示.rar (41.13 MB, 下载次数: 2)
收藏 评论1 发布时间:2024-8-22 20:35

举报

1个回答
STMCU-管管 回答时间:2024-11-4 16:21:10
视频看起来效果可以
0 @- L; n( g! T6 I

所属标签

相似分享

官网相关资源

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