STM32F103ZET6:CubeMX配置FSMC接口驱动SSD1963-7寸 TFTLCD

news/2024/11/7 21:05:33/

配置方法

FSMC接口驱动SSD1963-7寸 TFTLCD
芯片:STM32F103ZET6
引脚:
LCD_RS----PF0(FSMC_A0)
LCD_CS----PG12(FSMC_NE4)
LCD_WR----PD5(FSMC_NWE)
LCD_RD----PD4(FSMC_NOE)
时钟:系统时钟配置为72M
操作:通过杜邦线将液晶屏连接到LCD接口上
CubeMX(版本5.2.1)的配置界面:
引脚分布图
FSMC的具体配置

原理说明

主要讲解下FSMC的具体配置,使用异步模式 A(ModeA)方式来控制 TFTLCD。因为模式 A 支持独立的读写时序控制,这个对我们驱动 TFTLCD 来说非常有用,因为 TFTLCD在读的时候,一般比较慢,而在写的时候可以比较快,如果读写用一样的时序,那么只能以读的时序为基准,从而导致写的速度变慢。而如果有独立的读写时序控制,那么我们只要初始化的时候配置好,之后就不用再配置,既可以满足速度要求,又不需要频繁改配置。
LCD初始化程序可以直接调用原子哥的程序,便可以成功驱动TFTLCD,效果如下图。
调用原子哥LCD初始化程序时,需要注意地址线的使用,原子哥使用的是A10,本文使用的是A0,所以需要以下修改


//地址
#define LCD_REG (volatile uint16_t *)(0x6c000000)
#define LCD_RAM (volatile uint16_t *)(0x6c000002)/*写寄存器函数*/
void LCD_WR_REG(uint16_t command)
{*LCD_REG = command;
}/*写LCD数据函数*/
void LCD_WR_DATA(uint16_t data)
{*LCD_RAM = data ;
}
/*读LCD数据函数*/
uint16_t LCD_RD_DATA(void)
{volatile uint16_t data;data = *LCD_RAM;return data;
}/*特定寄存器写入特定数据*/
void LCD_WriteReg(uint16_t LCD_Reg,uint16_t LCD_RegValue)
{	*LCD_REG = LCD_Reg;		  *LCD_RAM = LCD_RegValue;    		 
}	  /*读寄存器*/
uint16_t LCD_ReadReg(uint16_t LCD_Reg)
{										   LCD_WR_REG(LCD_Reg);		delay_us(5);		  return LCD_RD_DATA();		
}   //开始写GRAM
void LCD_WriteRAM_Prepare(void)
{*LCD_REG=lcddev.wramcmd;	  
}	//LCD写GRAM
void LCD_WriteRAM(uint16_t RGB_Code)
{							    *LCD_RAM = RGB_Code;
}

主程序

/* USER CODE END 0 *//*** @brief  The application entry point.* @retval int*/
int main(void)
{/* USER CODE BEGIN 1 *//* USER CODE END 1 *//* MCU Configuration--------------------------------------------------------*//* Reset of all peripherals, Initializes the Flash interface and the Systick. */HAL_Init();/* USER CODE BEGIN Init *//* USER CODE END Init *//* Configure the system clock */SystemClock_Config();/* USER CODE BEGIN SysInit *//* USER CODE END SysInit *//* Initialize all configured peripherals */MX_GPIO_Init();MX_FSMC_Init();MX_USART1_UART_Init();/* USER CODE BEGIN 2 */delay_init();	    	 //ÑÓʱº¯Êý³õʼ»¯	  LCD_Init();	/* USER CODE END 2 *//* Infinite loop *//* USER CODE BEGIN WHILE */while (1){/* USER CODE END WHILE *//* USER CODE BEGIN 3 */POINT_COLOR=RED;//ÉèÖÃ×ÖÌåΪºìÉ« LCD_ShowString(60,50,200,16,16,"WarShip STM32");	LCD_ShowString(60,70,200,16,16,"TOUCH TEST");	LCD_ShowString(60,90,200,16,16,"ATOM@ALIENTEK");LCD_ShowString(60,110,200,16,16,"2019/11/05");LCD_ShowString(60,130,200,16,16,"Press KEY0 to Adjust");	}/* USER CODE END 3 */
}

成功驱动的效果图如下:
LCD可以成功驱动起来
本人博客经验尚浅,不足之处请指出,对大家有点帮助的话请鼓励,希望本人分享cubemx哪方面的配置请留言呦!
————————————————
版权声明:本文为CSDN博主「DHZFSYJ」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/DHZFSYJ/article/details/101294215


http://www.ppmy.cn/news/601474.html

相关文章

STM32的DMA

文章目录 DMA介绍F407的DMA有多少数据流与通道?F407的DMA如何判定DMA请求的优先级? DMA框图F407的DMA源和目的的可选项?F407DMA的主要特性源与目的的方向配置DMA必要性仲裁器F407每个数据流对应请求映射 DMA结构DMA相关寄存器DMA 中断状态寄存…

STM32之DMA

DMA介绍 DMA(Direct MemoryAccess,直接存储器访问)提供在外设与内存、存储器和存储器、外设与外设之间的高速数据传输使用。它允许不同速度的硬件装置来沟通,而不需要依赖于CPU,在这个时间中,CPU对于内存的工作来说就无法使用。 D…

STM32—DMA

什么是DMA? DMA(Direct Memory Access,直接存储器访问) 提供在外设与内存、存储器和存储器、外设与外设之间的高速数据传输使用。它允许不同速度的硬件装置来沟通,而不需要依赖于CPU,在这个时间中,CPU对于内存的工作来…

STM32F103——DMA

DMA的基本介绍 DMA,全称Direct Memory Access,即直接存储器访问。 DMA传输:在没有CPU的任何干预下,将数据从一个地址空间复制到另一个地址空间,提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。 我们知道…

DMA-STM32

DMA-STM32 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设和存储器或者存储器和存储器之间的高速数据传输,无须CPU干预,节省了CPU的资源 12个独立可配置的通道:DMA1 (7个通道),DMA2 (5个通道) 每个通道都支持软件触发和特定的硬件触发 STM32…

MIMX8MD6CVAHZAB I.MX 8MDUAL Cortex-A53 - 微处理器

概述 NXP i.MX 8M应用处理器采用Arm Cortex-A53和Cortex-M4内核,设计用于满足智能设备应用的丰富用户体验要求。i.MX 8M提供业界领先的多媒体处理功能,采用多达四个1.5GHz Arm Cortex-A53和Cortex-M4内核。另外,该器件还具有各种灵活的存储器…

基于STM32F103C8T6的DMA直接存储器存取

#一、DMA简介 #二、STM32存储器映像 #三、DMA基本结构 #四、项目代码 一、DMA简介 DMA(Direct Memory Access)直接存储器存储DMA可以提供外设和存储器或者存储器和存储器之间的高速数据传输,无须CPU干预,节省CPU的资源12个独立可配置的通道&#xff1a…

复旦微FM33LE0x单片机之串口DMA接收

一、简介 本例程以FM33LE026为例,已经过验证,其他型号不保证适用。   FM33LE0xx集成了多种不同类型的UART(LPUART),其差异如下表所示: UART特性UART0/1UART2UART4/5LPUART0/1DMA支持YYYY半双工/全双工YY…