⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 lcddrive.c

📁 关于ILI9320液晶模块的显示
💻 C
字号:
/****************************************************************************************
* 文件名:LCDDRIVE.C
* 功能:TFT4137液晶模块驱动。驱动芯片为S6D0139 (片内172800字节GRAM,即240*320*18/8),
*                                  
*  RGB对应值(16位数据,d15--d0):
*  d15--d11		R色
*  d10--d5      G色
*  d4--d0		B色
*  写操作时地址计数器会自动增长,而读操作则不会自动增长。读操作时,读第2个数
*  据才是有效的数据
****************************************************************************************/
#include "config.h"
#include "lcddrive.h"
#include "LPC2294.h"
/*******************************************************
* 名称: TftSendCom
* 功能: 向TFT液晶模块发送命令字。
* 入口参数: com   命令字(uint16)
* 出口参数: 无
*******************************************************/
void  TftSendCom(uint16 com)
{  S6D0139_IR = com;
}

/*******************************************************
* 名称: TftSendDat
* 功能: 向TFT液晶模块发送数据。
* 入口参数: dat   待发送的数据(uint16)
* 出口参数: 无
*******************************************************/
void  TftSendDat(uint16 dat)
{  S6D0139_DR = dat;
}

/*******************************************************
* 名称: TftRcvDat
* 功能: 读取TFT液晶模块的数据。
* 入口参数: 无
* 出口参数: 返回值即是读出的数据
*******************************************************/
uint16  TftRcvDat(void)
{  uint16  ret;

   ret = S6D0139_DR;
   return(ret);
}

/*******************************************************
* 名称: TftSetAddr
* 功能: 设置数据地址指针(坐标值)。
* 入口参数: x		横坐标的值 (0-239)
*           y       纵坐标的值 (0-319)
* 出口参数: 设置正确返回TRUE,参数超出范围返回FALSE
*******************************************************/
uint8  TftSetAddr(uint16 x, uint16 y)
{  TftSendCom(SET_ADDR_X);		// 设置地址低8位
   TftSendDat(x);
   
   TftSendCom(SET_ADDR_Y);		// 设置地址高9位
   TftSendDat(y);
   
   if((x<240) && (y<320)) return(TRUE);
     else  return(FALSE);
}

/*******************************************************
* 名称: TftSetWrite
* 功能: 设置数据地址指针(坐标值),并发送写数据命令。
*       接着不断的写入数据即可,GRAM地址会自动增加。
* 入口参数: x		横坐标的值 (0-239)
*           y       纵坐标的值 (0-319)
* 出口参数: 设置正确返回TRUE,参数超出范围返回FALSE
*******************************************************/
uint8  TftSetWrite(uint16 x, uint16 y)
{  uint8  ret;

   ret = TftSetAddr(x, y);
   TftSendCom(WR_RD_DATA);		// 写数据
   return(ret);
}

/*******************************************************
* 名称: TftSetWindow
* 功能: 设置数据填充窗口大小。
* 入口参数: x0,y0		窗口左上角从标
*           x1,y1	    窗口右上角从标
* 出口参数: 设置正确返回TRUE,参数错误返回FALSE
*******************************************************/
uint8  TftSetWindow(uint16 x0, uint16 y0, uint16 x1, uint16 y1)  
{  
  // 参数过滤
   if(x1>239) x1 = 239;
   if(y1>319) y1 = 319;
   if((x1<=x0) || (y1<=y0)) return(FALSE);         
   
   // 设置数据填充窗口大小
   TftSendCom(SET_WINDOW_SX);
   TftSendDat(x0);
   TftSendCom(SET_WINDOW_EX);		
   TftSendDat(x1);   
   TftSendCom(SET_WINDOW_SY);		
   TftSendDat(y0);    
   TftSendCom(SET_WINDOW_EY);		
   TftSendDat(y1);
   
   return(TRUE);
}

/*******************************************************
* 名称: DelaymS
* 功能: 软件延时(1mS,与系统时钟有关)。
* 入口参数: no   延时控制(uint32),值越大延时越长
* 出口参数: 无
*******************************************************/
void  DelaymS(uint32 no)
{  uint32 i;

   for(; no>0; no--)
   {  for(i=0; i<900; i++);
   }
}


/****************************************************************************
* 名称:TFT_FillSCR()
* 功能:全屏填充。直接使用数据填充显示缓冲区。
* 入口参数:dat		填充的数据
* 出口参数:无
****************************************************************************/
void  TFT_FillSCR(uint16 dat)
{  uint16  i, j;
   
   TftSetWrite(0,0); 
   for(i=0; i<GUI_LCM_YMAX; i++)		// 历遍所有行
   {  for(j=0; j<GUI_LCM_XMAX; j++)		// 历遍所有行
      {  TftSendDat(dat); 				// 填充数据
	  }
   }
 
}

/*******************************************************
* 名称: TftReset
* 功能: 控制TFT液晶模块复位。
* 入口参数: 无
* 出口参数: 无
*******************************************************/
void  TftReset(void)
{   PINSEL1 = PINSEL1 & (~(0x03<<12));
    IO0DIR = IO0DIR | S6D0139_RST;    

    IO0CLR = S6D0139_RST;
    DelaymS(10);
    IO0SET = S6D0139_RST;
    DelaymS(10);   
}


// 定义TFT4137初始化数据信息
STCOM_INI  TFT4137_INI[] = 
{   
    {0x0000, 0x0001, 10},	// Start Oscillation
    {0x0001, 0x0100,  0},	// Driver Output Contral. 
    {0x0002, 0x0700,  0},	// LCD Driver Waveform Contral.
    {0x0003, 0x1030,  0},	// Entry Mode Set.
    {0x0004, 0x0000,  0},	// Scalling Contral.
    {0x0008, 0x0202,  0},   // Display Contral 2.(0x0207)
    {0x0009, 0x0000,  0},	// Display Contral 3.(0x0000)
    {0x000a, 0x0000,  0},	// Frame Cycle Contal.(0x0000)
    {0x000c, 0x0001,  0},	// Extern Display Interface Contral 1.(0x0000)
    {0x000d, 0x0000,  0},   // Frame Maker Position.
    {0x000f, 0x0000,  10},   // Extern Display Interface Contral 2.
    
    
    
    {0x0007, 0x0101,  10},   // Display control1 
    
    {0x0010, 0x10c0,  40},	 //Power Control 1.(0x16b0)
    {0x0011, 0x0007,  40},	 //Power Control 2.(0x0001)
    {0x0012, 0x0110,  40},	 //Power Control 3.(0x0138)
	{0x0013, 0x0b00,  40},	 //Power Control 4.
	{0x0029, 0x0000,  40},	 //Power Control 7.
	
	
	{0x002b,0x4010,   0},
		
	{0x0050,0x0000,   0},	//Set X Start.
	{0x0051,0x00ef,   0},	//Set X End.
	{0x0052,0x0000,   0},	//Set Y Start.
	{0x0053,0x013f,   0},	//Set Y End.
	
	{0x0060,0x2700,   0},	//Driver Output Control.
	{0x0061,0x0001,   0},	//Driver Output Control.
	{0x006a,0x0000,   0},	//Vertical Srcoll Control.
	
	{0x0080,0x0000,   0},	//Display Position? Partial Display 1.
	{0x0081,0x0000,   0},	//RAM Address Start? Partial Display 1.
	{0x0082,0x0000,   0},	//RAM Address End-Partial Display 1.
	{0x0083,0x0000,   0},	//Displsy Position? Partial Display 2.
	{0x0084,0x0000,   0},	//RAM Address Start? Partial Display 2.
	{0x0085,0x0000,   0},	//RAM Address End? Partial Display 2.
	
	{0x0090,0x0010,   0},	//Frame Cycle Contral.(0x0013)
	{0x0092,0x0000,   0},	//Panel Interface Contral 2.(0x0000)
	{0x0093,0x0001,   0},	//Panel Interface Contral 3.
	{0x0095,0x0110,   0},	//Frame Cycle Contral.(0x0110)
	{0x0097,0x0000,   0},	//
	{0x0098,0x0000,   0},	//Frame Cycle Contral.

	
    {0x0007,0x0173,   0},	//(0x0173)
    
    {DATA_END,    0,  0}
};

/*******************************************************
* 名称: TftInit
* 功能: 初始化TFT液晶模块。
* 入口参数: 无
* 出口参数: 无
*******************************************************/
void  TftInit(void)  
{   STCOM_INI  init_dat;
    int  i;
   
    TftReset();
  
    for(i=0; i<100; i++)		// 设定最多100条初始化命令
    {   init_dat = TFT4137_INI[i];
        if(init_dat.com==DATA_END) break;
      
        TftSendCom(init_dat.com);
        TftSendDat(init_dat.dat);            
        DelaymS(init_dat.dly);      
    }
}

/****************************************************************************
* 名称:GUI_Initialize()
* 功能:初始化GUI,包括初始化显示缓冲区,初始化LCM并清屏。
* 入口参数:无
* 出口参数:无
* 说明:用户根据LCM的实际情况编写此函数。
****************************************************************************/
void  GUI_Initialize(void)
{   TftInit();
    TFT_FillSCR(WHITE);//(BLACK);
}


/****************************************************************************
* 名称:GUI_FillSCR()
* 功能:全屏填充。直接使用数据填充显示缓冲区。
* 入口参数:dat		填充的数据
* 出口参数:无
* 说明:用户根据LCM的实际情况编写此函数。
****************************************************************************/
void  GUI_FillSCR(TCOLOR dat)
{   TFT_FillSCR(dat);
}


/****************************************************************************
* 名称:GUI_ClearSCR()
* 功能:清屏。
* 入口参数:无
* 出口参数:无
* 说明:用户根据LCM的实际情况编写此函数。
****************************************************************************/
void  GUI_ClearSCR(void)
{   TFT_FillSCR(GUI_CCOLOR);
}


/****************************************************************************
* 名称:GUI_Point()
* 功能:在指定位置上画点。
* 入口参数:x		指定点所在列的位置
*           y		指定点所在行的位置
*           color	显示颜色
* 出口参数:返回值为1时表示操作成功,为0时表示操作失败。
****************************************************************************/
uint8  GUI_Point(uint16 x, uint16 y, TCOLOR color)
{  /* 参数过滤 */
   if(x>=GUI_LCM_XMAX) return(0);
   if(y>=GUI_LCM_YMAX) return(0);
   
   /* 刷新显示 */
   TftSetWrite(x, y);
   TftSendDat(color);
   
   return(1);
}


/****************************************************************************
* 名称:GUI_ReadPoint()
* 功能:读取指定位置点的颜色数据。
* 入口参数:x		指定点所在列的位置
*           y		指定点所在行的位置
* 出口参数:返回值即是读出值(RRRRRGGGGGGBBBBB)。
****************************************************************************/
uint8  GUI_ReadPoint(uint16 x, uint16 y, TCOLOR *ret)
{  uint16  bak;

   /* 参数过滤 */
   if(x>=GUI_LCM_XMAX) return(0);
   if(y>=GUI_LCM_YMAX) return(0);
   
   /* 读取数据 */
   TftSetAddr(x, y);		// 设置地址
   TftSendCom(WR_RD_DATA);
   bak = TftRcvDat();
   bak = TftRcvDat();      //?????
   *ret = bak;
   
   return(1);
}


/****************************************************************************
* 名称:GUI_HLine()
* 功能:画水平线。
* 入口参数:x0		水平线起点所在列的位置
*           y0		水平线起点所在行的位置
*           x1      水平线终点所在列的位置
*           color	显示颜色
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void  GUI_HLine(uint16 x0, uint16 y0, uint16 x1, TCOLOR color) 
{  uint16  bak;

   if(x0>x1) 						// 对x0、x1大小进行排列,以便画图
   {  bak = x1;
      x1 = x0;
      x0 = bak;
   }
      
   GUI_Point(x0, y0, color);		// 显示第一点
   x0++;
   while(x1>=x0)
   {  TftSendDat(color);			// 不断填充并显示
      x0++;
   }
}


/****************************************************************************
* 名称:GUI_RLine()
* 功能:画垂直线。
* 入口参数: x0		垂直线起点所在列的位置
*           y0		垂直线起点所在行的位置
*           y1      垂直线终点所在行的位置
*           color	显示颜色
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void  GUI_RLine(uint16 x0, uint16 y0, uint16 y1, TCOLOR color) 
{  uint16  bak;

   if(y0>y1) 						// 对y0、y1大小进行排列,以便画图
   {  bak = y1;
      y1 = y0;
      y0 = bak;
   }
   
   while(y1>=y0)
   {  GUI_Point(x0, y0, color);		// 逐点显示,描出垂直线
      y0++;
   }	
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -