欢迎来到天天文库
浏览记录
ID:51469621
大小:453.50 KB
页数:13页
时间:2020-03-25
《单片机原理及应用课程设计电子时钟设计.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、单片机原理及应用课程设计姓名:学号:班级:电子时钟设计1.功能要求:时钟计时器要求用单片机及16位LCD数码显示时、分、秒,以24小时计时方式运行,使用按键开关可以实现时、分、秒调整。2.方案论证:为实现LCD显示器的数字显示,系统没有其他复杂的处理任务,所以采用动态扫描法实现LCD的显示。单片机采用AT89S52系列,这种单片机有足够的空余硬件资源,可以实现其他的扩展功能。电子时钟系统的总体设计框图如下:时钟系统的总体设计框图3.系统硬件电路的设计:电子时钟的硬件电路原理图、PCB图、3D电路板图和Proteus仿真电路图如下图所示,该电路采用AT89S52单片机最小化应用设计,采
2、用LCD液晶显示器;P0口输出段码数据,P2.0~P2.2做扫描输出,P1.0,P1.1和P1.2口接3个按钮开关,用于调试及功能设计;采用12MHz晶振,可提高秒计时的精确性;PCB电路板布线规则为线粗:0.5mm,有效间距:0.3mm,采用底面布线。时钟电路原理图PCB图3D电路版图4.系统程序的设计:主程序中计时采用定时器T0中断完成,秒表使用定时器T1完成,主程序循环调用显示子程序和查键子程序,当端口有开关按下时,转入相应功能子程序;时间显示子程序显示每次显示28个内存单元的字符和十进制BCD码数据,首地址在调用显示子程序时先指定。5.软、硬件调试:软件调试在KielC51编
3、译器下进行,最后可结合硬件实时调试;硬件调试可结合示波器测试晶振及P0、P2端口的波形情况进行综合硬件测试分析。6.单片机源程序:;*************C文件程序**************#include"reg51.h"#include"clock.h"main(){lcdinit();uartint();t0_init();while(1){keyscan();FloatToASCII();display();}};***************H文件程序******************#defineucharunsignedchar#defineuintunsign
4、edintucharaa[]={"time:16-37-00"};ucharbb[]={"Date:2009-11-05"};uinttim=0;uintsec=58;uintmin=59;uinthour=23;uintyear=2009;uintmonth=11;uintday=5;uintaddr;sbitrs=P2^0;sbitrw=P2^1;sbiten=P2^2;sbitkey0=P1^0;//调整位切换sbitkey1=P1^1;//加控制sbitkey2=P1^2;//减控制sbitkey3=P1^3;//显示模式转换uintmode=1;//mode=1为时钟显示,
5、mode=2为计时显示uintstation=0;//mode=1:station=1为时调整,station=2为分调整,station=3为秒调整,station=4为年调整,station=5为月调整,station=6为日调整voidwrcommand(uchardat);voidwrdata(uchardat);voiddelay(uintdat);voidlcd_string(uchar*p,charflag);voidwrcommand(uchardat){delay(300);rs=0;rw=0;en=1;P0=dat;en=0;}voidwrdata(ucharda
6、t){delay(300);rs=1;rw=0;en=1;P0=dat;en=0;}voiddelay(uintdat){while(dat--);}voidlcdinit(){wrcommand(0x01);wrcommand(0x38);wrcommand(0x06);wrcommand(0x0c);}voidlcd_string(uchar*p,charflag){if(flag==1){addr=0x80;while(*p!=' '){wrcommand(addr);wrdata(*p);addr++;p++;}}if(flag==2){addr=0xc0;while(*p
7、!=' '){wrcommand(addr);wrdata(*p);addr++;p++;}}}voidt0_init(void){TMOD=0x01;ET0=1;TH0=0X3C;TL0=0XB0;TR0=1;EA=1;}voidt0(void)interrupt1using2{tim=tim+1;if(tim==20){tim=0;sec=sec+1;if(sec==60){sec=0;min=min+1;if(min==60){min=0;hour
此文档下载收益归作者所有