DELAY1:
MOV R5,#05H
D2:MOV R7,#38H
D1:MOV R6,#0F9H
DJNZ R6,$
DJNZ R7,D1
DJNZ R5,D2
RET
END
把渗晌皮END放到最后试试。因为程序已经结束了,你又弄谨桥出个DELAY1这子程序出来,编译时,当然不认识了丛差。
1、首先我们打开Keil μVision编译器,新建一个工程,然后保存在硬盘上的位置,然后选择Atmel-AT89C51单片机为模型,并启动器添加STARTUP.A51文件,然后在当前目录下新建一个C文件,并将其添加入工作路径。
2、导入51单片机的头文件以及LCD1602的头文件。
3、创建一个延时函数,可以传入想要具体延时的时长,其内部实现是由一个二重循环,两个循环的次数悔知芦相乘积。
4、然后创建写命令的函数,指定RS和E同时为0时,才可以写入命令,设定完成后,将com写入输出端口,规定写命令时,E为正脉冲,然后空 *** 作一个机器周期等待机器反应。
5、然后创建写数据的函数,规定写数据时,E为正脉冲,规定当RS=1和RW=0时才可以写入数据,然后将数据从输出端口输出,最后让碧带E产生正跳变。
6、然后创建初始化LCD1602的函数,指定显示模式位两行显示,5*7,8位数据、整体显示,无光标,无闪烁、写入一个字符后地址指针加1,最后进行清屏 *** 作。
7、最后在主函数中首先执行LCD1602的初始化函数,首先创猛唤建一个无限循环,然后添加两个字符串,这里以两行显示百度经验的网址为例,再进行延时以及使用清屏函数进行刷新。
51单片机对lcd1602一些基础程序#include <intrins.h>
#define dataport P1
sbit RS=P2^ 6
sbit RW=P2^5
sbit EN=P2^4
//========================
//=========================
void waitfor() //检测忙信号函数
{
dataport=0xff
RS=0RW=1_nop_() //选择指令寄存器 读 *** 作
EN=1_nop_() //使能 *** 作
while(dataport&0x80) //如果最高位是1 表示1602正忙 原地踏步 忙完后芯片会将高位拉低
EN=0
}
//======================
void writedata(unsigned char dataw) //写数据到lcm
{
waitfor() //测忙
RS=1RW=0_nop_()//选择数据寄存老段器 写 *** 作
dataport=dataw_nop_()//将数据送到数据口
EN=1_nop_()_nop_()EN=0 //使能
}
//==========================
void writecmd(unsigned char cmd) //写命令到lcm
{
waitfor()
RS=0RW=0_nop_()
dataport=cmd_nop_()
EN=1_nop_()_nop_()EN=0
}
//===========================
void init(void) // 初始化函数
{
writecmd(0x38)//功能设定 8位数据传输 双行显示
writecmd(0x0c)//显示器开关
writecmd(0x01)//清屏
writecmd(0x06)//字符进入模式 每进入一个字符光标向右移动一格 原有字符不动
//我在刚开始学的时候历掘不知道下一个字符显示在哪 是和AC值有关还是和光标位置有关?
//最后摸索出来是只和光标定位有关 现在还是不知道Ac值有什么用
}
//=========================
void location(unsigned char x,unsigned char y) //确实坐标函数
{
unsigned char temp
temp=x&0x0f //只要x数据的后四位
if(y){temp=temp|0x40} //第侍烂誉一行为0 第二行为1 如果y=1则地址加0x40
temp|=0x80//DDRAM地址的命令DB7为一
writecmd(temp)
}
//==============================
void displyonechar(unsigned char x,unsigned char y,unsigned char dataw) //显示一个字符函数
{
location(x,y)
writedata(dataw)
}
//=======================================
void displylistchar(unsigned char x,unsigned char y,unsigned char *p) //显示字符串
{
while(*p) //当一个字符型数组读完时*P指的为零
{
displyonechar(x,y,*(p++))
x++
}
}
//=====================================================
void writecgram(unsigned char address,unsigned char *p)//写CGRAM的数据
{
unsigned char i=8
writecmd(address) //CGRAM里的地址 初始值0x40 每次加0x80
while(i--)
{
writedata(*p)
p++
}
}
//=====================================================
void displyonecharacter(unsigned char x,unsigned char y,unsigned char address,unsigned char *p) //显示一个自定义字符
{
unsigned char i=8
writecmd(address) //CGRAM里的地址 初始值0x40 每次加0x08
while(i--)
{
writedata(*p)
p++
}
//============================================================
location(x,y) //设定要显示的位置
writedata((address&=0x3f)/0x08)//要从CGRAM中读出数据在1602上显示 搞了半天发现CGRAM里的地址
} //和DDRAM里的地址有上面的转换关系
//========================================================
void displynumber(unsigned char x,unsigned char y,unsigned long num) //显示一个整数
{
unsigned int number[8]
int k,gh
for(k=0k++)
{
*(number+k)=(unsigned int)(num%10)//强制类型转换
num=num/10
if(num==0)break
}
for(gh=kgh>=0gh--)
{
displyonechar(x,y,(*(number+gh)+48))
x++
}
}
//字型码
uchar code nin[]={0x08,0x0f,0x12,0x0f,0x0a,0x1f,0x02,0x02}// "年"
uchar code yue[]={0x0f,0x09,0x0f,0x09,0x0f,0x09,0x0b,0x11}// "月"
uchar code ri[]={0x1f,0x11,0x11,0x1f,0x11,0x11,0x11,0x1f}// "日"
显示汉字
displyonecharacter(0,0,0x40,nin)
displyonecharacter(1,0,0x80,yue)
displyonecharacter(1,0,0xc0,ri)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)