LTDC_DMA2D驱动实验

STM32F429芯片使用LTDC、DMA2D、及RAM存储器,构成了一个完整的液晶控制器。LTDC负责不断刷新液晶屏(将数据从显存搬运到液晶屏),DMA2D用于图像数据搬运、混合及格式转换(将数据搬运到显存),RAM存储器作为显存。

一、LTDC初始化结构体

1)、设置行同步信号HSYNC的极性,即HSYNC有效时的电平。

2)、设置垂直同步信号CSYNC的极性

3)、设置数据使能信号DE的极性

4)、设置像素时钟信号CLK的极性,可设置为上升沿,或下降沿,表示RGB数据信号在CLK的哪个时刻被采集

5)、设置行同步信号的的宽度——HSW-1

6)、设置垂直同步信号的的宽度——VSW-1

7)、HSW+HBP-1的值

8)、VSW+VBP-1的值

9)、HSW+HBP+有效宽度-1的值

10)、VSW+VBP+有效高度-1的值

11)、HSW+HBP+有效宽度+HFP-1的值

12)、VSW+VBP+有效高度+VFP-1的值

13)、配置背景的红色值

14)、配置背景的绿色值

15)、配置背景的蓝色值

LTDC初始化结构体配置好了与液晶屏通信的基本时序,还有像素格式、显示地址等诸多参数需要使用LTDC层级初始化结构体完成。

二、LTDC层级初始化结构体

1)、确定该层显示窗口的边界

2)、设置该层数据的像素格式

3)、设置该层恒定的透明度常量Alpha(LTDC_ConstantAlpha)

4)、配置该层的默认颜色值,分别为蓝色、绿色、红色分量及透明度分量

5)、设置混合系数BF1和BF2。每一层实际显示的颜色都需要使用透明度参与运算,计算出不包含透明度的直接RGB颜色值,然后才传输给液晶屏(因为液晶屏本身没有透明度的概念)

计算公式为  BC=BF1*C + BF2*Cs

本结构成员可以设置BF1/BF2参数是使用CA配置还是PA*CA配置。配置成CA表示混合系数中只包含恒定的Alpha值,即像素本身的Alpha不会影响混合效果;若配置成PA*CA,则混合系数中包含像素本身的Alpha值,即把像素本身的Alpha加入混合运算中,其中的恒定Alpha值即透明度百分比(配置的Alpha值/0xFF)

BC=恒定Alpha*C + (1-恒定Alpha)*Cs 

6)、设置该层的显存首地址

7)、设置当前层的行数据长度(行有效像素个数*每个像素的字节数 + 3)

8)、设置从某行的有效像素起始位置到下一行起始位置出的数据增量

9)、设置当前层的显示行数

将这些配置写入LTDC的层级控制寄存器中,完成初始化。初始化完成后,LTDC会不断把显存空间的数据传输到液晶屏进行显示,可以直接修改或使用DMA2D修改显存中的数据,从而改变显示的内容。

三、DMA2D初始化结构体

1)、配置DMA2D的传输模式

2)、配置输出PFC(像素格式转换器)的颜色格式,即它将要传输给显存的格式

3)、配置DMA2D的寄存器颜色值(蓝色、绿色、红色分量及透明度分量)

4)、配置输出FIFO的地址,DMA2D的数据会被搬运到该空间,一般把它设置为本次传输显示位置的起始地址

5)、配置行偏移量(以像素为单位),行偏移量会被添加到各行的结尾,用于确定下一行的 起始地址。

行偏移量的值=行宽度-线的宽度

6)、配置DMA2D一共要传输多少行数据

7)、配置每行有多少个像素点

配置完将这些参数写入DMA2D的控制寄存器,然后再调用DMA2D_StartTransfer函数开启数据传输及转换。

 

液晶显示实验编程要点

1)、初始化LCD驱动的引脚

2)、使用LTDC初始化结构体,配置液晶屏的控制参数

3)、使用LTDC的层级初始化结构体,配置各层的控制参数

4)、直接操控显存,控制液晶屏显示图形

5)、使用DMA2D快速绘制直线及矩形

 

posted @ 2020-11-28 22:52  cswft  Views(404)  Comments(0Edit  收藏  举报