LCD 深度剖析

来源:http://blog.csdn.net/hardy_2009/article/details/6922900

http://blog.csdn.net/jaylondon/article/details/6363741

http://blog.csdn.net/zhaocj/article/details/5397180

http://www.cnblogs.com/stardream/articles/1758303.html

LCD背景知识:

TFT(Thin Film Transistor)即薄膜场效应晶体管

1. LCD工作的硬件需求:

要使一块LCD正常的显示文字或图像,不仅须要LCD驱动器,并且还须要对应的LCD控制器。在通常情况下,生产厂商把LCD驱动器会以COF/COG的形式与LCD玻璃基板制作在一起,而LCD控制器则是由外部的电路来实现,如今非常多的MCU内部都集成了LCD控制器,如S3C2410/2440等。通过LCD控制器就能够产生LCD驱动器所须要的控制信号来控制STN/TFT屏了。也就说,LCD控制驱动器一般都是由厂家做好的,我们仅仅须要商家提供我们VBPD,VFPD,VSPW,HBPD,HFPD,HSPW,这些參数就可以。

S3C2440LCD控制器结构图:

a:LCD控制器由REGBANK、LCDCDMA、TIMEGEN、VIDPRCS寄存器组成;

b:REGBANK由17个可编程的寄存器组和一块256*16的调色板内存组成,它们用来配置LCD控制器的;

c:LCDCDMA是一个专用的DMA,它能自己主动地把在侦内存中的视频数据传送到LCD驱动器,通过使用这个DMA通道,视频数据在不须要CPU的干预的情况下显示在LCD屏上;

d:VIDPRCS接收来自LCDCDMA的数据,将数据转换为合适的数据格式,比方说4/8位单扫,4位双扫显示模式,然后通过数据portVD[23:0]传送视频数据到LCD驱动器;

e:TIMEGEN由可编程的逻辑组成,他生成LCD驱动器须要的控制信号,比方VSYNC、HSYNC、VCLK和LEND等等,而这些控制信号又与REGBANK寄存器组中的LCDCON1/2/3/4/5的配置密切相关,通过不同的配置,TIMEGEN就能产生这些信号的不同形态,从而支持不同的LCD驱动器(即不同的STN/TFT屏)。

3  lcd型号             我的是索尼3.5寸TFT液晶屏

3.1 LCD液晶屏与触摸屏的区分

首先要区分这俩个,非常多买的液晶屏都带了触摸屏,可是就仅仅有一块屏,我一開始一直没有分清楚这俩个屏,其实这里有俩个屏,是分开的,独立的,我做触 摸屏的实验的时候我一開始就不明确这个屏亮都不亮(就是lcd没有驱动)能够驱动触摸屏吗,其实是能够的,他们的接口是分开的,触摸屏是和AD放在一起的,主要是由于触摸屏的实现主要运用AD计算位置。

MINI2440 索尼X36屏是TFT屏,TFT屏支持16BPp或者24Bpp(须要设置选择,例如以下图所看到的),  尺寸大小:240*320

对于16bpp就是每一位像素16位,这样就能够用5,6,5 或者5,5,5,1 分别表示红绿蓝占的位数,后面的1就用来表示透 明度,内存布局例如以下图所看到的。

24bpp的话就红绿蓝各占8位,这样一来使用不同的搭配就能够表示各种颜色了,内存布局如图所看到的

,可是对于8bpp来说使用8位,红绿蓝使用不到3位来表示,这样颜色表示的不丰富并且显示能力太弱,这样就引入了调色板,调试板事实上是一块内存,

3.2 时序,帧频率,行频率,像素时钟

VSYNC/VFRAME/STV:垂直同步信号(TFT)/帧同步信号(STN)/SEC TFT信号;

HSYNC/VLINE/CPV:水平同步信号(TFT)/行同步脉冲信号(STN)/SEC TFT信号;

VCLK/LCD_HCLK:象素时钟信号(TFT/STN)/SEC TFT信号;

VD[23:0]:LCD像素数据输出port(TFT/STN/SEC TFT);

VDEN/VM/TP:数据使能信号(TFT)/LCD驱动交流偏置信号(STN)/SEC TFT 信号;

LEND/STH:行结束信号(TFT)/SEC TFT信号;

LCD一般须要三个时序信号:VSYNC、HSYNC和VCLK。VSYNC是垂直同步信号(帧同步信号),在每进行一个帧(即一个屏)的扫描之前,该信号就有效一次,由该信号能够确定LCD的场频,即每秒屏幕刷新的次数(单位Hz)。HSYNC是水平同步信号(行同步信号),在每进行一行的扫描之前,该信号就有效一次,由该信号能够确定LCD的行频,即每秒屏幕从左到右扫描一行的次数(单位Hz)。VCLK是像素时钟信号。

s3c2440处理LCD的时钟源是HCLK,通过寄存器LCDCON1中的CLKVAL能够调整VCLK频率大小,它的公式为:

VCLK=HCLK÷[(CLKVAL+1)×2]

比如,HCLK的频率为100MHz,要想驱动像素时钟信号为6.4MHz的LCD屏,则通过上式计算CLKVAL值,结果CLKVAL为6.8,取整后(值为6)放入寄存器LCDCON1中对应的位置就可以。因为CLKVAL进行了取整,因此我们把取整后的值代入上式,又一次计算VCLK,得到VCLK=7.1MHz。

VBPD,VFPD,VSPW,HBPD,HFPD,HSPW參数意义:

VBPD(vertical back porch):表示在一帧图像開始时,垂直同步信号以后的无效的行数

VFPD(vertical front porch):表示在一帧图像结束后,垂直同步信号曾经的无效的行数

VSPW(vertical sync pulse width):表示垂直同步脉冲的宽度,用行数计算

HBPD(horizontal back porch):表示从水平同步信号開始到一行的有效数据開始之间的VCLK的个数

HFPD(horizontal front porth):表示一行的有效数据结束到下一个水平同步信号開始之间的VCLK的个数

HSPW(horizontal sync pulse width):表示水平同步信号的宽度

按理说,对于一个已知尺寸(即水平显示尺寸HOZVAL和垂直显示尺寸LINEVAL已知)的LCD屏,仅仅要确定了VCLK值,行频和场频就应该知道了。但这样还不行的,由于在每一帧时钟信号中,还会有一些与屏显示无关的时钟出现,这就给确定行频和场频带来了一定的复杂性。如在HSYNC信号先后会有水平同步信号前肩(HFPD)和水平同步信号后肩(HBPD)出现,在VSYNC信号先后会有垂直同步信号前肩(VFPD)和垂直同步信号后肩(VBPD)出现,在这些信号时序内,不会有有效像素信号出现,另外HSYNC和VSYNC信号有效时,其电平要保持一定的时间,它们分别叫做水平同步信号脉宽HSPW和垂直同步信号脉宽VSPW,这段时间也不能有像素信号。因此计算行频和场频时,一定要包含这些信号。HBPD、HFPD和HSPW的单位是一个VCLK的时间,而VSPW、VFPD和VBPD的单位是扫描一行所用的时间。在s3c2440中,全部的这些信号(VSPW、VFPD、VBPD、LINEVAL、HBPD、HFPD、HSPW和HOZVAL)都是实际值减1的结果。这些值是通过寄存器LCDCON2、LCDCON3和LCDCON4来配置,仅仅要把这些值配置成与所要驱动的LCD中相关内容的数据一致就可以。比如,我们所要显示的LCD屏大小为320×240,因此HOZVAL=320-1,LINEVAL=240-1。水平同步信号的脉宽、前肩和后肩分别为30、20和38,则HSPW=30-1,HFPD=20-1,HBPD=38-1;垂直同步信号的脉宽、前肩和后肩分别为3、12和15,则VSPW=3-1,VFPD=12-1,VBPD=15-1。

这些參数用于配置LCD驱动控制器,由厂商设置提供;

对于MINI2440 X35LCD屏參考參例如以下:

VBPD =  0,VFPD =4,VSPW=8,HBPD=25,HFPD=0,HSPW=4

寄存器配置说明:

LCDCON1:17 - 8位CLKVAL

          6 - 5位扫描模式(对于STN屏:4位单/双扫、8位单扫)

          4 - 1位色位模式(1BPP、8BPP、16BPP等)

LCDCON2:31 - 24位VBPD

         23 - 14位LINEVAL

         13 - 6位VFPD

          5 - 0位VSPW

LCDCON3:25 - 19位HBPD

         18 - 8位HOZVAL

          7 - 0位HFPD

LCDCON4: 7 - 0位HSPW

LCDCON5:

来源:http://blog.csdn.net/jaylondon/article/details/6363741

举例说明:X35 LCD寄存器配置參数:

rLCDCON1 = (6<<8) | (3<<5) | \

                  (12<<1) | (0<<0);

        rLCDCON2 = (0<<24) | (319<<14) | \

                  (4<<6) | (8);

        rLCDCON3 = (25<<19) | (239<<8) | (0);

        rLCDCON4 = 4;

        rLCDCON5 = (1<<11) | (1<<9) | (1<<8) | (1<<6) |\

                  (0<<1)|(1);

4.3寸屏16Bpp  480*272

/*1.[17:8]=6  VCLK

        [7]   =0  each frame

        [6:5] =3  tft lcd panel

        [4:1]=12  16pp fot tft

    */

    rLCDCON1=(CLKVAL_TFT_320240<<8)|(0<<7)|(3<<5)|(12<<1)|0;



    /*  rLCDCON1 设置

     *     改动时间:2014/5/17

     * 设置VCLK时钟,[17:8]=6  VCLK = HCLK / [(CLKVAL + 1) × 2],此时HCLK为135M,VCLK为9M,CLKVAL = 6

     * 设置屏的类型,[6:5] =3  TFT

     * 设置bpp模式, [4:1]=12  16pp fot tft

     * 设置ENVID     [0]=0     LCD 视频输出和逻辑使能/禁止

     */

    rLCDCON1 = (6<<8)|(3<<5)|(12<<1)|0;





    /*2.[31:24]=15 (VBPD-垂直同步信号的后肩)

        [23:14]=271(272-1:行数)

        [13:6] =12  (VFPD-垂直同步信号的前肩)

        [5:0]=3  (VSPW-垂直同步信号的脉宽)

    */

    //rLCDCON2=(LTV350QV_VBPD<<24)|(LINEVAL_TFT<<14)|(LTV350QV_VFPD<<6)|(LTV350QV_VSPW);

    /*  rLCDCON2 设置

     *     改动时间:2014/5/17

     * 设置VBPD,        [31:24]=XX    VBPD(vertical back porch)表示在一帧图像開始时,垂直同步信号以后的无效的行数,垂直同步信号的后肩

     * 设置屏的LINEVAL,[23:14] =(272-1)=271  此位决定了LCD 面板的垂直尺寸(LINEVAL+1=LCD的垂直高度)LINEVAL = (垂直显示大小) - 1

     * 设置VFPD            [13:6]=XX     VFBD(vertical front porch)表示在一帧图像结束后,垂直同步信号曾经的无效的行数,垂直同步信号的前肩

     * 设置VSPW            [5:0]=XX      VSPW(vertical sync pulse width)表示垂直同步脉冲的宽度,垂直同步信号的脉宽

     */

    //rLCDCON2=(40<<24)|(271<<14)|(30<<6)|3;

      rLCDCON2 =(10<<24)|(271<<14)|(1990<<6)|3;

    /*3 [25:19]=38(HBPD-水平同步信号的后肩)

      [18:9] =479(480-1:列数)

      [7:0]  =20(HFPD-水平同步信号的前肩)

    */

    //rLCDCON3=(LTV350QV_HBPD<<19)|(HOZVAL_TFT<<8)|(LTV350QV_HFPD);

    /*  rLCDCON3 设置

     *     改动时间:2014/5/17

     * 设置HBPD,        [25:19]=XX    HBPD(horizontal back porch)表示从水平同步信号開始到一行的有效数据開始之间的VCLK的个数,水平同步信号的后肩

     * 设置屏的HOZVAL, [18:8] =(480-1)=479  此位决定了LCD 面板的水平尺寸(HOZVAL+1=LCD的垂直高度),HOZVAL = (水平显示大小) - 1

     * 设置HFPD            [7:0]=XX      VFBD(vertical front porch)表示在一帧图像结束后,垂直同步信号曾经的无效的行数,         垂直同步信号的前肩

     */

    rLCDCON3=(100<<19)|(479<<8)|1;

     //  rLCDCON3=(479<<8);

     /*4 [15:8]=0

      [7:0]=30(LTV350QV_HSPW:水平同步信号的脉宽)

     */

    //rLCDCON4=(MVAL<<8)|(LTV350QV_HSPW);

    /* rLCDCON4 设置

     * 设置MVAL         [15:8]=XX      STN此位定义假设MMODE 位被置位为逻辑’1’的VM 信号将要触发的频率

     * 设置HSPW         [7:0]=XX      HSPW(horizontal sync pulse width)表示水平同步信号的宽度  

     */

    rLCDCON4=15;





    /*5 [31:17] 保留0

     *  [16:15] 不须要设置,VSTATUS垂直状态(仅仅读)

     *  [14:13] 不须要设置,HSTATUS水平状态(仅仅读)

     *  [12]    此位决定24 bpp 视频存储器的顺序       1 = MSB 有效

     *  [11]    此位选择16 bpp 输出视频数据的格式    1 = 5:6:5 格式,0 = 5:5:5:1 格式    (必须选择)

     *  [10]    此位控制VCLK 有效沿的极性     1 = VCLK 上升沿取视频数据 0 = VCLK 下降沿取视频数据( 不影响)

     *  [9]        此位表明VLINE/HSYNC 脉冲极性  1 = 反转      0 = 正常       

     *  [8]        此位表明VFRAME/VSYNC 脉冲极性  1 = 反转      0 = 正常    

     *  [7]     此位表明VD(视频数据)脉冲极性  1 = 反转      0 = 正常    

     *  [6]     此位表明VDEN 信号极性     1 = 反转      0 = 正常          

     *  [5]     此位表明PWREN 信号极性     1 = 反转      0 = 正常    

     *  [4]        此位表明LEND 信号极性     1 = 反转      0 = 正常        

     *  [3]        此位表明TFT:LCD_PWREN 输出信号使能/禁止     1 = 同意     0 = 禁止        

     *  [2]        此位表明LEND 输出信号使能/禁止     1 = 同意      0 = 禁止    

     *  [1]BSWP 字节交换控制位         0 = 交换禁止 1 = 交换使能    

     *  [0]HWSWP 半字交换控制位        0 = 交换禁止 1 = 交换使能       

     */

    //rLCDCON5=(1<<11)|(1<<10)|(1<<9)|(1<<8)|(0<<6)|(BSWP<<1)|(HWSWP);

    rLCDCON5=(1<<11)|(0<<10)|(0<<9)|(0<<8)|(0<<7)|(0<<6)|(0<<5)|(1<<4)|(1<<3)|(1<<2)|(0<<1)|(1);

代码演示样例:

/**************************************************************
The initial and control for 320¡Á240 16Bpp TFT LCD----3.5´çÊúÆÁ
**************************************************************/ #include <string.h>
#include "def.h"
#include "2440addr.h"
#include "2440lib.h"
#include "LCD_LTV350QV_FOE.h" #define MVAL (13)
#define MVAL_USED (0) //0=each frame 1=rate by MVAL
#define INVVDEN (1) //0=normal 1=inverted
#define BSWP (0) //Byte swap control
#define HWSWP (1) //Half word swap control #define M5D(n) ((n) & 0x1fffff) // To get lower 21bits //TFT
#define LCD_XSIZE_TFT (240)
#define LCD_YSIZE_TFT (320)
#define SCR_XSIZE_TFT (240)
#define SCR_YSIZE_TFT (320)
#define HOZVAL_TFT (LCD_XSIZE_TFT-1)
#define LINEVAL_TFT (LCD_YSIZE_TFT-1) //FCLK=405MHz,HCLK=135MHz,VCLK=135/([6+1)*2]=9.6MHz
#define CLKVAL_TFT_320240 (6) #define LCD_BLANK 16
#define C_UP ( LCD_XSIZE_TFT - LCD_BLANK*2 )
#define C_RIGHT ( LCD_XSIZE_TFT - LCD_BLANK*2 )
#define V_BLACK ( ( LCD_YSIZE_TFT - LCD_BLANK*4 ) / 6 ) extern unsigned char image1[];
extern unsigned char image2[];
extern unsigned char image3[];
extern unsigned char image4[];
extern unsigned char image5[];
extern unsigned char image6[];
extern unsigned char image7[];
volatile static unsigned short LCD_BUFER[SCR_YSIZE_TFT][SCR_XSIZE_TFT]; #define WHITE 0xFFFF
#define BLACK 0x0000
#define BLUE 0x001F
#define BRED 0XF81F
#define GRED 0XFFE0
#define GBLUE 0X07FF
#define RED 0xF800
#define MAGENTA 0xF81F
#define GREEN 0x07E0
#define CYAN 0x7FFF
#define YELLOW 0xFFE0
#define BROWN 0XBC40 //×ØÉ«
#define BRRED 0XFC07 //×غìÉ«
#define GRAY 0X8430 //»ÒÉ« /**************************************************************
320¡Á240 16Bpp TFT LCDÊý¾ÝºÍ¿ØÖƶ˿ڳõʼ»¯
**************************************************************/
static void Lcd_Port_Init(void)
{
/*1.2440 IOÒý½ÅÅäÖà */ rGPCUP = 0xffffffff; //enable Pull-up register
rGPCCON = 0xaa9556a9; //Initialize VD[7:0],LCDVF[2:0],VM,VFRAME,VLINE,VCLK,LEND rGPDUP = 0xffffffff;
rGPDCON = 0xaaaaaaaa; Uart_Printf("\nLcd_Port_Init OK !\n");
} /**************************************************************
320¡Á240 16Bpp TFT LCD¹¦ÄÜÄ£¿é³õʼ»¯
**************************************************************/
static void Lcd_Init(void)
{
rLCDCON1 = (6<<8) | (3<<5) | \
(12<<1) | (0<<0);
rLCDCON2 = (0<<24) | (319<<14) | \
(4<<6) | (8);
rLCDCON3 = (25<<19) | (239<<8) | (0);
rLCDCON4 = 4;
rLCDCON5 = (1<<11) | (1<<9) | (1<<8) | (1<<6) |\
(0<<1)|(1); rLCDSADDR1=(((U32)LCD_BUFER>>22)<<21)|M5D((U32)LCD_BUFER>>1);
rLCDSADDR2=M5D((U32)LCD_BUFER>>1)+240*320;
rLCDSADDR3=240;
/* ÆÁ±ÎÖÐ¶Ï */
rLCDINTMSK|=(3);
/* ÆÁ±ÎÖÆLPC3600/LCC3600 ģʽ*/
rTCONSEL = 0;
/* È¡Ïûµ÷É«°å */
rTPAL=0;
}
/*
* ÉèÖÃÊÇ·ñÊä³öLCDµçÔ´¿ª¹ØÐźÅLCD_PWREN
* ÊäÈë²ÎÊý£º
* invpwren: 0 - LCD_PWRENÓÐЧʱΪÕý³£¼«ÐÔ
* 1 - LCD_PWRENÓÐЧʱΪ·´×ª¼«ÐÔ
* pwren: 0 - LCD_PWRENÊä³öÓÐЧ
* 1 - LCD_PWRENÊä³öÎÞЧ
*/
void Lcd_PowerEnable(int invpwren, int pwren)
{
rGPGCON = (rGPGCON & (~(3<<8))) | (3<<8); // GPG4ÓÃ×÷LCD_PWREN
rGPGUP = (rGPGUP & (~(1<<4))) | (1<<4); // ½ûÖ¹ÄÚ²¿ÉÏÀ­ rLCDCON5 = (rLCDCON5 & (~(1<<5))) | (invpwren<<5); // ÉèÖÃLCD_PWRENµÄ¼«ÐÔ: Õý³£/·´×ª
rLCDCON5 = (rLCDCON5 & (~(1<<3))) | (pwren<<3); // ÉèÖÃÊÇ·ñÊä³öLCD_PWREN
}
/**************************************************************
LCDÊÓƵºÍ¿ØÖÆÐźÅÊä³ö»òÕßÍ£Ö¹£¬1¿ªÆôÊÓƵÊä³ö
**************************************************************/
static void Lcd_EnvidOnOff(int onoff)
{
if(onoff==1)
rLCDCON1|=1; // ENVID=ON
else
rLCDCON1 =rLCDCON1 & 0x3fffe; // ENVID Off
}
/**************************************************************
320¡Á240 16Bpp TFT LCDµ¥¸öÏóËصÄÏÔʾÊý¾ÝÊä³ö
**************************************************************/
static void PutPixel(U32 x,U32 y,U32 c)
{
if ( (x < SCR_XSIZE_TFT) && (y < SCR_YSIZE_TFT) )
LCD_BUFER[(y)][(x)] = c;
} /**************************************************************
320¡Á240 16Bpp TFT LCDÈ«ÆÁÌî³äÌض¨ÑÕÉ«µ¥Ôª»òÇåÆÁ
**************************************************************/
static void Lcd_ClearScr(U16 c)
{
unsigned int x,y ; for( y = 0 ; y < SCR_YSIZE_TFT ; y++ )
{
for( x = 0 ; x < SCR_XSIZE_TFT ; x++ )
{
LCD_BUFER[y][x] = c;
}
}
} /**************************************************************
LCDÆÁÄ»ÏÔʾ´¹Ö±·­×ª
// LCD display is flipped vertically
// But, think the algorithm by mathematics point.
// 3I2
// 4 I 1
// --+-- <-8 octants mathematical cordinate
// 5 I 8
// 6I7
**************************************************************/
static void Glib_Line(int x1,int y1,int x2,int y2,int color)
{
int dx,dy,e;
dx=x2-x1;
dy=y2-y1; if(dx>=0)
{
if(dy >= 0) // dy>=0
{
if(dx>=dy) // 1/8 octant
{
e=dy-dx/2;
while(x1<=x2)
{
PutPixel(x1,y1,color);
if(e>0){y1+=1;e-=dx;}
x1+=1;
e+=dy;
}
}
else // 2/8 octant
{
e=dx-dy/2;
while(y1<=y2)
{
PutPixel(x1,y1,color);
if(e>0){x1+=1;e-=dy;}
y1+=1;
e+=dx;
}
}
}
else // dy<0
{
dy=-dy; // dy=abs(dy) if(dx>=dy) // 8/8 octant
{
e=dy-dx/2;
while(x1<=x2)
{
PutPixel(x1,y1,color);
if(e>0){y1-=1;e-=dx;}
x1+=1;
e+=dy;
}
}
else // 7/8 octant
{
e=dx-dy/2;
while(y1>=y2)
{
PutPixel(x1,y1,color);
if(e>0){x1+=1;e-=dy;}
y1-=1;
e+=dx;
}
}
}
}
else //dx<0
{
dx=-dx; //dx=abs(dx)
if(dy >= 0) // dy>=0
{
if(dx>=dy) // 4/8 octant
{
e=dy-dx/2;
while(x1>=x2)
{
PutPixel(x1,y1,color);
if(e>0){y1+=1;e-=dx;}
x1-=1;
e+=dy;
}
}
else // 3/8 octant
{
e=dx-dy/2;
while(y1<=y2)
{
PutPixel(x1,y1,color);
if(e>0){x1-=1;e-=dy;}
y1+=1;
e+=dx;
}
}
}
else // dy<0
{
dy=-dy; // dy=abs(dy) if(dx>=dy) // 5/8 octant
{
e=dy-dx/2;
while(x1>=x2)
{
PutPixel(x1,y1,color);
if(e>0){y1-=1;e-=dx;}
x1-=1;
e+=dy;
}
}
else // 6/8 octant
{
e=dx-dy/2;
while(y1>=y2)
{
PutPixel(x1,y1,color);
if(e>0){x1-=1;e-=dy;}
y1-=1;
e+=dx;
}
}
}
}
}
/**************************************************************
ÔÚLCDÆÁÄ»ÉÏÓÃÑÕÉ«Ìî³äÒ»¸ö¾ØÐÎ
**************************************************************/
static void Glib_FilledRectangle(int x1,int y1,int x2,int y2,int color)
{
int i;
for(i=y1;i<=y2;i++)
Glib_Line(x1,i,x2,i,color);
} /**************************************************************
ÔÚLCDÆÁÄ»ÉÏÖ¸¶¨×ø±êµã»­Ò»¸öÖ¸¶¨´óСµÄͼƬ
**************************************************************/
static void Paint_Bmp(int x0,int y0,int h,int l,unsigned char bmp[])
{
int x,y;
U32 c;
int p = 0; for( y = 0 ; y < l ; y++ )
{
for( x = 0 ; x < h ; x++ )
{
c = bmp[p+1] | (bmp[p]<<8) ;
if ( ( (x0+x) < SCR_XSIZE_TFT) && ( (y0+y) < SCR_YSIZE_TFT) )
LCD_BUFER[y0+y][x0+x] = c ;
p = p + 2 ;
}
}
} /**************************************************************
**************************************************************/
void Lcd_Test( void )
{
char ch;
Uart_Printf("\n GEC LCD Test\n"); /*========== ³õʼ»¯ ==========*/
/* 1.LCD IO¿Ú³õʼ»¯ */
Lcd_Port_Init();
/* 2.LTV350Çý¶¯Ð¾Æ¬³õʼ»¯ */
LTV350QV_Power_ON();
/* 3.LCD ¼Ä´æÆ÷³õʼ»¯ */
Lcd_Init();
/*´ò¿ª±³¹âµçÔ´*/
Lcd_PowerEnable(0, 1);
/* 4.LCD ¿ªÆôÊÓƵÊä³ö */
Lcd_EnvidOnOff(1);
/* 5.ʹÓð×É«ÏñËØÇåÆÁ */ Lcd_ClearScr(WHITE);
#if 0
while(1)
{
Lcd_ClearScr(RED);
Delay(100000);
Lcd_ClearScr(BLUE);
Delay(100000);
Lcd_ClearScr(BLACK);
Delay(100000);
}
#endif /*========== ´úÂë²âÊÔ ==========*/
/* 1.ʹÓû­Ïߺ¯Êý*/
// Glib_Line(1 f0,100,300,100,BLACK); /* 2.ʹÓÃÌî³ä¾ØÐκ¯Êý*/
// Glib_FilledRectangle(10,100,300,200,BLUE); /* 3.ÏÔʾͼƬ*/
// Uart_Printf("display a beauty picture\n");
Uart_Printf("display a beauty girl\n");
#if 0
while(1)
{
ch = Uart_Getch();
switch (ch)
{
case 'a':
Paint_Bmp( 0,0,480,272, image1) ;
//Delay(100000);
break;
case 'b':
Paint_Bmp( 0,0,480,272, image2) ;
// Delay(100000);
break;
case 'c':
Paint_Bmp( 0,0,480,272, image3) ;
Delay(100000);
break;
case 'd':
Paint_Bmp( 0,0,480,272, image4) ;
// Delay(100000);
break;
}
}
#endif
while( 1 )
{
if(Uart_GetKey() != ESC_KEY)
{
Paint_Bmp( 0,0,240,320, image1) ;
Delay(5000000);
}
else
{
break;
}
if(Uart_GetKey() != ESC_KEY)
{
Paint_Bmp( 0,0,240,320, image2) ;
Delay(5000000);
}
else
{
break;
}
if(Uart_GetKey() != ESC_KEY)
{
Paint_Bmp( 0,0,240,320, image3) ;
Delay(5000000);
}
else
{
break;
}
if(Uart_GetKey() != ESC_KEY)
{
Paint_Bmp( 0,0,240,320, image4) ;
Delay(5000000);
Lcd_ClearScr(BLACK);
}
else
{
break;
}
}
while(1);
}
//*************************************************************

LCD深度剖析的更多相关文章

  1. 《AngularJS深度剖析与最佳实践》简介

    由于年末将至,前阵子一直忙于工作的事务,不得已暂停了微信订阅号的更新,我将会在后续的时间里尽快的继续为大家推送更多的博文.毕竟一个人的力量微薄,精力有限,希望大家能理解,仍然能一如既往的关注和支持sh ...

  2. ASP.NET Core管道深度剖析(2):创建一个“迷你版”的管道来模拟真实管道请求处理流程

    从<ASP.NET Core管道深度剖析(1):采用管道处理HTTP请求>我们知道ASP.NET Core请求处理管道由一个服务器和一组有序的中间件组成,所以从总体设计来讲是非常简单的,但 ...

  3. Objective-C类成员变量深度剖析

    目录 Non Fragile ivars 为什么Non Fragile ivars很关键 如何寻址类成员变量 真正的“如何寻址类成员变量” Non Fragile ivars布局调整 为什么Objec ...

  4. 大众点评开源分布式监控平台 CAT 深度剖析

    一.CAT介绍 CAT系统原型和理念来源于eBay的CAL的系统,CAT系统第一代设计者吴其敏在eBay工作长达十几年,对CAL系统有深刻的理解.CAT不仅增强了CAL系统核心模型,还添加了更丰富的报 ...

  5. 深度剖析WordPress主题结构(转)

    利用强大的技术,可以把基于wordpress的网站做成各种各样的形式,这除了要求wordpress主题开发人员精通html,PHP,JS,CSS等技术,还需要开发者掌握WordPress主题的框架. ...

  6. WCF技术剖析之十九:深度剖析消息编码(Encoding)实现(下篇)

    原文:WCF技术剖析之十九:深度剖析消息编码(Encoding)实现(下篇) [爱心链接:拯救一个25岁身患急性白血病的女孩[内有苏州电视台经济频道<天天山海经>为此录制的节目视频(苏州话 ...

  7. 大兴雷克萨斯深度剖析2013款LS460L_深圳大兴雷克萨斯_太平洋汽车网

    大兴雷克萨斯深度剖析2013款LS460L_深圳大兴雷克萨斯_太平洋汽车网 大兴雷克萨斯深度剖析2013款LS460L

  8. Java反射机制剖析(四)-深度剖析动态代理原理及总结

    动态代理类原理(示例代码参见java反射机制剖析(三)) a)  理解上面的动态代理示例流程 a)  理解上面的动态代理示例流程 b)  代理接口实现类源代码剖析 咱们一起来剖析一下代理实现类($Pr ...

  9. 【渗透课程】第二篇下-HTTP协议的请求与响应深度剖析

    [渗透课程]第二篇下-HTTP协议的请求与响应深度剖析 HTTP1.1目前支持以下7种请求方法: 常见的MIME类型如下: 第一个数字有五种可能的取值: 目录 什么是请求方法?什么是请求头? HTTP ...

随机推荐

  1. C/S和B/S两种软件体系结构

    目前两种流行的软件体系结构就是C/S和B/S体系结构,下面对两种体系结构进行一下总结: 1.C/S(客户端/服务器模式): 客户端和服务器都是独立的计算机,客户端是面向最终用户的应用程序或一些接口设备 ...

  2. VMware下打开Chrome OS遇到没有网络连接可用

    打开ChromeOS.vmx文件,最后一行添加 ethernet0.virtualDev = "e1000" 就能解决.

  3. BZOJ 1634: [Usaco2007 Jan]Protecting the Flowers 护花

    Description Farmer John went to cut some wood and left N (2 <= N <= 100,000) cows eating the g ...

  4. uva 1308 - Viva Confetti

    这个题目的方法是将圆盘分成一个个圆环,然后判断这些圆环是否被上面的圆覆盖: 如果这个圆的圆周上的圆弧都被上面的覆盖,暂时把它标记为不可见: 然后如果他的头上有个圆,他有个圆弧可见,那么他自己本身可见, ...

  5. 《转》SQL Server 2008 数据维护实务

    SQL Server 2008 数据维护实务 http://blog.csdn.net/os005/article/details/7739553 http://www.cnblogs.com/xun ...

  6. Linq查询出结果集中重复数据

    private List<FMDS_FarmPlotNewInfo> GetSame(List<FMDS_FarmPlotNewInfo> lst) { List<FMD ...

  7. Delphi XML-RPC 中文乱码解决方法

    http://download.csdn.net/user/csm2432/uploads/2

  8. QT类库与Delphi类库的体系结构对比——两者十分类似!

    今天在看QT对象内存管理的一篇文章时:http://blog.csdn.net/dbzhang800/article/details/6300025想到了一个问题:就是QT类库体系结构与Delphi类 ...

  9. HTML表单和验证事件

    1.表单验证<form></form> (1).非空验证(去空格) (2).对比验证(跟一个值对比) (3).范围验证(根据一个范围进行判断) (4).固定格式验证:电话号码, ...

  10. 同一個Loader對象傳入不同參數時,从数据库中查询的結果每次都一樣

    發現問題: LoaderManager().initLoader()方法調用時會根據第一個參數ID去判斷是否已經存在一個Loader加載器,如果存在則複 用,不存在則建一個新的加載器.由於我第一次已經 ...