TFT 彩屏 GUI 开发

针对 TFT 彩屏 GUI 开发,最稳妥的方案是 "底层驱动 + 中间件 + 应用 API" 三层结构。


一、推荐方案组合

方案 适用 MCU RAM 需求 效果
LVGL + 屏驱 F4 / G4 / H7 ≥ 16KB 手机级 UI
STemWin STM32 全系 ≥ 8KB 工业稳定
TFT_eSPI ESP32 / ESP8266 快速原型
自制 GUI 51 / F103 极低 简单按钮

建议 :STM32F407 及以上直接用 LVGL ;F103 用 STemWin 或精简版 LVGL。


二、底层驱动源码(以 ILI9341 为例)

1、 硬件接口定义(SPI)

c 复制代码
#define TFT_CS_PIN    GPIO_PIN_4
#define TFT_DC_PIN    GPIO_PIN_5
#define TFT_RST_PIN   GPIO_PIN_6
#define TFT_PORT      GPIOA

2、 写命令 / 写数据(底层核心)

c 复制代码
void TFT_WriteCmd(uint8_t cmd)
{
    HAL_GPIO_WritePin(TFT_DC_PORT, TFT_DC_PIN, GPIO_PIN_RESET);
    HAL_GPIO_WritePin(TFT_CS_PORT, TFT_CS_PIN, GPIO_PIN_RESET);
    HAL_SPI_Transmit(&hspi1, &cmd, 1, 10);
    HAL_GPIO_WritePin(TFT_CS_PORT, TFT_CS_PIN, GPIO_PIN_SET);
}

void TFT_WriteData(uint8_t dat)
{
    HAL_GPIO_WritePin(TFT_DC_PORT, TFT_DC_PIN, GPIO_PIN_SET);
    HAL_GPIO_WritePin(TFT_CS_PORT, TFT_CS_PIN, GPIO_PIN_RESET);
    HAL_SPI_Transmit(&hspi1, &dat, 1, 10);
    HAL_GPIO_WritePin(TFT_CS_PORT, TFT_CS_PIN, GPIO_PIN_SET);
}

3、 设置显示窗口(GUI 必用)

c 复制代码
void TFT_SetWindow(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1)
{
    TFT_WriteCmd(0x2A); // Column Address Set
    TFT_WriteData(x0 >> 8); TFT_WriteData(x0 & 0xFF);
    TFT_WriteData(x1 >> 8); TFT_WriteData(x1 & 0xFF);

    TFT_WriteCmd(0x2B); // Page Address Set
    TFT_WriteData(y0 >> 8); TFT_WriteData(y0 & 0xFF);
    TFT_WriteData(y1 >> 8); TFT_WriteData(y1 & 0xFF);

    TFT_WriteCmd(0x2C); // Memory Write
}

4、 画点 / 填充(GUI 基础函数)

c 复制代码
void TFT_DrawPixel(uint16_t x, uint16_t y, uint16_t color)
{
    TFT_SetWindow(x, y, x, y);
    TFT_WriteData(color >> 8);
    TFT_WriteData(color & 0xFF);
}

void TFT_Fill(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1, uint16_t color)
{
    uint32_t i, total = (x1 - x0 + 1) * (y1 - y0 + 1);
    TFT_SetWindow(x0, y0, x1, y1);
    for(i = 0; i < total; i++)
    {
        TFT_WriteData(color >> 8);
        TFT_WriteData(color & 0xFF);
    }
}

三、GUI 基础函数(自建简易 UI)

1、 画矩形 / 按钮

c 复制代码
void GUI_DrawButton(uint16_t x, uint16_t y, uint16_t w, uint16_t h, uint16_t color)
{
    TFT_Fill(x, y, x + w - 1, y + h - 1, color);
}

2、 显示字符(ASCII 8x16)

c 复制代码
void GUI_DrawChar(uint16_t x, uint16_t y, uint8_t chr, uint16_t color)
{
    uint8_t i, j;
    uint8_t temp;
    for(i = 0; i < 16; i++)
    {
        temp = ascii_8x16[chr * 16 + i];
        for(j = 0; j < 8; j++)
        {
            if(temp & (0x80 >> j))
                TFT_DrawPixel(x + j, y + i, color);
        }
    }
}

3、 触摸校准(XPT2046)

c 复制代码
typedef struct
{
    uint16_t x;
    uint16_t y;
} TouchPoint;

TouchPoint TP_GetPoint(void)
{
    TouchPoint p;
    p.x = XPT2046_Read(XP);
    p.y = XPT2046_Read(YP);
    return p;
}

四、LVGL 移植核心代码(工业级 GUI )

1、 显示刷新回调

c 复制代码
void my_flush(lv_disp_drv_t *disp, const lv_area_t *area, lv_color_t *color_p)
{
    TFT_SetWindow(area->x1, area->y1, area->x2, area->y2);
    uint32_t size = (area->x2 - area->x1 + 1) * (area->y2 - area->y1 + 1);
    HAL_SPI_Transmit(&hspi1, (uint8_t *)color_p, size * 2, 100);
    lv_disp_flush_ready(disp);
}

2、 心跳节拍(1ms)

c 复制代码
void HAL_SYSTICK_Callback(void)
{
    lv_tick_inc(1);
}

参考代码 TFT彩屏GUI函数和驱动源码 www.youwenfan.com/contentcst/182151.html

五、常用颜色定义

c 复制代码
#define RED     0xF800
#define GREEN   0x07E0
#define BLUE    0x001F
#define WHITE   0xFFFF
#define BLACK   0x0000
#define YELLOW  0xFFE0

六、调试与性能优化

问题 解决
花屏 检查 SPI 速率(≤ 40MHz)
刷屏慢 开启 DMA
触摸不准 四点校准
内存不足 减少 LVGL 缓冲区

性能提升技巧

  • 使用 DMA + SPI
  • 双缓冲机制
  • 局部刷新(Partial Update)
相关推荐
✎ ﹏梦醒͜ღ҉繁华落℘6 天前
单片机基础知识---stm32单片机的优先级
stm32·单片机·mongodb
u152109648496 天前
S.S.Audio PRO A2音频隔离器
嵌入式硬件·音视频·实时音视频·视频编解码·视频
zd8451015006 天前
RS485 总线详解
单片机·嵌入式硬件
半条-咸鱼6 天前
【STM32】I2C协议原理、HAL读写与OLED显示操作
嵌入式硬件·c·信息与通信
牛根生同志6 天前
SPI数据收发的时候 TXE与RXNE标志位置位的时机
stm32·spi·transfer
wohoo_wangzi6 天前
苏州晟雅泰电子:关于W25Q128JVSIQ这个芯片物料的参数,规格及应用领域
嵌入式硬件
goldenrolan6 天前
学习型红外控制系统稳定性挂测工装专项总结
软件测试·python·stm32·嵌入式·红外
科芯创展6 天前
1A,1MHz,30VIN,XZ4115,降压恒流LED驱动芯片
单片机·嵌入式硬件
集芯微电科技有限公司6 天前
四通道2A输出集成功率电感降压模块专为紧凑型方案设计
人工智能·单片机·嵌入式硬件·生成对抗网络·计算机外设
踏着七彩祥云的小丑6 天前
嵌入式测试学习第 37 天:异常场景测试:断电、拔插、干扰、非法指令
单片机·嵌入式硬件·学习