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

📄 lcddrive.c

📁 基于ARM7开发系统的触摸屏校准程序
💻 C
字号:
/****************************************************************************************
* 文件名:LCDDRIVE.C
* 功能:通过操作S1D13503,控制256色RGB伪彩液晶显示屏。
* 说明:使用LPC2200芯片控制,8位总线接口。
*       S1D13503的寄存器地址为0x838000xx,显示存储器的地址为0x834xxxxx。
* 作者:黄绍斌
* 日期:2005.05.26
****************************************************************************************/
#include "config.h"

/* 定义显示缓冲区(可根据情况定义或直接使用LCM显示存储空间) */
TCOLOR  gui_disp_buf[GUI_LCM_YMAX][GUI_LCM_XMAX];

uint8 const  INIT_TAB[14] = { 0x00, // 寄存器0 -- 00000000B (正常工作模式,即非测试模式)
							  0xBD,	// 寄存器1 -- 10111101B (模式控制:打开显示,单屏,屏蔽XSCL水平非显示周期输出,使能LCDENB,彩色8位LCD数据--无XCSL2,16位显示存储数据总线方式)  
							  159,	// 寄存器2 -- 159 (行字节控制)(每行显示占用的存储器字节数,即列参数)
							  0x0E, // 寄存器3 -- 00001110B (非节功模式,256彩色方式)
							  239,  // 寄存器4 -- 239 (总行数)
							  0,	// 寄存器5 -- 0 (WF翻转周期,为0时表示每一帧WF输出翻转一次)
							  0x00,	// 寄存器6 -- 00H (第一屏显示RAM地址低8位)
							  0x00, // 寄存器7 -- 00H (第一屏显示RAM地址高8位)
							  0x00,	// 寄存器8 -- 00H (第二屏显示RAM地址低8位)
							  0x00, // 寄存器9 -- 00H (第二屏显示RAM地址高8位)
							  239,  // 寄存器A -- 239 (显示一区占用行数)
							  0, 	// 寄存器B -- 0 (显示一区占用行数,高2位)
							  10,	// 寄存器C -- 10 (水平默认不显示周期) 
							  0		// 寄存器D -- 0 (显示域冗余宽度,正常操作模式)
                            };                           
/****************************************************************************
* 名称:S1D13503_Init()
* 功能:初始化S1D13503。320*240 256色单屏彩屏。
* 入口参数:无
* 出口参数:无
* 说明:本子程序对S1D13503寄存器0--D进行初始化(使用查表方法)
****************************************************************************/
void  S1D13503_Init(void)
{  volatile uint16  *REG_Point;
   uint8  i; 

   REG_Point = (void *) S1D13503_REG;
   for(i=0; i<14; i++)				// 共初始化14个寄存器
   {  *REG_Point = INIT_TAB[i];		// 查表取出数据,然后赋值给S1D13503相应的寄存器,实现初始化
      REG_Point++;					// 指向下一寄存器
   }
}



uint8 const  LUT_RED_TAB[16] = { 0, 3, 5, 7, 9, 11, 13, 15,
                                 0, 3, 5, 7, 9, 11, 13, 15
                               };
uint8 const  LUT_GRN_TAB[16] = { 0, 3, 5, 7, 9, 11, 13, 15,
                                 0, 3, 5, 7, 9, 11, 13, 15
                               };
uint8 const  LUT_BLU_TAB[16] = { 0, 6, 10, 15,
                                 0, 6, 10, 15,
                                 0, 6, 10, 15, 
                                 0, 6, 10, 15
                               };                                                              
/****************************************************************************
* 名称:S1D13503_LutInit()
* 功能:初始化S1D13503的调色板,红、绿基色设置为0、3、5、7、9、11、13、15,
*      蓝基色设置为0、6、10、15。
* 入口参数:无
* 出口参数:无
* 说明:使用
****************************************************************************/
void  S1D13503_LutInit(void)
{  volatile uint16  *REG_Point1;
   volatile uint16  *REG_Point2;
   uint8  i; 
   
   REG_Point1 = (void *) S1D13503_REG;
   REG_Point1 += 0x0E;
   
   REG_Point2 = (void *) S1D13503_REG;	
   REG_Point2 += 0x0F;
   
   for(i=0; i<16; i++) 
   {  *REG_Point1 = i;				// 设置为自动更换存取方式,设置地址
      *REG_Point2 = LUT_RED_TAB[i];	// 设置红色调色板
      *REG_Point2 = LUT_GRN_TAB[i];	// 设置绿色调色板
      *REG_Point2 = LUT_BLU_TAB[i];	// 设置蓝色调色板
   }
}


/***********************************************************************
* 名称:LCD_Initialize()
* 功能:LCM初始化。将LCM初始化为纯图形模式,显示起始地址为0x0000。
* 入口参数:无
* 出口参数:无
* 说明:
***********************************************************************/
void  LCD_Initialize(void)
{  S1D13503_Init();										// 初始化LCM工作模式			
   S1D13503_LutInit();									// 初始化调色板
}


/***********************************************************************
* 名称:LCD_FillAll()
* 功能:LCD填充。以图形方式进行填充,起始地址为0x0000。
* 入口参数:dat		要填充的颜色数据
* 出口参数:无
***********************************************************************/
void  LCD_FillAll(TCOLOR dat)
{  volatile uint16  *DAT_Point;
   uint32  i, j; 

   /* 开始复制填充数据 */
   DAT_Point = (void *) S1D13503_DAT;					// 置地址指针
   for(i=0; i<GUI_LCM_YMAX; i++)						// 历遍所有行
   {  for(j=0; j<GUI_LCM_XMAX; j++)						// 历遍所有行
      {  *DAT_Point++ = dat;
	  }
   }
}


/****************************************************************************
* 名称:LCD_UpdatePoint()
* 功能:在指定位置上画点,刷新某一点。
* 入口参数:x		指定点所在列的位置
*           y		指定点所在行的位置
* 出口参数:无
* 说明:操作失败原因是指定地址超出有效范围。
****************************************************************************/
void  LCD_UpdatePoint(uint32 x, uint32 y)
{  volatile uint16  *DAT_Point;
   uint32  addr;
   uint32 x1, y1;    
   
   x1 = GUI_LCM_XMAX - x - 1;       // 对于9111屏有效
   y1 = GUI_LCM_YMAX - y - 1;       // 对于9111屏有效
 
   /* 找出目标地址 */
   addr = y1*GUI_LCM_XMAX + x1;
   DAT_Point = (void *) S1D13503_DAT;
   DAT_Point += addr;
   
   *DAT_Point = gui_disp_buf[y][x];						// 输出数据 
}




/****************************************************************************
*                    与LCM相关的GUI接口函数
****************************************************************************/


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

   /* 填充缓冲区 */
   for(i=0; i<GUI_LCM_YMAX; i++)		// 历遍所有行
   {  for(j=0; j<GUI_LCM_XMAX; j++)		// 历遍所有行
      {  gui_disp_buf[i][j] = dat;
	  }
   }
   
   /* 填充LCM */
   LCD_FillAll(dat);
}


/****************************************************************************
* 名称:GUI_Initialize()
* 功能:初始化GUI,包括初始化显示缓冲区,初始化LCM并清屏。
* 入口参数:无
* 出口参数:无
* 说明:用户根据LCM的实际情况编写此函数。
****************************************************************************/
void  GUI_Initialize(void)
{  LCD_Initialize();					// 初始化LCM模块工作模式,纯图形模式
   GUI_FillSCR(0x00);					// 初始化缓冲区为0x00,并输出屏幕(清屏)
}


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



/****************************************************************************
* 名称:GUI_Point()
* 功能:在指定位置上画点。
* 入口参数: x		指定点所在列的位置
*           y		指定点所在行的位置
*           color	显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:返回值为1时表示操作成功,为0时表示操作失败。(操作失败原因是指定地址超出有
*          效范围)
* 说明:用户根据LCM的实际情况编写此函数。对于单色,只有一个位有效,则要使用左移的方法
*      实现point_dat = (point_dat&MASK_TAB [i]) | (color<<n),其它位数的一样
*      处理。
****************************************************************************/
uint8  GUI_Point(uint32 x, uint32 y, TCOLOR color)
{  /* 参数过滤 */
   if(x>=GUI_LCM_XMAX) return(0);
   if(y>=GUI_LCM_YMAX) return(0);
   
   /* 设置缓冲区相应的点 */
   gui_disp_buf[y][x] = color;

   /* 刷新显示 */
   LCD_UpdatePoint(x, y);
   return(1);
}


/****************************************************************************
* 名称:GUI_ReadPoint()
* 功能:读取指定点的颜色。
* 入口参数:x			指定点所在列的位置
*          y		指定点所在行的位置
*          ret		保存颜色值的指针
* 出口参数:返回0时表示指定地址超出有效范围。
* 说明:对于单色,设置ret的d0位为1或0,4级灰度则为d0、d1有效,8位RGB则d0--d7有效,
*      RGB结构则R、G、B变量有效。
****************************************************************************/
int  GUI_ReadPoint(uint32 x, uint32 y, TCOLOR *ret)
{  /* 参数过滤 */
   if(x>=GUI_LCM_XMAX) return(0);
   if(y>=GUI_LCM_YMAX) return(0);
  
   /* 取得该点颜色(用户自行更改) */ 
   *ret = gui_disp_buf[y][x];
   
   return(1);
}


/****************************************************************************
* 名称:GUI_HLine()
* 功能:画水平线。
* 入口参数: x0		水平线起点所在列的位置
*           y0		水平线起点所在行的位置
*           x1      水平线终点所在列的位置
*           color	显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:无
* 说明:对于单色、4级灰度的液晶,可通过修改此函数作图提高速度,如单色LCM,可以一次更
*      新8个点,而不需要一个点一个点的写到LCM中。
****************************************************************************/
void  GUI_HLine(uint32 x0, uint32 y0, uint32 x1, TCOLOR color) 
{  uint32  bak;

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


/****************************************************************************
* 名称:GUI_RLine()
* 功能:画垂直线。
* 入口参数: x0		垂直线起点所在列的位置
*           y0		垂直线起点所在行的位置
*           y1      垂直线终点所在行的位置
*           color	显示颜色
* 出口参数:无
* 说明:对于单色、4级灰度的液晶,可通过修改此函数作图提高速度,如单色LCM,可以一次更
*      新8个点,而不需要一个点一个点的写到LCM中。
****************************************************************************/
void  GUI_RLine(uint32 x0, uint32 y0, uint32 y1, TCOLOR color) 
{  uint32  bak;

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



/****************************************************************************
* 名称:GUI_CmpColor()
* 功能:判断颜色值是否一致。
* 入口参数:color1		颜色值1
*		   color2		颜色值2
* 出口参数:返回1表示相同,返回0表示不相同。
* 说明:由于颜色类型TCOLOR可以是结构类型,所以需要用户编写比较函数。
****************************************************************************/
//int  GUI_CmpColor(TCOLOR color1, TCOLOR color2)
//{  if(color1==color2) return(1);
//     else  return(0);
//}


/****************************************************************************
* 名称:GUI_CopyColor()
* 功能:颜色值复制。
* 入口参数:color1		目标颜色变量
*		   color2		源颜色变量
* 出口参数:无
* 说明:由于颜色类型TCOLOR可以是结构类型,所以需要用户编写复制函数。
****************************************************************************/
//void  GUI_CopyColor(TCOLOR *color1, TCOLOR color2)
//{  *color1 = color2;
//}















⌨️ 快捷键说明

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