芯片厂家推荐的用法:
INT:
MOV
A,#30H
MOV
DATR,#CW_ADD
MOV
R2,#03H
INT1:
MOVX
@DPTR,A
CALL
DELAY
DJNZ
R2,INT1
这上面就是1602对于51单片机推荐的初始化之前加的三次模式设置
#include <string.h>sbit RS=P1^0
sbit RW=P1^1
sbit EN=P1^2
sbit DATA=P2 //定义LCD1602管脚
void lcd1602_display_str(unsigned char x,bit y,unsigned char dat[]) //x:列 0-15 y:行 0-1 dat写入的东西
void lcd1602_display_byte(unsigned char x,bit y,unsigned char ascll)
void lcd1602_init()
void lcd1602_write(bit sign, unsigned char dat) //sign=0 :写入命令 sign=1:写入数据
{
delay_1ms(1)
RS=sign
RW=0
EN=0
DATA=dat
EN=1
delay_1ms(1)
EN=1
RS=0
}
void lcd1602_init()
{
delay_1ms(10)
lcd1602_write(0,0x38)
lcd1602_write(0,0x38)
lcd1602_write(0,0x38)
lcd1602_write(0,0x0c)
lcd1602_write(0,0x01)
}
void lcd1602_display_str(unsigned char x,bit y,unsigned char dat[])
{
unsigned char point=0x80+x
unsigned char len=16
unsigned char j=0
if(y)
{point+=0x40}
lcd1602_write(0,point)
len=strlen(dat)
for(j=0j<lenj++)
{
lcd1602_write(1,dat[j])
}
}
void lcd1602_display_byte(unsigned char x,bit y,unsigned char ascll)
{
unsigned char point=0x80+x
if(y)
{point+=0x40}
lcd1602_write(0,point)
lcd1602_write(1,ascll)
}
以上是基础程序,也就是LCD1602的工作程序(注意我的延时函数未写出,请根据实际芯片的速度写延时函数)
unsigned char table[]=" Hello,World "lcd1602_init()
lcd1602_display_str(0,1,table)
以上是工作程序(显示字符串),注意的是LCD一行最多16个字符,而且不支持中文,这是在第一列第二行输出的Hello,World,包括空格,一共16个字符。
如果是STC89C52的话,可以使用以下的延时函数
void delay_1ms(unsigned int n){
unsigned int i=0,j=0
for(i=0i<ni++)
for(j=0j<110j++)
}
具体要求是什么,可以帮你完成。使用外部中断0,按1次加1并LCD显示#include "reg51.h"
#include "intrins.h"
typedef unsigned char BYTE
typedef bit BOOL
BYTE Time=0
sbit LCD_RS = P1^2
sbit LCD_RW = P1^1
sbit LCD_EP = P1^3
delay(int ms)
{ // 延时子程序
int i
while(ms--)
{
for(i = 0i<250i++)
{
_nop_()
_nop_()
_nop_()
_nop_()
}
}
}
BOOL lcd_bz()
{ // 测试LCD忙碌状态
BOOL result
LCD_RS = 0
LCD_RW = 1
LCD_EP = 1
_nop_()
_nop_()
_nop_()
_nop_()
result = (BOOL)(P0 &0x80)
LCD_EP = 0
return result
}
lcd_wcmd(BYTE cmd)
{ // 写入指令数据到LCD
while(lcd_bz())
LCD_RS = 0
LCD_RW = 0
LCD_EP = 0
_nop_()
_nop_()
P2 = cmd
_nop_()
_nop_()
_nop_()
_nop_()
LCD_EP = 1
_nop_()
_nop_()
_nop_()
_nop_()
LCD_EP = 0
}
lcd_pos(BYTE pos)
{ //设定显示位置
lcd_wcmd(pos | 0x80)
}
lcd_wdat(BYTE dat)
{ //写入字符显示数据到LCD
while(lcd_bz())
LCD_RS = 1
LCD_RW = 0
LCD_EP = 0
P2 = dat
_nop_()
_nop_()
_nop_()
_nop_()
LCD_EP = 1
_nop_()
_nop_()
_nop_()
_nop_()
LCD_EP = 0
}
lcd_init()
{//LCD初始化设定
lcd_wcmd(0x38) //16*2显示,5*7点阵,8位数据
delay(1)
lcd_wcmd(0x0c) //显示开,关光标
delay(1)
lcd_wcmd(0x06) //移动光标
delay(1)
lcd_wcmd(0x01) //清除LCD的显示内容
delay(1)
}
main()
{
EX0=1
EA=1
lcd_init() // 初始化LCD
delay(10)
while(1)
{
lcd_wcmd(0x06) //向右移动光标
lcd_pos(0) //设置显示位置为第一行的第1个字符
lcd_wdat(Time/10+0x30)
lcd_wdat(Time%10+0x30)
}
}
void M() interrupt 0
{
while(INT0==0)
Time++
if(Time==100)Time=0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)