LCD控制器的使用,从几个寄存器上面可以充分的体现出来。第一来看几个图:
这个是LCD工作时的时序图。
上半部分是垂直同步码的时序。这里衡量单位是以多少个行脉冲为单位。可以看出来一帧 = VSYNC的一个周期。也就是说帧周期和垂直同步码的周期是一样的。
Frame Rate = 1/ [ { (VSPW+1) + (VBPD+1) + (LIINEVAL + 1) + (VFPD+1) } * {(HSPW+1) + (HBPD +1)
+ (HFPD+1) + (HOZVAL + 1) } *{ 2 *( CLKVAL+1 ) / ( HCLK ) } ]
VSPW = 垂直同步信号宽度(以行脉冲来量)
VBPD = 帧开始之前,垂直同步之后,这期间有多少个行脉冲
VFPD = 帧结束后,下一个垂直同步之前,这期间的行脉冲个数。
LINEVAL+1 :一帧所行的行脉冲数。
HFPD:有效数据结束后和行脉冲上升沿之间VCLK的个数。
HOZVAL = 一行中的VCLK的个数。
HBPD =行同步码的下降延和有效数据开始之前期间的VCLK的个数。
2*(CLKVAL+1)/HCLK是VCLK的周期。
这张图之后就很容易理解各个寄存器的设置了。从LCDCON1-LCDCON5。有几个比较重要的设置:
LCDCON1:LINECNT:是一个只读数据,显示行扫描计数。
LCDCON2:LINEVAL :设置LCD的行个数。
LCDCON3:HOZVAL:设置列的个数。
LCDCON5中有较多的设置信息。
VSTATUS:垂直信号的状态。
HSTATUS:水平信号状态。
BPP24BL:24色视频缓存在字中的顺序:前24还是后24字节有效。
FRM65:16色情况下RGB的分配.5:5:5:1还是5:6:5.
INV开头的都极性的设置。可以选取默认。
PWREN 和ENLEND是使能LCD_PWREN,和LEND输出
BSWP。byte swap .
HWSWAP:half –word swap.
下面的几个寄存器就是控制显示的关键。
LCDADDR1:LCDBANK: 四字节对齐的一个地址。是视频缓存地址的[30:22]位。
LCDADDR1:LCDBASEU:LCD显示面板的起始地址的A[21:1]位。就是起始地址的【21:1】位。
LCDADDR2:LCDBASEL:LCD显示面板的末地址。
LCDBASEL = ((the fame end address) >>1) + 1
= LCDBASEU +
(PAGEWIDTH+OFFSIZE)x(LINEVAL+1)
LCDSADDR3:OFFSIZE:前一行末尾和新一行开始之间的点的个数。用半字作为单位。注意这里如果是16色的,那么一个像素就看成16个点。8色的就看成8个点。
PAGEWIDTH:这里同样是用半字来衡量的。一页中包含点的个数。
TPAL寄存器。临时调色板:当用户要用一个颜色填满整个帧的话,使用临时调试板。将器使能。然后在临时调色板里面写颜色就可以。
LCDINTPND:中断寄存器。
LCDINTPND:INT_FrSyn:LCD中断寄存器。
LCDINTPND:INT_FiCnt:LCDFIFO中断寄存器
LCDSRCPND:中断源未决寄存器。和中断寄存器对应。
LCDINTMASK:中断屏蔽寄存器。和上面对应。
640*480TFT基本上使用这些寄存器就差不多。
下面是自己在使用过程中的一些代码:
像素着色
输出字符
这里的输出字符因为怕太小。所以两倍大小输出。不过放大字体应该不是这样。。。
需要改进的就是可以多写点绘图的API、字模提取、显示汉字、JPEG,BMP显示。
路过的可以贴代码上来。。。