touchGFX综合学习十四、基于cubeMX、正点原子H750开发版、RGB4.3寸屏移植touchGFX完整教程+工程(二)

本文主要是介绍touchGFX综合学习十四、基于cubeMX、正点原子H750开发版、RGB4.3寸屏移植touchGFX完整教程+工程(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、软件安装及CubeMX配置

请参考我这篇博文:touchGFX综合学习十三、基于cubeMX、正点原子H750开发版、RGB4.3寸屏移植touchGFX完整教程+工程(一)

二、touchGFX Designer生成代码

打开上一篇生成工程目录
在这里插入图片描述
双击打开
添加一个BOX控件并且充满屏幕,颜色改为红色
在这里插入图片描述
点击生成
在这里插入图片描述
如果生成失败,多生成几次
在这里插入图片描述

三、代码修改

1、SDRAM部分修改

SDRAM需要初始化相关参数,所以要加入SDRAM初始化部分
在这里插入图片描述
函数部分
在这里插入图片描述

u8 SDRAM_Send_Cmd(u8 bankx,u8 cmd,u8 refresh,u16 regval)
{u32 target_bank=0;FMC_SDRAM_CommandTypeDef Command;if(bankx==0) target_bank=FMC_SDRAM_CMD_TARGET_BANK1;       else if(bankx==1) target_bank=FMC_SDRAM_CMD_TARGET_BANK2;   Command.CommandMode=cmd;                //命令Command.CommandTarget=target_bank;      //目标SDRAM存储区域Command.AutoRefreshNumber=refresh;      //自刷新次数Command.ModeRegisterDefinition=regval;  //要写入模式寄存器的值if(HAL_SDRAM_SendCommand(&hsdram1,&Command,0XFFFF)==HAL_OK) //向SDRAM发送命令{return 0;  }else return 1;    
}
void SDRAM_Initialization_Sequence(SDRAM_HandleTypeDef *hsdram)
{u32 temp=0;//SDRAM控制器初始化完成以后还需要按照如下顺序初始化SDRAMSDRAM_Send_Cmd(0,FMC_SDRAM_CMD_CLK_ENABLE,1,0); //时钟配置使能HAL_Delay(1);                                  //至少延时200usSDRAM_Send_Cmd(0,FMC_SDRAM_CMD_PALL,1,0);       //对所有存储区预充电SDRAM_Send_Cmd(0,FMC_SDRAM_CMD_AUTOREFRESH_MODE,8,0);//设置自刷新次数 //配置模式寄存器,SDRAM的bit0~bit2为指定突发访问的长度,//bit3为指定突发访问的类型,bit4~bit6为CAS值,bit7和bit8为运行模式//bit9为指定的写突发模式,bit10和bit11位保留位temp=(u32)SDRAM_MODEREG_BURST_LENGTH_4          |	//设置突发长度:1(可以是1/2/4/8)SDRAM_MODEREG_BURST_TYPE_SEQUENTIAL   |	//设置突发类型:连续(可以是连续/交错)SDRAM_MODEREG_CAS_LATENCY_2           |	//设置CAS值:2(可以是2/3)SDRAM_MODEREG_OPERATING_MODE_STANDARD |   //设置操作模式:0,标准模式SDRAM_MODEREG_WRITEBURST_MODE_SINGLE;     //设置突发写模式:1,单点访问SDRAM_Send_Cmd(0,FMC_SDRAM_CMD_LOAD_MODE,1,temp);   //设置SDRAM的模式寄存器//刷新频率计数器(以SDCLK频率计数),计算方法://COUNT=SDRAM刷新周期/行数-20=SDRAM刷新周期(us)*SDCLK频率(Mhz)/行数//我们使用的SDRAM刷新周期为64ms,SDCLK=200/2=100Mhz,行数为8192(2^13).//所以,COUNT=64*1000*100/8192-20=677HAL_SDRAM_ProgramRefreshRate(&hsdram1,677);	
}	
/* USER CODE END 0 */

四、工程烧录验证

使用keil编译工程烧录进开发版,查看屏幕显示:显示一片红色为正常
在这里插入图片描述

五、添加触摸

下载H750正点原子开发版资料

1、添加文件

Drivers文件夹下新建Bsp文件夹,将正点原子资料里面的TOUCH文件夹拷贝进来,用keil5打开工程将ctiic.c和gt9147.c添加到工程,并添加头文件支持。
在这里插入图片描述
Drivers文件夹下新建Sys文件夹,将正点原子资料里面的delay和sys文件夹拷贝进来,用keil5打开工程将delay.c和sys.c添加到工程,并添加头文件支持。
在这里插入图片描述

2、代码修改

1、修改添加进来的所有头文件,添加c++支持

举个例子
在这里插入图片描述
主要是添加

#ifdef __cplusplus
extern "C"
{
#endif
...........
省略
...........#ifdef __cplusplus
}
#endif

记得所有添加进来的文件都要修改哦

2、修改delay_us函数

在这里插入图片描述

//注意:nus的值不要大于1000us
void delay_us(u32 nus)
{		
//	u32 ticks;
//	u32 told,tnow,tcnt=0;
//	u32 reload=SysTick->LOAD;				//LOAD的值	    	 
//	ticks=nus*fac_us; 						//需要的节拍数 
//	told=SysTick->VAL;        				//刚进入时的计数器值
//	while(1)
//	{
//		tnow=SysTick->VAL;	
//		if(tnow!=told)
//		{	    
//			if(tnow<told)tcnt+=told-tnow;	//这里注意一下SYSTICK是一个递减的计数器就可以了.
//			else tcnt+=reload-tnow+told;	    
//			told=tnow;
//			if(tcnt>=ticks)break;			//时间超过/等于要延迟的时间,则退出.
//		}  
//	};u8 i=10*nus;while(i--);
}
//延时nms
//nms:要延时的ms数
void delay_ms(u16 nms)
{u32 i;for(i=0;i<nms;i++) delay_us(1000);
}

3、修改ctiic.c文件

在这里插入图片描述

4、修改GT9147_Init函数,并将GT9147_Scan函数删除

在这里插入图片描述

u8 GT9147_Init(void)
{u8 temp[5]; GPIO_InitTypeDef GPIO_Initure;__HAL_RCC_GPIOH_CLK_ENABLE();			//开启GPIOH时钟__HAL_RCC_GPIOI_CLK_ENABLE();			//开启GPIOI时钟//PH7GPIO_Initure.Pin=GPIO_PIN_7;            //PH7GPIO_Initure.Mode=GPIO_MODE_INPUT;      //输入GPIO_Initure.Pull=GPIO_PULLUP;          //上拉GPIO_Initure.Speed=GPIO_SPEED_FREQ_VERY_HIGH;     //高速HAL_GPIO_Init(GPIOH,&GPIO_Initure);     //初始化//PI8GPIO_Initure.Pin=GPIO_PIN_8;            //PI8GPIO_Initure.Mode=GPIO_MODE_OUTPUT_PP;  //推挽输出HAL_GPIO_Init(GPIOI,&GPIO_Initure);     //初始化CT_IIC_Init();      	//初始化电容屏的I2C总线  GT_RST(0);				//复位delay_ms(10);GT_RST(1);				//释放复位		    delay_ms(10); GPIO_Initure.Pin=GPIO_PIN_7;            //PH7GPIO_Initure.Mode=GPIO_MODE_INPUT;      //输入GPIO_Initure.Pull=GPIO_PULLUP;          //不带上下拉,浮空输入GPIO_Initure.Speed=GPIO_SPEED_FREQ_VERY_HIGH;     //高速HAL_GPIO_Init(GPIOH,&GPIO_Initure);     //初始化delay_ms(100);  GT9147_RD_Reg(GT_PID_REG,temp,4);//读取产品IDtemp[4]=0;
//	printf("CTP ID:%s\r\n",temp);	//打印IDreturn 0;
}

5、修改touchGFX代码添加触摸支持

打开STM32TouchController.cpp文件
添加头文件
在这里插入图片描述
修改void STM32TouchController::init()函数添加触摸初始化

在这里插入图片描述
修改bool STM32TouchController::sampleTouch(int32_t& x, int32_t& y)函数添加扫描触摸
在这里插入图片描述

bool STM32TouchController::sampleTouch(int32_t& x, int32_t& y)
{/*** By default sampleTouch returns false,* return true if a touch has been detected, otherwise false.** Coordinates are passed to the caller by reference by x and y.** This function is called by the TouchGFX framework.* By default sampleTouch is called every tick, this can be adjusted by HAL::setTouchSampleRate(int8_t);**/uint8_t mode,temp;uint8_t buf[4];GT9147_RD_Reg(GT_GSTID_REG,&mode,1);	//读取触摸点的状态  if(mode&0X80&&((mode&0XF)<6)){temp=0;GT9147_WR_Reg(GT_GSTID_REG,&temp,1);//清标志 		}if((mode&0XF)&&((mode&0XF)<6)){GT9147_RD_Reg(GT_TP1_REG,buf,4);	//读取XY坐标值x = ((u16)(buf[1]&0x0f)<<8)+buf[0];y = ((u16)(buf[3]&0x0f)<<8)+buf[2];return true;}return false;
}

6、优化touchGFX动画显示效果

打开TouchGFXHAL.cpp文件
在这里插入图片描述

void TouchGFXHAL::initialize()
{// Calling parent implementation of initialize().//// To overwrite the generated implementation, omit call to parent function// and implemented needed functionality here.// Please note, HAL::initialize() must be called to initialize the framework.TouchGFXGeneratedHAL::initialize();uint32_t frameSize = DISPLAY_HEIGHT*DISPLAY_WIDTH*3;setFrameBufferStartAddresses((void *)(0xC0000000),(void *)(0xC0000000+frameSize),(void *)(0xC0000000+frameSize*2));setFrameRateCompensation(true);}

六、触摸验证

界面添加一个按钮,然后点击生成工程
在这里插入图片描述
keil5编译源码下载到开发版,点击按钮查看有没有按下效果

七、完整工程下载

点击下载完整工程

这篇关于touchGFX综合学习十四、基于cubeMX、正点原子H750开发版、RGB4.3寸屏移植touchGFX完整教程+工程(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/340877

相关文章

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

SpringBoot连接Redis集群教程

《SpringBoot连接Redis集群教程》:本文主要介绍SpringBoot连接Redis集群教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 依赖2. 修改配置文件3. 创建RedisClusterConfig4. 测试总结1. 依赖 <de

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF