📄 lcddrive.c
字号:
* 出口参数:无
****************************************************************************/
void GUI_FillSCR(uint8 dat)
{ uint32 i, j;
for(i=0; i<GUI_LCM_YMAX; i++) // 历遍所有行
{ for(j=0; j<GUI_LCM_XMAX/8; j++) // 历遍所有行
{ gui_disp_buf[i][j] = dat; // 填充数据
}
}
/* 填充LCM */
LCD_FillAll(dat);
}
/****************************************************************************
* 名称:GUI_Initialize()
* 功能:初始化GUI,包括初始化显示缓冲区,初始化LCM并清屏。
* 入口参数:无
* 出口参数:无
****************************************************************************/
void GUI_Initialize(void)
{ LCD_Initialize(); // 初始化LCM模块工作模式,纯图形模式
GUI_FillSCR(0x00); // 初始化缓冲区为0x00,并输出屏幕(清屏)
}
/****************************************************************************
* 名称:GUI_ClearSCR()
* 功能:清屏。
* 入口参数:无
* 出口参数:无
* 说明:用户根据LCM的实际情况编写此函数。
****************************************************************************/
void GUI_ClearSCR(void)
{ GUI_FillSCR(0x00);
}
uint8 const DCB_HEX_TAB[8] = {0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01};
/****************************************************************************
* 名称: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);
/* 设置缓冲区相应的点 */
if( (color&0x01) != 0 ) gui_disp_buf[y][x>>3] |= DCB_HEX_TAB[x&0x07];
else gui_disp_buf[y][x>>3] &= (~DCB_HEX_TAB[x&0x07]);
/* 刷新显示 */
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)
{ TCOLOR bak;
/* 参数过滤 */
if(x>=GUI_LCM_XMAX) return(0);
if(y>=GUI_LCM_YMAX) return(0);
/* 取得该点颜色(用户自行更改) */
bak = gui_disp_buf[y][x>>3];
if( (bak&DCB_HEX_TAB[x&0x07])!=0 ) *ret = 1;
else *ret = 0;
return(1);
}
/****************************************************************************
* 名称:GUI_HLine()
* 功能:画水平线。
* 入口参数: x0 水平线起点所在列的位置
* y0 水平线起点所在行的位置
* x1 水平线终点所在列的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void GUI_HLine(uint32 x0, uint32 y0, uint32 x1, uint8 color)
{ uint32 bak;
if(x0>x1) // 对x0、x1大小进行排列,以便画图
{ bak = x1;
x1 = x0;
x0 = bak;
}
if(x0==x1)
{ GUI_Point(x0, y0, color);
return;
}
do
{ /* 设置相应的点为1 */
if(0!=color) gui_disp_buf[y0][x0>>3] |= DCB_HEX_TAB[x0&0x07];
else gui_disp_buf[y0][x0>>3] &= (~DCB_HEX_TAB[x0&0x07]);
/* 刷新显示(一次刷新一字节) */
if( (x0&0x07)==0x07 ) LCD_UpdatePoint(x0, y0);
x0++;
}while(x1>x0);
/* 对最后一点显示操作 */
if(0!=color) gui_disp_buf[y0][x0>>3] |= DCB_HEX_TAB[x0&0x07];
else gui_disp_buf[y0][x0>>3] &= (~DCB_HEX_TAB[x0&0x07]);
LCD_UpdatePoint(x0, y0);
}
/****************************************************************************
* 名称:GUI_RLine()
* 功能:画垂直线。
* 入口参数: x0 垂直线起点所在列的位置
* y0 垂直线起点所在行的位置
* y1 垂直线终点所在行的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
void GUI_RLine(uint32 x0, uint32 y0, uint32 y1, uint8 color)
{ uint32 bak;
if(y0>y1) // 对y0、y1大小进行排列,以便画图
{ bak = y1;
y1 = y0;
y0 = bak;
}
if(y0==y1)
{ GUI_Point(x0, y0, color);
return;
}
do
{ GUI_Point(x0, y0, color); // 逐点显示,描出垂直线
y0++;
}while(y1>y0);
GUI_Point(x0, y0, color);
}
/*******************************************************************
* 名称:void BusDelay(uint32 t)
* 功能:用模拟时序方式延时用
* 返回值:无
********************************************************************/
void BusDelay(uint32 t)
{
while(t--);
}
/*******************************************************************
* 名称:void PinSet(uint8 N)
* 功能:用模拟时序方式延时用,N=0为p0.0
* 返回值:无
********************************************************************/
void PinSet(uint8 N)
{
if(N<16)
{
PINSEL0=PINSEL0&(~(3<<(2*N)));
}
else{PINSEL1=PINSEL1&(~(3<<(2*N)));}
IO0DIR=IO0DIR|(1<<N);
IO0SET=IO0SET|(1<<N);
}
/*******************************************************************
* 名称:void PinClr(uint8 N)
* 功能:用模拟时序方式延时用,N=0为p0.0
* 返回值:无
********************************************************************/
void PinClr(uint8 N)
{
if(N<16)
{
PINSEL0=PINSEL0&(~(3<<(2*N)));
}
else{PINSEL1=PINSEL1&(~(3<<(2*N)));}
IO0DIR=IO0DIR|(1<<N);
IO0CLR=IO0CLR|(1<<N);
}
/*******************************************************************
* 名称:uint8 PinRead(uint8 N)
* 功能:用模拟时序方式延时用,N=0为p0.0
* 返回值:无
********************************************************************/
uint8 PinRead(uint8 N)
{
if(N<16)
{
PINSEL0=PINSEL0&(~(3<<(2*N)));
}
else{PINSEL1=PINSEL1&(~(3<<(2*N)));}//设置GPIO
IO0DIR=IO0DIR&(~(1<<N));//变为输入
if(IO0PIN&(1<<N)==1){return 1;}
else{return 0;}
}
/*******************************************************************
* 名称:void Pin1Set(uint8 N)
* 功能:用模拟时序方式延时用,N=0为p0.0
* 返回值:无
********************************************************************/
void Pin1Set(uint8 N)
{
PINSEL2=0x00;
IO1DIR=IO1DIR|(1<<N);
IO1SET=IO1SET|(1<<N);
}
/*******************************************************************
* 名称:void Pin1Clr(uint8 N)
* 功能:用模拟时序方式延时用,N=0为p0.0
* 返回值:无
********************************************************************/
void Pin1Clr(uint8 N)
{
PINSEL2=0x00;
IO1DIR=IO1DIR|(1<<N);
IO1DIR=IO1CLR|(1<<N);
}
/*******************************************************************
* 名称:uint8 Pin1Read(uint8 N)
* 功能:用模拟时序方式延时用,N=0为p0.0
* 返回值:无
********************************************************************/
uint8 Pin1Read(uint8 N)
{
PINSEL2=0x00;
IO1DIR=IO1DIR&(~(1<<N));//变为输入
if(IO1PIN&(1<<N)==1){return 1;}
else{return 0;}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -