📄 lcddrive.c
字号:
if( LCD_TestStaBit01()==0 ) return(0);
LCD_WriteCommand(command); // 发送命令字
DelayNs(1);
return(1);
}
/***********************************************************************
* 名称:LCD_WriteTData1()
* 功能:写1字节数据子程序。会先判断状态字。
* 入口参数:dat 要写入LCM的数据
* 出口参数:操作出错返回0,否则返回1
***********************************************************************/
extern uint8 LCD_WriteTData1(uint8 dat)
{
if( LCD_TestStaBit3()==0 ) return(0);
LCD_WriteData(dat);
return(1);
}
/* *************以下为LCM的用户接口层,主要负责解释用户命令,并发送到LCM,为用户编程提供接口 ******************/
/***********************************************************************
* 名称:LCD_Initialize()
* 功能:LCM初始化,将LCM初始化为纯图形模式,显示起始地址为0x0000,。
* 入口参数:无
* 出口参数:无
* 说明:函数会设置LCM数据总线为输出方式
***********************************************************************/
extern void LCD_Initialize(void)
{ LCD_WriteTCommand3(LCD_TXT_STP, 0x00, 0x00); // 设置文本方式RAM起始地址
//DelayNs(1);
LCD_WriteTCommand3(LCD_TXT_WID, 16, 0x00); // 设置文本模式的宽度,宽度为N/6或N/8,N为宽度点数,128
//DelayNs(1);
LCD_WriteTCommand3(LCD_GRH_STP, 0x00, 0x00); // 设置图形方式RAM起始地址
//DelayNs(1);
LCD_WriteTCommand3(LCD_GRH_WID, 16, 0x00); // 设置图形模式的宽度,宽度为N/6或N/8,N为宽度点数,如240
// DelayNs(1);
LCD_WriteTCommand1(LCD_MOD_OR); // 设置显示方式为"或"
// DelayNs(1);
LCD_WriteTCommand1(LCD_DIS_SW|0x08); // 设置纯图形显示模式
}
/***********************************************************************
* 名称:LCD_FillAll()
* 功能:LCD填充。以图形方式进行填充,起始地址为0x0000。
* 入口参数:dat 要填充的数据
* 出口参数:无
***********************************************************************/
extern void LCD_FillAll(uint8 dat)
{ uint32 i;
LCD_WriteTCommand3(LCD_ADR_POS, 0x00, 0x00); // 置地址指针
DelayNs(1);
LCD_WriteTCommand1(LCD_AUT_WR); // 自动写
DelayNs(1);
for(i=0;i<64*16;i++)
{ LCD_WriteTData1(dat); // 写数据
}
DelayNs(1);
LCD_WriteTCommand1(LCD_AUT_OVR); // 自动写结束
DelayNs(1);
LCD_WriteTCommand3(LCD_ADR_POS,0x00,0x00); // 重置地址指针
}
/****************************************************************************
* 名称:LCD_UpdatePoint()
* 功能:在指定位置上画点,刷新某一点。
* 入口参数: x 指定点所在列的位置
* y 指定点所在行的位置
* 出口参数:返回值为1时表示操作成功,为0时表示操作失败。
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
extern void LCD_UpdatePoint(uint32 x, uint32 y)
{ uint32 addr;
/* 找出目标地址 */
addr = y*(GUI_LCM_XMAX>>3) + (x>>3); //找到是那个区域(8位)
LCD_WriteTCommand3(LCD_ADR_POS, addr&0xFF, addr>>8); // 置地址指针
/* 输出数据 */
LCD_WriteTCommand2(LCD_INC_WR, gui_disp_buf[y][x>>3]);
}
/****************************************************************************
* 名称:GUI_FillSCR()
* 功能:全屏填充。直接使用数据填充显示缓冲区。
* 入口参数:dat 填充的数据(对于黑白色LCM,为0的点灭,为1的点显示)
* 出口参数:无
****************************************************************************/
extern 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);
}
uint8 const DCB_HEX_TAB[8] = {0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01};
/****************************************************************************
* 名称:GUI_Point()
* 功能:在指定位置上画点。
* 入口参数: x 指定点所在列的位置
* y 指定点所在行的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:返回值为1时表示操作成功,为0时表示操作失败。(操作失败原因是指定地址超出有
* 效范围)
****************************************************************************/
extern 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_HLine()
* 功能:画水平线。
* 入口参数: x0 水平线起点所在列的位置
* y0 水平线起点所在行的位置
* x1 水平线终点所在列的位置
* color 显示颜色(对于黑白色LCM,为0时灭,为1时显示)
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
extern 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);
}
/****************************************************************************
* 名称:display_shuzi()
* 功能:在指定的地方显示数字
*入口参数:ix表示横向字节坐标,iy表示纵轴坐标,disp_datesz表示显示的数字
* 出口参数:无
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
extern uint8 display_shuzi(uint8 Disp_datesz,uint8 ix,uint8 iy)
{ uint32 addr1;
uint8 shuzizimo[12];
uint8 ds,szzmc,ls;
switch(Disp_datesz)
{
case 0:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_0[ds];
break;
case 1:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_1[ds];
break;
case 2:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_2[ds];
break;
case 3:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_3[ds];
break;
case 4:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_4[ds];
break;
case 5:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_5[ds];
break;
case 6:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_6[ds];
break;
case 7:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_7[ds];
break;
case 8:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_8[ds];
break;
case 9:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_9[ds];
break;
case 0x0A:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=MatrixMaohao[ds];
break;
case 0x0B:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=Matrixxie[ds];
break;
case 0x0C:
for(ds=0;ds<12;ds++)
shuzizimo[ds]=shuzi_kg[ds];
break;
}
szzmc=0;
for(ls=iy;ls<iy+12;ls++)
//j表示横向两个字节如果是在显示3,4个字节上把j该为j=2;j<4
{
addr1=ls*16+ix;
LCD_WriteTCommand3(LCD_ADR_POS, addr1&0xFF, addr1>>8); // 置地址指针
LCD_WriteTCommand2(LCD_NOC_WR, shuzizimo[szzmc]);
szzmc++;
}
return(1);
}
/****************************************************************************
* 名称:display_date()
* 功能:显示日期数字
* 入口参数:Disp_date[8] 为年/月/日从高位到低位依次排列每个数字为一个数组里的数
* 出口参数:1败原因是指定地址超出缓冲区范围。
****************************************************************************/
extern uint8 display_date(uint8 * Disp_date)
{ uint8 dasz;
uint8 dasz1;
for(dasz1=8;dasz1>0;dasz1--)
{ dasz=dasz1-1;
switch(dasz)
{ case 7:
display_shuzi(Disp_date[dasz],5,3) ;
break;
case 6:
display_shuzi(Disp_date[dasz],6,3) ;
break;
case 5:
display_shuzi(Disp_date[dasz],7,3) ;
break;
case 4:
display_shuzi(Disp_date[dasz],8,3) ;
display_shuzi(0xB,9,3) ;
break;
case 3:
display_shuzi(Disp_date[dasz],10,3) ;
break;
case 2:
display_shuzi(Disp_date[dasz],11,3) ;
display_shuzi(0xB,12,3) ;
break;
case 1:
display_shuzi(Disp_date[dasz],13,3) ;
break;
case 0:
display_shuzi(Disp_date[dasz],14,3) ;
break;
}
}
return(1); }
/****************************************************************************
* 名称:display_time()
* 功能:显示时间数字
* 入口参数:Disp_time 为 小时/分钟/秒 从高位到低位依次排列每个数字为一个数组里的数
* 出口参数:1
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
extern uint8 display_time(uint8 * Disp_time)
{ uint8 timesz;
uint8 timesz1;
for(timesz1=0;timesz1<6;timesz1++)
{ timesz=timesz1;
switch(timesz)
{
case 5:
if(Disp_time[timesz]==0){display_shuzi(0xC,6,41) ;}
else display_shuzi(Disp_time[timesz],5,21) ;
break;
case 4:
display_shuzi(Disp_time[timesz],6,21) ;
display_shuzi(0xA,7,21) ;
break;
case 3:
display_shuzi(Disp_time[timesz],8,21) ;
break;
case 2:
display_shuzi(Disp_time[timesz],9,21) ;
display_shuzi(0xA,10,21) ;
break;
case 1:
display_shuzi(Disp_time[timesz],11,21) ;
break;
case 0:
display_shuzi(Disp_time[timesz],12,21) ;
break;
}
}
return(1); }
/****************************************************************************
* 名称:display_speed()
* 功能:显示速度数字
* 入口参数:百位十位各位 从高位到低位依次排列每个数字为一个数组里的数
* 出口参数:1
* 说明:操作失败原因是指定地址超出缓冲区范围。
****************************************************************************/
extern uint8 display_speed(uint8 * Disp_speed)
{ uint8 speedsz;
uint8 speedsz1;
for(speedsz1=3;speedsz1>0;speedsz1--)
{ speedsz=speedsz1-1;
switch(speedsz)
{
case 2:
if(Disp_speed[speedsz]==0){display_shuzi(0xC,6,41) ;}
else display_shuzi(Disp_speed[speedsz],6,41) ;
break;
case 1:
display_shuzi(Disp_speed[speedsz],7,41) ;
break;
case 0:
display_shuzi(Disp_speed[speedsz],8,41) ;
break;
}
}
return(1); }
/************************程序实例 勿删*****************************************/
/*LCD_WriteTCommand3(LCD_ADR_POS, 0x00, 0x00); // 置地址指针
i=0;
dat=Matrixkmh[i] ;
for(k=36;k<54;k++) //k表示 数据从第几行到第几行
{for(j=11;j<16;j++) //j表示 横着数据从第几列到第几列
{addr1=k*16+j; //计算在RAM哪个存储区地址(按字节排的)
LCD_WriteTCommand3(LCD_ADR_POS, addr1&0xFF, addr1>>8); // 置地址指针
LCD_WriteTCommand2(LCD_NOC_WR, dat);
dat=Matrixkmh[i] ;
i++;}
} */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -