系列目录


前言

前面一章利用CH347的USB转SWD接口,搭配OpenOCD,实现了对常见型号MCU下载功能。

本章节主要利用CH347的USB转SPI接口,操作ST7798 LCD(1.8寸,128*160,SPI接口)屏幕,去实现照片的轮询显示。

最终界面效果如下:

功能介绍中提供硬件的连接图。

在这里插入图片描述
LCD屏幕控制部分,会轮询显示右侧添加的图片(支持PNG、BMP与JPG),同时会将轮询显示的图片与LCD 硬件屏幕同步。
在这里插入图片描述
LCD设置部分:
主要有以下设置:

  1. 图片轮询间隔,默认5S,可拖动修改间隔时间。
  2. LCD屏的DC(命令/数据切换脚)与RST(复位脚)设置,需借用CH347F的两个GPIO引脚实现。默认设置是DC脚(GPIO 0),RST脚(GPIO 1),可根据实际硬件的接线自行修改。
  3. LCD填充屏幕测试:用来测试当前接线与SPI LCD屏幕是否正常,可选择颜色,点击填充屏幕,观察LCD颜色显示是否正常。
    在这里插入图片描述
    演示视频:

ch347_spi_lcd演示

[注]:显示的图片确认无透明通道,推荐48位深的png图像。
LCD屏幕尺寸固定为128 * 160,因为更大尺寸,CH347难以直接驱动,需额外添加电源电路。

具体实现

CH347相关的SPI操作如下:

UCHAR GPIOInit(UCHAR enable, UCHAR dir, UCHAR data) {
	UCHAR state;
	CH347GPIO_Set(m_devIndex, enable, dir, data);
	CH347GPIO_Get(m_devIndex, &dir, &state);
	return state;
}
void GPIOSet(UCHAR enable, UCHAR dir, UCHAR data) {
	CH347GPIO_Set(m_devIndex, enable, dir, data);
}
bool SpiInit() {
	mSpiCfgS spi_cfg;
	spi_cfg.iMode = 3;
	spi_cfg.iClock = 1;     //30M
	spi_cfg.iByteOrder = 1;   //MSB
	spi_cfg.iSpiWriteReadInterval = 0;
	spi_cfg.iSpiOutDefaultData = 0xFF;
	spi_cfg.iChipSelect = 0x0080;
	spi_cfg.CS1Polarity = 0;
	spi_cfg.CS2Polarity = 0;
	spi_cfg.iIsAutoDeativeCS = 0;
	spi_cfg.iActiveDelay = 0;
	spi_cfg.iDelayDeactive = 0;
	if (CH347SPI_Init(m_devIndex, &spi_cfg) == FALSE) {
		return false;
	}
}
void WriteSpi(std::vector<UCHAR> data)
{
	CH347SPI_Write(m_devIndex, 0x80, data.size(), 128, data.data());
}

其他设置

包含程序界面的主题色设置与使用说明超链接。
在这里插入图片描述

总结及未来延伸

本章节完善了CH347 USB转SPI接口功能,基于ST7798 SPI LCD屏幕实现了图片轮询、引脚配置及屏幕测试等基础功能。目前仅支持预设图片轮询,未来可拓展显示温湿度、CPU及内存状态等实用信息。
至此,CH347多功能接口演示软件(集SPI、I2C、JTAG、SWD、UART、GPIO于一体)的主要功能全部完成,覆盖CH347核心协议与外设控制场景,形成了相对完整的CH347外设控制解决方案。未来可进一步优化操作逻辑、增加自定义脚本功能,拓展更多外设适配库,提升工具通用性。

程序发布在SourceForge上,如有任何使用建议欢迎评论留言:

https://sourceforge.net/projects/ch347-multi-function-software/

Logo

openvela 操作系统专为 AIoT 领域量身定制,以轻量化、标准兼容、安全性和高度可扩展性为核心特点。openvela 以其卓越的技术优势,已成为众多物联网设备和 AI 硬件的技术首选,涵盖了智能手表、运动手环、智能音箱、耳机、智能家居设备以及机器人等多个领域。

更多推荐