c语言液晶显示,AT89C51单片机驱动液晶显示汉字C语言

AT89C51单片机驱动液晶显示汉字C语言

作者:时间:2016-11-30来源:网络

void writeDataLcd(unsigned char dat)// 写入数据

{

LCD_RS=1; //RS置1 (运算后P5=xxx1 xxxx,即RS=1其他位状态不变)

LCD_RW=0; //RW清0 (运算后P5=xx0x xxxx, 即RW=0其他位状态不变)

LCD_E=0; //使能E清0 (运算后P5=xxxx 0xxx, 即E=0其他位状态不变)

P1 = dat; //送数据到P2OUT准备输出进入1602,等E下降沿来即可进入1602.

LCD_E=1; //使能E置1,P5OUT= xxxx xxxx+0000 1000=xxxx1xxx,E=1.

delay(10);

LCD_E=0; //使能E清0,这样E从1变0,产生一个下降,写入命令到1602。

}

//********************************

//*******显示一个字符函数*********

void LCD_disp_char(uchar x,uchar y,uchar dat)

{

if(y>=64)

{

y=y-1;

}

LCD_write_command(0x40|y);

delay(10);

LCD_write_command(0xb8|x);

LCD_write_data(dat);

}

//********************************

/*******检查忙函数*************

voidLCD_check_busy()

//实践证明,在我的LCD1602 上,检查忙指令通

过率极低,以至于不能正常使用LCD。因此我没有再用检查忙函数。而使

do//用了延时的方法,延时还是非常好用的。我试了一下,用//

{LCD_E=0; //for 循环作延时,普通指令只要1次循就可完成。清屏指令

LCD_RS=0; //要用200次循环便能完成。

LCD_RW=1;

LCD_DB=0xff;

LCD_E=1;

while(LCD_DB^7==1);

******************************/

//********延时函数***************

void delay(uint n)

{ uint i;

uchar j;

for(i=n;i>0;i--)

for(j=0;j<2;j++); //在这个延时循环函数中我只做了2次循环,

} //实践证明我的LCD1602 上普

//通的指令只需1次循环就能可靠完成。

//*******************************

//*********主函数*****************

void main(void)

{

while(1)

{

uint i;

LCD_init();

while(1)

{

for (i=0;i<12;i++)//陕字上半部

{

cs1=1;

cs2=0;

LCD_disp_char(0,i+36+4,kk[i]);//加36是显示起始位置左移,因为一个汉字的宽度为12

delay(500);

}

for (i=12;i<24;i++)//陕字下半部

{

cs1=1;

cs2=0;

LCD_disp_char(1,i+24+4,kk[i]);

delay(500);

}

for (i=0;i<12;i++)//西上

{

cs1=1;

cs2=0;

LCD_disp_char(0,i+48+4,xi[i]);

delay(500);

}

for (i=12;i<24;i++)//西下

{

cs1=1;

cs2=0;

LCD_disp_char(1,i+36+4,xi[i]);

delay(500);

}

for (i=0;i<12;i++)//电上

{

cs1=0;

cs2=1;

LCD_disp_char(0,i,dian[i]);

delay(500);

}

for (i=12;i<24;i++)//电下

{

cs1=0;

cs2=1;

LCD_disp_char(1,i-12,dian[i]);

delay(500);

}

for (i=0;i<12;i++)//子上

{

cs1=0;

cs2=1;

LCD_disp_char(0,i+12,zi[i]);

delay(500);

}

for (i=12;i<24;i++)//子下

{

cs1=0;

cs2=1;

LCD_disp_char(1,i,zi[i]);

delay(500);

}

/**************************************/

for (i=0;i<12;i++)//ke上

{

LCD_disp_char(0,i+24,ke[i]);

delay(500);

}

for (i=12;i<24;i++)//ke下

{

LCD_disp_char(1,i+12,ke[i]);

delay(500);

}

for (i=0;i<12;i++)//ji上

{

cs1=1;

cs2=0;

LCD_disp_char(3,i+48+4,ji[i]);

delay(500);

}

for (i=12;i<24;i++)//ji下

{

LCD_disp_char(4,i+36+4,ji[i]);

delay(500);

}

for (i=0;i<12;i++)//xue上

{

cs1=0;

cs2=1;

LCD_disp_char(3,i+24-24,xue[i]);

delay(500);

}

for (i=12;i<24;i++)//xue下

{

LCD_disp_char(4,i+12-24,xue[i]);

delay(500);

}

for (i=0;i<12;i++)//yuan上

{

cs1=0;

cs2=1;

LCD_disp_char(3,i+36-24,yuan[i]);

delay(500);

}

for (i=12;i<24;i++)//下

{

LCD_disp_char(4,i+24-24,yuan[i]);

delay(500);

}

for (i=0;i<12;i++)//yu上

{

cs1=1;

cs2=0;

LCD_disp_char(6,i+48+4,yu[i]);

delay(500);

}

for (i=12;i<24;i++)//yu下

{

LCD_disp_char(7,i-12+48+4,yu[i]);

delay(500);

}

for (i=0;i<12;i++)//老上

{

cs1=0;

cs2=1;

LCD_disp_char(6,i,lao[i]);

delay(500);

}

for (i=12;i<24;i++)//老下

{

LCD_disp_char(7,i-12,lao[i]);

delay(500);

}

for (i=0;i<12;i++)//shi上

{

cs1=0;

cs2=1;

LCD_disp_char(6,i+24-12,shi[i]);

delay(500);

}

for (i=12;i<24;i++)//shi下

{

LCD_disp_char(7,i-12+24-12,shi[i]);

delay(500);

}

LCD_write_command(0x01);

delay(10000);

}

}

}

2936547a77771607184bbd002cfb94bb.png

上一页

1

2

下一页

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值