0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

TouchGFX开发(3)----使用TouchGFX配置IIC接口OLED

嵌入式单片机MCU开发 来源:嵌入式单片机MCU开发 作者:嵌入式单片机MCU开 2023-11-09 15:31 次阅读

概述

TouchGFX是一种先进的软件框架,用于开发嵌入式图形界面(GUI)。借助其特性,开发者可以在STM32连接到单色OLED显示器,并使用PNG文件和Touch GFX引擎在屏幕上显示图像。

最近在弄ST的课程,需要样片的可以加群申请:615061293。

参考文档:https://support.touchgfx.com/4.18/zh-CN/docs/introduction/welcome

视频教学

https://www.bilibili.com/video/BV17m4y1t7RT/

样品申请

https://www.wjx.top/vm/mSVawPF.aspx

完整代码下载

https://download.csdn.net/download/qq_24312945/87806820

生成例程

使用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显示如下所示。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OLED
    +关注

    关注

    119

    文章

    6184

    浏览量

    223918
  • IIC接口
    +关注

    关注

    0

    文章

    23

    浏览量

    11681
  • TouchGFX
    +关注

    关注

    1

    文章

    42

    浏览量

    13223
收藏 人收藏

    评论

    相关推荐

    如何添加触摸屏驱动到TouchGFX中?

    使用STM32CubeMX移植TouchGFX 一文中介绍了如何用TouchGFX点亮屏幕,但是此时屏幕还没有触摸的功能。下面将介绍如何添加触摸屏驱动到TouchGFX
    的头像 发表于 10-09 14:41 2053次阅读

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

    了解如何使用 TouchGFX 配置屏幕,添加触摸按钮,并通过按钮控制板载 LED 的状态。
    的头像 发表于 11-09 15:25 1264次阅读
    <b class='flag-5'>TouchGFX</b><b class='flag-5'>开发</b>(2)----触摸屏幕组件点亮LED

    如何使用CubeMX创建TouchGFX工程

    目录前言一、新建BSP二、使用CubeMX创建TouchGFX工程1、配置FMC(SDRAM)2、配置DMA2D,打开DMA2D中断3配置
    发表于 01-25 06:34

    使用RT-Thread Studio开发TouchGFX软件库的原理及其步骤

    。使用RT-Thread Studio 开发1.打开 RT-Thread Studio 的包管理器,安装 ART-PI SDK 资源包2.安装完成后 选择基于 开发板 创建工程3.打开Touc
    发表于 03-25 10:43

    LPC4353 TouchGFX

    LPC4353 TouchGFX,触摸屏代码。
    发表于 03-17 08:18 15次下载

    TouchGFX代码框架以及如何添加用户代码

    1. 摘要 本文档主要介绍,TouchGFX代码框架以及如何添加用户代码。 2. 准备工作 可以正常运行的TouchGFX工程 3. 代码结构 TouchGFX的框架是基于MVP模型设
    的头像 发表于 01-18 11:28 2644次阅读
    <b class='flag-5'>TouchGFX</b>代码框架以及如何添加用户代码

    TouchGFX中Callback模板实现原理

    TouchGFX中Callback模板实现原理(现代电源技术基础杨飞课后答案)-TouchGFX为MCU带来了炫彩丰富的GUI界面,使得基于STM32芯片的人机界面开发非常方便而友好
    发表于 08-04 18:51 15次下载
    <b class='flag-5'>TouchGFX</b>中Callback模板实现原理

    TouchGFX在STM32F429IGT6上的移植(RT-Thread版本)

    目录前言一、新建BSP二、使用CubeMX创建TouchGFX工程1、配置FMC(SDRAM)2、配置DMA2D,打开DMA2D中断3配置
    发表于 11-30 18:06 0次下载
    <b class='flag-5'>TouchGFX</b>在STM32F429IGT6上的移植(RT-Thread版本)

    TouchGFX界面开发TouchGFX软件安装

    TouchGFX和STemWin类似,都是一个GUI框架,可以方便的在STM32 Cortex-M4 以及更高级别的STM32芯片上创建GUI应用程序。
    的头像 发表于 05-29 10:08 1569次阅读
    <b class='flag-5'>TouchGFX</b>界面<b class='flag-5'>开发</b>:<b class='flag-5'>TouchGFX</b>软件安装

    实战经验 | TouchGFX从旧版本更新到新版本的方法

    关键词:TouchGFX,版本升级 目录预览 1、引言 2、TouchGFX软件升级安装 3、工程项目由旧版本迁移到新版本TouchGFX 4、软件升级遇到的常见问题 01 引言 随着
    的头像 发表于 11-01 17:15 1071次阅读

    实战经验 | STM32GUI TouchGFX 屏幕切换功能简介

    关键词:GUI,TouchGFX,Transition 目录预览 1、引言 2、TouchGFX屏幕切换功能 3、小结 01 引言 TouchGFX 是专用于 STM32 的图形界面设
    的头像 发表于 11-09 10:05 5259次阅读

    实战经验 | TouchGFX 控件附加 ClickListener 功能的方法介绍

    关键词:GUI,TouchGFX,Mixin,ClickListener 目录预览 1、引言 2、TouchGFX ClickListener 模板的使用 3、小结 01 引言 TouchGF
    的头像 发表于 11-17 17:40 1312次阅读

    基于TouchGFX的智能手表设计(1)

    电子发烧友网站提供《基于TouchGFX的智能手表设计(1).pdf》资料免费下载
    发表于 12-29 17:28 6次下载

    基于TouchGFX的智能手表设计(3

    电子发烧友网站提供《基于TouchGFX的智能手表设计(3).pdf》资料免费下载
    发表于 12-29 17:30 7次下载

    基于TouchGFX的智能手表设计(4)

    电子发烧友网站提供《基于TouchGFX的智能手表设计(4).pdf》资料免费下载
    发表于 12-29 17:31 4次下载