百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

STM32新手?保姆级教程,快速上手(stm32入门教程)

liuian 2025-07-21 15:54 34 浏览

简介:本文面向熟悉STM32但是从未使用过TouchGFX的新手。

通过阅读本教程,你将可以快速上手创建你的第一个TouchGFX项目,并将其移植到你自己的硬件平台上。

说是全网独一份,不过分八


全文导航:(10章)前言、准备工作、软件安装、创建基础项目、为项目添加TouchGFX软件包、设计界面、运行代码、添加触摸支持、移植官方的Demo、结语。

一、前言

TouchGFX是专为STM32系列芯片设计的一个现代的、高性能的、强大的嵌入式图形库。

因为以快速为目标。

本文除了关键点外,不会对教程中的步骤进行过多的讲解,所以需要具有一定的STM32开发基础

这至少需要你做过图形界面的开发或者对无图形库下的,基于RGB显示屏的应用开发有最基本的概念。

并且需要了解相关的外设如FMC(SDRAM),LTDC,DMA2D的知识。

如果你曾有过LVGL、emWin之类的图形库开发经验,那么在本教程中,这些经验同样会发挥作用。

本教程基于STM32 CubeMX和STM32Cube IDE进行开发,需要对这两个软件有最基本的了解

如果你习惯使用MDK或IAR,那么也可以使用自己熟悉的IDE来完成本教程。

但是STM32 CubeMX是必须的。

不过,我还是建议使用STM32CubeIDE,毕竟CubeIDE是ST官方的开发环境,拥有最好的兼容性


二、准备工作

此小节说明了移植TouchGFX的准备工作,包括软硬件的准备,和软件环境的搭建

1.硬件

①基于STM32 MCU的核心板/开发板一块

  • 需要带有LTDC功能的型号(常见型号如F429,F746,H743);
  • 核心板需要至少板载1M以上的外部SDRAM(本文中使用基于STM32F429IG核心板,板载SDRAM为IS42S16400QJ-7TLI)。

②RGB接口的显示屏一块

  • 推荐分辨率:320x240或480x272;
  • 建议选择带触摸的型号(本文使用分辨率为320x240带电阻触摸的LCD屏)。

③ST-Link或者兼容的调试器

  • 本文使用ST-Link v2.1。

2.软件

①STM32 CubeIDE(本文中使用的版本:v1.6.1);

②STM32 CubeMX(本文中使用的版本:v6.2.1)CubeMX请预先安装MCU对应的软件包(本文中使用:STM32Cube_FW_F4 V1.26.1);

③独立的TouchGFX软件包,下载地址:STM32 Graphical User Interface - STMicroelectronics (本文中使用:TouchGFX v4.16.1)。


三、软件安装(2步)

1.TouchGFX Designer的安装

解压下载的TouchGFX软件包。

  • 进入目录:\Utilities\PC_Software\TouchGFXDesigner
  • 找到:TouchGFX-4.16.1.msi

双击运行,保持所有的选项默认直接安装即可。

安装完毕后,桌面上应该出现这两个图标。

2.CubeMX中TouchGFX软件包的安装

运行STM32 CubeMX。

在主界面右侧点击 install/remove。

在打开的对话框中,定位至 STMicroelectronis 选项卡。

滚动条往下拉,找到X-CUBE-TOUCHGFX并展开。

然后选中v4.16.1版本前方的方块,点击下方InstallNow安装

等待安装结束,则准备工作完成。


四、创建基础项目(3步)

1.通过CubeMX创建一个基础项目

通过STM32CubeMX 创建一个可以驱动RGB显示屏的基本工程,配置好必要的外设。

如果可以的话,请顺便添加触摸屏的支持。创建的过程不再赘述。

提示

这一步中请不要为项目添加过多的功能

只需添加可以驱动你的液晶屏的最少功能即可。

  • 一般为RCC,FMC,SDRAM,LTDC和DMA2D;
  • 如果有触屏,则可能需要配置SPI或者IIC。

否则出现错误后会增加排查的难度。

切换至Project Mananger,根据下图进心项目配置。

配置完成后,点击右上角“Generate code”生成代码。

等待代码生成完毕,点击关闭对话框。

2.将项目导入至STM32 CubeIDE

启动STM32 CubeIDE。

注意工作空间(Workspace)一定是CubeMX中设置的Project Location。

选择“File” -> "Import"。

选择 “Existing Projects into Workspace”,点击“Next”。

点击Browse,选择刚刚生成的项目。

其他选项保持与下图相同,点击Finish。

3.纠错、测试并运行项目

在左侧Project Explorer中即可看到刚刚导入的项目,展开工程,打开main.c文件。

在User code begin 2区域中,添加SDRAM的初始化代码。

然后编写简单的液晶屏清屏测试代码用来确认工程配置是否存在错误。

注意!!!

如果生成的代码文件中存在类似XXX CODE BEGIN 和XXX CODE END注释包裹的代码块。

所有自行编写的代码,都必须放置在这些代码块中

否则下次点击CubeMX的生成代码按钮时,代码块以外的内容会被删除

完成后,将开发板通过ST-Link连接至电脑,点击“运行”按钮。

首次运行会弹出运行配置对话框,保持所有选项默认,直接OK确认即可。

  • 如果一切配置都正确,则程序会下载至开发板运行,液晶屏此时也应该按照预期显示颜色;
  • 如果存在错误,请根据错误提示检查,直至液晶屏可以正常工作。


五、为项目添加TouchGFX软件包(2步)

通过此章节,我们会将TouchGFX软件包添加至我们刚刚创建的项目,并创建一个最基本的用户界面。

1.添加TouchGFX软件包

切换回CubeMX,选择Select Components。

选择TouchGFX,然后点击OK。

在左侧的Software Packs中选择TouchGFX,在右侧勾选Graphics Application启用TouchGFX功能。

2.配置TouchGFX的基本参数

按照图中的说明设置参数,其中的参数的具体功能为:

1、 显示接口的类型,选择LTDC即可;

2、颜色格式,根据实际情况选择,推荐RGB565

3、TouchGFX的帧缓存策略,此处使用单缓冲即可,暂时不使用双缓冲和部分缓冲;

4、设置缓冲区地址为by address,即固定的缓冲区地址;

5、在SDRAM的LTDC framebuffer之外的空间选择一处空间分配给TouchGFX的帧缓存。需要注意,可用空间必须大于等于LTDC帧缓冲的大小,并且四字节对齐;

6、TouchGFX的时钟源,选择LTDC即可;

7、硬件加速器,如果你选择的MCU有DMA2D,选择即可(如果之前的项目配置中,未启用DMA2D,则需要先配置启用DMA2D);

8、在本教程中,我们暂时不使用OS。

然后我们还有几个关键的功能需要开启,第一个是硬件CRC校验;

第二个是中断管理中的DMA2D和LTDC中断必须开启。

全部设计完成后,我们再次点击“GENERATE CODE”生成代码,生成代码完成后,选择Open Folder。


六、设计界面

进入TouchGFX文件夹,双击运行后缀名为touchgfx.part的文件。

此时,TouchGFX Designer会自动启动。

然后会进入设计器主界面。

我们点击 Add Widgets,随意添加几个控件。

然后点击右上角的 Generate Code,等待代码生成结束。


七、运行代码

代码生成完毕后回到STM32CubeIDE,在右边的工程上点击右键,选择刷新。

然后依然点击运行。

一切正常的话,我们应该可以看到液晶屏上出现了我们刚刚放置的小部件。

至此,我们已经成功完成了TouchGFX的移植。


八、添加触摸支持

接下来,我们要为TouchGFX添加触摸支持。

触摸“支持”需要通过常规的方法,根据你的“开发板”和“液晶屏”的具体“硬件编写”或者“移植触摸屏”驱动。

编写完成后,我们在左侧项目管理器中打开:STM32TouchController.cpp。

在打开的代码文件的init函数中,添加触屏的初始化代码。

然后在sampleTouch函数中添加读取触屏的代码,典型的代码应该如下。

完成代码的编写后,点击运行

将程序下载至开发板

此时点击按钮之类的控件。

如果可以看到按压动画,则标志触摸屏支持移植完成。


九、移植官方的Demo

要想学习一个软件库,最好的方法就是参考官方的Demo。

在本章中,我们将移植一个官方的Demo至我们的项目。

导入官方Demo并运行

我们回到TouchGFXDesigner,点击Edit 选择Import。

然后在弹出的对话框中,根据你的液晶屏分辨率,选择一个合适的Example或者Demo

点击感叹号可以查看此Demo适合的屏幕分辨率:

  • 此处选择的是分辨率240x320的Demo。

根据分辨率选择你感兴趣的、合适的Demo。

点击Import,将Demo导入自己的项目中。

注意!!!

请不要选择过于复杂的Demo。

这些Demo通常会因为携带大量的媒体文件,导致片内Flash无法存储,需要外部储存器映射

此处因为笔者的显示屏分辨率是320x240,而Demo的分辨率是240x320。

所以需要配置一下屏幕旋转。

如果你也需要使用此功能,请在Config中设置。

回到设计器界面,确认配置无误后,依然点击GenerateCode 按钮生成代码。

  • 切回STM32CubeIDE;
  • 刷新项目后开始运行项目;
  • 将代码下载到开发板中。

如果没有错误的话,Demo就可以正常运行了。

结语

至此我们成功地在自己的开发板上运行了TouchGFX,本教程结束

感谢大家的阅读,如果有什么问题、建议或者发现了教程中的错误,可以直接在评论区提出。

我会尽快响应。

请不要发送私信,因为公开的技术讨论才能帮助所有人。

如果你还想继续深入地研究TouchGFX的运行机理,开发自己的TouchGFX应用,请参考TouchGFX的官方文档:TouchGFX Documentation

相关推荐

教你把多个视频合并成一个视频的方法

一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...

零代码编程:用kimichat合并一个文件夹下的多个文件

一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...

Java APT_java APT 生成代码

JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...

Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器

在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...

挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?

如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...

五年后,谷歌还在全力以赴发展 Kotlin

作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...

kotlin和java开发哪个好,优缺点对比

Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...

移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?

掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...

颜值非常高的XShell替代工具Termora,不一样的使用体验!

Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...

预处理的底层原理和预处理编译运行异常的解决方案

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...

为“架构”再建个模:如何用代码描述软件架构?

在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...

深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型

2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...

比分网开发技术栈与功能详解_比分网有哪些

一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...

设计模式之-生成器_一键生成设计

一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...

构建第一个 Kotlin Android 应用_kotlin简介

第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...