- 1、本文档共8页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《单片机原理实验》
考
试
报
告
题 目:1602显示温度时钟及星期
1602显示温度时钟及星期
摘 要:本次实验利用STC89C51单片机作为控制器,通过keil编写程序,并且将生成hex文件写入单片机的内存中,实现对单片机的I/O口,液晶显示屏1602和温度传感器DS18B20操作,最终实现在液晶显示器1602上显示时钟,星期以及实时温度的功能。
关键词:STC89C52单片机,液晶显示器1602,DALLAS公司生产的DS18B20数字温度计,时钟,温度,星期
引言
在开始的时候只是想用1602显示成数字温度计,可是在做完温度计之后发现1602屏上还有足够的空间用来显示时钟,所以就在原来的数字温度的程序上进行了扩展,加入了时钟的显示程序以及星期的 显示程序。确定了要显示的内容之后,通过计算字符的个数,对要显示的东西进行了布局,使得其显示看起来比较协调美观。在做这个实验的时候,数字温度计的程序是最难的部分,我花了两天的时间把参考书上的一个用数码管显示温度的程序读懂,弄清楚DS18B20操作时序和数码管显示温度的基本步骤和原理之后,再结合我已经掌握的1602显示器的知识,尝试这把数码管显示改为1602显示,这个过程就是写这个程序最重要的地方,由于数码管显示原理与数码管显示原理完全不同,要进行比较大的调整,从写完这个程序和到完全调试好这个程序并且进行成功仿真花了大半天的时间。当我调试完了程序和仿真之后,我在面包板上用相应的元器件搭出了仿真时候的电路,当我把程序写入单片机内,1602显示的实验室温度为30.7。成功之后,我再把以前写过的数字钟的程序逐渐的移植到这个程序当中,并且重新设置相关的参数,经过半天的调试,最终取得了理想中的结果。
原理
使用的STC89c51单片机对所有的元器件进行控制。外接时钟信号的晶振的频率为12MHz,所以其机器周期为1us,在写数字钟的程序是用的是中断计时,因此赋的初值为(65536-50000),即为50ms,中断进行20次后就是一秒,因此也就可以实现比较精准的定时了。
温度传感器DS18B20采用的是单总线协议,与单片机连接只需要一个I/O端口就可以实现双向通信。它只有三个引脚,一个接高电平,一个接地,还一个就是单总线,在接单总线通常要求外接一个约为5k欧的电阻,仿真实验时我采用的是4.7k欧,搭建实物电路用的是4.3k欧。该单条信号线既可以传输时钟,又可以传输数据,而且数据传输是双向的,因而这种单总线控制技术具有线路简单硬件开销少,成本低廉,便于总线扩展和维护。
液晶显示屏1602可以显示两行字符,每行最多可以显示16个字符,液晶第3端为对比度调节端,通过一个10k欧的电位器接地来调节液晶显示器的对比度,在仿真时可以不接入,但是在搭建实物电路时必须接上,以免烧坏器件造成损失。
通过先学习以上元器件的工作原理及操作时序,然后在keil上编写出控制这些器件正常工作的程序,并且生成hex文件以供单片机识别和使用。
电路
程序
#includereg51.h
#includestdio.h
#define uchar unsigned char
#define uint unsigned int
uchar code T[]={Temp:};
uchar code *Day[7]={Mon,Tue,Wed,Thu,Fri,Sat,Sun};
uchar a[6]={0};
int num,s,f,m;
uint d=0;
sbit ds=P2^2;
sbit E=P3^4;
sbit RS=P3^5;
int temp;
float f_temp;
void delay()
{
uint x,y;
for(x=3;x0;x--)
for(y=110;y0;y--);
}
timer0() interrupt 1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
num++;
if(num=20){num=0;m=m+1;}
if(m=60){m=0;f=f+1;}
if(f=60){f=0;s=s+1;}
if(s==24){s=0;d++;}
if(d==6)d=0;
}
void reset(void)
{
uint i;
ds=0;
i=103;
while(i0)i--;
ds=1;
i=4;
while(i0)i--;
}
bit tempreadbit(void)
{
uint i;
bit dat;
ds=0;i++;
ds=1;i++;i++;
dat=ds;
i=8;while(i0)i--;
return(dat)
文档评论(0)