TouchGFX开发(3)----触摸屏幕组件点亮LED

news2025/1/11 7:39:50

TouchGFX开发.3----触摸屏幕组件点亮LED

  • 概述
  • 生成例程
  • 配置时钟树
  • 开启调试接口
  • 移植SSD1306
  • 配置调试
  • 开启TouchGFX
  • 设置屏幕刷新率
  • 配置TouchGFX
  • TouchGFX代码配置
  • 编译
  • 实际效果

概述

TouchGFX是一种先进的软件框架,用于开发嵌入式图形界面(GUI)。借助其特性,开发者可以在STM32连接到单色OLED显示器,并使用PNG文件和Touch GFX引擎在屏幕上显示图像。
参考文档:https://support.touchgfx.com/4.18/zh-CN/docs/introduction/welcome

生成例程

使用STM32CUBEMX生成例程,这里使用MCU是STM32G030C8T6。
使用的OLED的IIC接口是PB8和PB9。
在这里插入图片描述
配置IIC。

在这里插入图片描述

配置时钟树

配置时钟为64M。
在这里插入图片描述

开启调试接口

在这里插入图片描述

移植SSD1306

源码使用的是GitHub上面的stm32-ssd1306源码。
https://github.com/afiskon/stm32-ssd1306
git clone的地址为:
https://github.com/afiskon/stm32-ssd1306.git

在这里插入图片描述
下载完毕之后,需要的文件如下所示。
在这里插入图片描述

将这几个文件分别添加到对应的文件夹中。
在这里插入图片描述
将这几个文件分别添加到对应的文件夹中。

在这里插入图片描述

修改ssd1306_conf_template.h文件中的定义,选取实际所使用的MCU和接口(IIC或者SPI,以及对应通道)。
在这里插入图片描述

在main.c中添加头文件。

/* USER CODE BEGIN Includes */
#include "ssd1306.h"
#include "ssd1306_tests.h"
/* USER CODE END Includes */

在这里插入图片描述
在main.c中添加SSD1306初始化函数和demo演示函数。

  /* USER CODE BEGIN 2 */
  ssd1306_Init();
  ssd1306_TestDrawBitmap();
  /* USER CODE END 2 */

在这里插入图片描述
在ssd1306_fonts.h文件中使用的头文件为ssd1306_conf.h,所以需要修改ssd1306_conf_template.h文件名称。
在这里插入图片描述

右键重命名。
在这里插入图片描述
修改函数为ssd1306_conf.h。
在这里插入图片描述

配置调试

点击小虫子的下拉箭头,选择Debug Configurations
在这里插入图片描述
这里我使用JLink进行调试。
在这里插入图片描述

将程序下载进去之后,可以看到OLED正常的进行显示。

在这里插入图片描述

开启TouchGFX

在STM32CUBEMX中安装X-CUBE-TOUCHGFX软件包。
在这里插入图片描述
对X-CUBE-TOUCHGFX进行配置。
在这里插入图片描述

对软件包进行配置,打开X-CUBE-TOUCHGFX,可以看到需要配置CRC。
在这里插入图片描述
开启CRC。

在这里插入图片描述

配置屏幕参数由于使用的是单色OLED,所以设置为BW。

在这里插入图片描述

设置屏幕刷新率

设置屏幕刷新率为20Hz,定时器计算函数如下所示。
在这里插入图片描述

使用一个定时器来产生一个20Hz的中断来刷新屏幕。
PSC配置为640-1,ARR配置为5000-1。
在这里插入图片描述
开启中断。
在这里插入图片描述

配置TouchGFX

重新生成工程之后,可以在STM32CUBEIDE中开启TouchGFX。
在这里插入图片描述
开启完毕之后,界面如下所示。
在这里插入图片描述

由于所使用的OLED是单色的,那么配置底色为黑色的。
添加Box组件。
在这里插入图片描述
选择颜色为黑色。
在这里插入图片描述
所需的png图片可以从下面网站中进行下载。
https://iconsdb.com/
在TouchGFX添加图片组件。
在这里插入图片描述
选择对应的图片。
在这里插入图片描述

调整相应的位置。
在这里插入图片描述

生成代码。
在这里插入图片描述
代码生成成功。
在这里插入图片描述

TouchGFX代码配置

在TouchGFXConfiguration.cpp中,可以看到已经导入了LCD驱动文件。
在这里插入图片描述

TouchGFXHAL.cpp定义TouchGFXGeneratedHAL的子类TouchGFXHAL。
OSWrappers.cpp(OSAL) 包含与TouchGFX Engine同步所需的功能,所以需要在TouchGFXHAL.cpp引入头文件。

#include "ssd1306.h"
#include <touchgfx/hal/OSWrappers.hpp>

在这里插入图片描述
需要将数据从MCU缓冲区传输到显示缓冲区中。

    const unsigned char* bitmap = (const unsigned char*) getClientFrameBuffer();
    ssd1306_Fill(Black);
    ssd1306_DrawBitmap(0, 0, bitmap, 128, 64, White); 
    ssd1306_UpdateScreen();

在这里插入图片描述

在最后添加一个函数,函数将被定时器每秒调用20次,用来刷新屏幕。

extern "C"
void touchgfxSignalVSync(void)
{
	/* VSync has occurred, increment TouchGFX engine vsync counter */
	touchgfx::HAL::getInstance()->vSync();
	/* VSync has occurred, signal TouchGFX engine */
	touchgfx::OSWrappers::signalVSync();
}

在main.c函数中,注释掉刚刚的测试代码。
在这里插入图片描述

开启定时器中断。

  HAL_TIM_Base_Start_IT(&htim17);

在这里插入图片描述
定义溢出事件回调函数。

extern void touchgfxSignalVSync(void);
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
	if (htim->Instance == TIM6) 
	{
		touchgfxSignalVSync();
	}
}

在这里插入图片描述

编译

编译过程中如果出现Flash不够,可以修改优化等级。
在这里插入图片描述

选择Project->Properties
在这里插入图片描述

选择合适的优化等级。
在这里插入图片描述

实际效果

程序下载进去之后,OLED显示如下所示。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/529798.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一个非奇异快速终端滑模控制(NTSM)实例及仿真

一、被控对象 考虑这么一个被控对象 J θ ( t ) u ( t ) d ( t ) J \ddot\theta(t) u(t) d(t) Jθ(t)u(t)d(t) 其中&#xff0c; J J J 为转动惯量&#xff0c; θ \theta θ 为角度&#xff0c; u u u 为控制量&#xff0c; d d d 为扰动&#xff0c;且 d ( t ) < …

vue diff算法与虚拟dom知识整理(7) 根据init.ts源码简单梳理patch都做了些什么

之前我们也见证了 diff算法 的强大 但他 只有确认是同一个节点才做对比 如果不是就直接暴力拆卸了 我们打开我们的案例 找到 node_modules 下面的snabbdom/src下面的 init.ts文件 init.ts 拉到最下面 我们就可以看到这个返回的patch函数 patch相比于他的功能 代码算比较少的…

LeetCode高频算法刷题记录1

文章目录 1. 无重复字符的最长子串【中等】1.1 题目描述1.2 解题思路1.3 代码实现 2. 反转链表【简单】2.1 题目描述2.2 解题思路2.3 代码实现 3. LRU 缓存【中等】3.1 题目描述3.2 解题思路3.3 代码实现 4. 数组中的第K个最大元素【中等】4.1 题目描述4.2 解题思路4.3 代码实现…

吴恩达OpenAI最新课程:prompt-engineering-for-developers读书笔记

文章目录 一、前言二、Prompt编写原则2.1 环境配置2.2 编写清晰、具体的指令2.2.1 使用分隔符2.2.2 结构化输出&#xff08;JSON、HTML等&#xff09;2.2.3 要求模型检查条件是否满足2.2.4 提供少量示例&#xff08;Few-shot Prompting&#xff09; 2.3 指导模型思考2.3.1 指定…

未来工业维护:探索数据分析与机器学习的融合之路

随着工业领域相关技术的不断发展&#xff0c;预测性维护作为一种先进的维护策略&#xff0c;正日益受到企业的重视。预测性维护的核心目标是通过准确预测设备故障的发生时间&#xff0c;实现及时维护和优化生产效率。而在实现这一目标的过程中&#xff0c;数据分析和机器学习的…

FreeRTOS:任务状态和信息查询

目录 一、任务相关 API函数预览二、任务相关API函数详解2.1uxTaskPriorityGet()2.2vTaskPrioritySet()2.3uxTaskGetSystemState() ※※※※※2.4vTaskGetInfo() ※※※※※2.5xTaskGetApplicationTaskTag()2.6xTaskGetCurrentTaskHandle()2.7xTaskGetHandle()2.8xTaskGetIdleTa…

教你用JMeter做接口测试的几个简单实例

目录 前言 1、登录&#xff08;POST&#xff09; 登录 2、获取学生信息&#xff08;GET&#xff09; 获取学生信息 3、添加学生信息&#xff08;POST&#xff0c;JSON&#xff09; 添加学生信息 4、学生充值金币&#xff08;POST&#xff0c;Cookie&#xff09; 学生金…

【Linux】11. 进程控制

小实验(谨慎测试) 1. 进程退出码的引出 2. 进程码的使用 3. 进程退出 3.1 进程退出情况 进程退出分三种情况&#xff1a; 1.代码运行完毕&#xff0c;结果正确 – return 0; 2.代码运行完毕&#xff0c;结果不正确 – 根据退出码判断错误情况 3.代码没有运行完毕&#xff0c;…

如何0基础自学黑客(网络安全)技术,万字长文教你如何学习黑客(网络安全)

一、自学网络安全学习的误区和陷阱 1.不要试图先成为一名程序员&#xff08;以编程为基础的学习&#xff09;再开始学习 我在之前的回答中&#xff0c;我都一再强调不要以编程为基础再开始学习网络安全&#xff0c;一般来说&#xff0c;学习编程不但学习周期长&#xff0c;而…

【数字化转型-06】数字化转型咨询项目中如何做好高层访谈

咨询项目中少不了至关重要的一步&#xff0c;那就是高层访谈&#xff0c;做好高层访谈&#xff0c;对于咨询项目至关重要&#xff0c;我们接触的维度越高&#xff0c;就会越能把控项目的真实意图&#xff0c;有的放矢&#xff0c;不会让下面的人带偏&#xff1b;另一方面我们也…

Vue3 使用 Ts 泛型 封装本地存储

前期回顾 NVM —— 你把我玩明白_彩色之外的博客-CSDN博客本文将学习 使用 NVM 管理node版本https://blog.csdn.net/m0_57904695/article/details/130670262?spm1001.2014.3001.5501 目录 新建 \src\utils\storage-utils.ts 使用 泛型示例 泛型交换变量 泛型 strin…

在Linux系统中用vim编写第一个C语言之gcc编译器

文章目录 在Linux系统中用vim编写第一个C语言HelloWorld第一步 创建第二步 编写第三步&#xff0c;编译第四步 运行 gcc四步骤gcc常用选项 在Linux系统中用vim编写第一个C语言HelloWorld 第一步 创建 vim HelloWorld.c第二步 编写 #include<stdio.h>int main(){printf(…

Android Jsoup爬取网页数据及其局限性,接口爬取数据的思路

1.Jsoup jsoup 是一款Java 的HTML解析器&#xff0c;可直接解析某个URL地址、HTML文本内容。它提供了一套非常省力的API&#xff0c;可通过DOM&#xff0c;CSS以及类似于jQuery的操作方法来取出和操作数据。 需求是需要获取某个网站上的排行榜数据&#xff0c;用作App展示&am…

【axios】后端未收到前端post传参

今天遇到过问题&#xff0c;前端post请求参数明明已经传过去了&#xff0c;可是后端说没收到&#xff0c;不知道后端大哥是不是故意搞我。 代码前端图如下↓ 代码 import axios from axios //对象形式 const val {pass:123,user:name}axios.post(/api/login, val).then(res>…

Vue3-黑马(十三)

目录&#xff1a; &#xff08;1&#xff09;vue3-router-动态路由3 &#xff08;2&#xff09;vue3-进阶router-动态菜单 &#xff08;3&#xff09;vue3-进阶-router-令牌-获取用户信息 &#xff08;1&#xff09;vue3-router-动态路由3 登录页面后&#xff0c;如果点击了…

Android技术探索与实践:从新功能体验到故障调试的全方位探索

目录 Android技术探索与实践&#xff1a;从新功能体验到故障调试的全方位探索 第一章&#xff1a;技术解析 Android平台的架构和工作原理 应用组件的生命周期和交互方式 Android开发中常用的设计模式和技术框架解析 第二章:产品新功能体验测评 深入了解最新发布的Androi…

【安卓源码】Binder机制5 -- Java层Framework Binder机制和 AIDL

图中红色代表整个framework层 binder架构相关组件&#xff1b; Binder类代表Server端&#xff0c;BinderProxy类代码Client端&#xff1b;图中蓝色代表Native层Binder架构相关组件&#xff1b;上层framework层的Binder逻辑是建立在Native层架构基础之上的&#xff0c;核心逻辑都…

shell编程:概述、脚本入门、变量、运算符、条件判断、流程控制、读取控制台、函数、正则表达式、文本处理工具、综合案例

第 1 章 Shell 概述 1&#xff09;Linux 提供的 Shell 解析器有 [atguiguhadoop101 ~]$ cat /etc/shells /bin/sh /bin/bash /usr/bin/sh /usr/bin/bash /bin/tcsh /bin/csh2&#xff09;bash 和 sh 的关系 sh&#xff1a;比较基础bash&#xff1a;功能更加强大&#xff0c;默…

三十四、Hybrid 接口用法解析

文章目录 前言交换机接口类型有哪些Hybrid 端口使用场景什么时候必须使用 Hybrid 一、Hybrid 特点二、Hybrid 当做 access和trunk使用三、Hybrid 特殊用法 前言 交换机接口类型有哪些 Access、trunk、Hybrid、qinq Hybrid 端口使用场景 接pc、服务器、接交换机、接路由器&a…

Linux守护进程

"忍耐的灵魂啊&#xff0c;安静地运转吧~" 我们先来看看这个场景。这是一个常见的基于TCP套接字的网络服务器&#xff0c;服务端接收客户端发送的消息&#xff0c;收到后并向echo回响给客户端。 对于Linux而言&#xff0c;终端只能有一个前台进程&#xff0c;这也是为…