|
網上找了LCD1602的驅動程序,幫你實現了這個功能,LCD1602的程序和LCD12864的差不多,下面附上程序和proteus仿真文件。
#include<reg52.h> //包含單片機寄存器的頭文件
#include <intrins.h>
sbit RS=P2^0;
sbit RW=P2^1;
sbit E =P2^2;
sbit BF=P0^7;
sbit key =P2^3;
unsigned char code digit[ ]={"0123456789"}; //定義字符數組顯示數字
/*****************************************************
函數功能:延時若干毫秒
入口參數:n
***************************************************/
void delay(unsigned char n)
{
unsigned char i;
for(i=0;i<n;i++)
;
}
/*****************************************************
函數功能:判斷液晶模塊的忙碌狀態
返回值:result。result=1,忙碌;result=0,不忙
***************************************************/
unsigned char BusyTest(void)
{
bit result;
RS=0; //根據規定,RS為低電平,RW為高電平時,可以讀狀態
RW=1;
E=1; //E=1,才允許讀寫
_nop_(); //空操作
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬件反應時間
result=BF; //將忙碌標志電平賦給result
E=0; //將E恢復低電平
return result;
}
/*****************************************************
函數功能:將模式設置指令或顯示地址寫入液晶模塊
入口參數:dictate
***************************************************/
void Write_LCD_command (unsigned char dictate)
{
while(BusyTest()==1); //如果忙就等待
RS=0; //根據規定,RS和R/W同時為低電平時,可以寫入指令
RW=0;
E=0; //E置低電平(根據表8-6,寫指令時,E為高脈沖,
// 就是讓E從0到1發生正跳變,所以應先置"0"
_nop_();
_nop_(); //空操作兩個機器周期,給硬件反應時間
P0=dictate; //將數據送入P0口,即寫入指令或地址
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬件反應時間
E=1; //E置高電平
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬件反應時間
E=0; //當E由高電平跳變成低電平時,液晶模塊開始執行命令
}
/*****************************************************
函數功能:將數據(字符的標準ASCII碼)寫入液晶模塊
入口參數:y(為字符常量)
***************************************************/
void Write_LCD_data(unsigned char value)
{
while(BusyTest()==1);
RS=1; //RS為高電平,RW為低電平時,可以寫入數據
RW=0;
E=0; //E置低電平(根據表8-6,寫指令時,E為高脈沖,
// 就是讓E從0到1發生正跳變,所以應先置"0"
P0=value; //將數據送入P0口,即將數據寫入液晶模塊
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬件反應時間
E=1; //E置高電平
_nop_();
_nop_();
_nop_();
_nop_(); //空操作四個機器周期,給硬件反應時間
E=0; //當E由高電平跳變成低電平時,液晶模塊開始執行命令
}
/*****************************************************
函數功能:對LCD的顯示模式進行初始化設置
***************************************************/
void LcdInitiate(void)
{
delay(15); //延時15ms,首次寫指令時應給LCD一段較長的反應時間
Write_LCD_command(0x38); //顯示模式設置:16×2顯示,5×7點陣,8位數據接口
delay(5); //延時5ms ,給硬件一點反應時間
Write_LCD_command(0x38);
delay(5);
Write_LCD_command(0x38); //連續三次,確保初始化成功
delay(5);
Write_LCD_command(0x0c); //顯示模式設置:顯示開,無光標,光標不閃爍
delay(5);
Write_LCD_command(0x06); //顯示模式設置:光標右移,字符不移
delay(5);
Write_LCD_command(0x01); //清屏幕指令,將以前的顯示內容清除
delay(5);
}
void main()
{
unsigned char i,j,add[2]={0x80,0xc0};
LcdInitiate();
Write_LCD_command(0x80);
Write_LCD_data(0x7e);
Write_LCD_data('u');
Write_LCD_command(0xc1);
Write_LCD_data('d');
while(1)
{
if(!key)
{
delay(5);
if(!key)
{
while(!key);
j=i;
i++;
if (i==2) i=0;
Write_LCD_command(add[i]);
Write_LCD_data(0x7e); //將字符常量t寫入LCD
Write_LCD_command(add[j]);
Write_LCD_data(' ');
}
}
}
}
|
-
無標題.png
(22.88 KB, 下載次數: 88)
下載附件
2017-3-29 20:59 上傳
-
-
仿真.zip
2017-3-29 21:00 上傳
點擊文件名下載附件
7.02 KB, 下載次數: 14
|