LCD控制器的使用,从几个寄存器上面可以充分的体现出来。第一来看几个图:

image

这个是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显示。

路过的可以贴代码上来。。。

posted on 2010-04-09 09:59  灰太狼大王  阅读(1105)  评论(0编辑  收藏  举报