1、基于单片机的多功能电子钟课程设计说明书山东建筑大学课 程 设 计 说 明 书题 目: 基于单片机的多功能电子钟课 程: 单片机原理及应用B课程设计院 (部): 信息与电气工程学院专 业: 电子信息工程班 级: 电信111 学生姓名: 姜庆飞学 号: 2011081197指导教师: 高焕兵完成日期: 2015年1月摘 要 II1 设计目的 12 设计要求 23 设计内容 33.1电子时钟的工作原理 33.2 系统硬件电路设计及元件 43.2.1 AT89C51芯片 43.2.2 DS1302芯片 83.2.3 LCD1602液晶显示 123.3系统软件电路设计 153.3.1 系统流程图及源代码
2、设计 15总结与致谢 18参考文献 19附录一 20摘 要单片机, 是集 CPU ,RAM ,ROM , 定时器,计数器和多种接口于一体的微控制器。自20 世纪 70 年代问世以来,以其极高的性能价格比,受到人们的重视和关注。它体积小、重量轻、抗干扰能力强、环境要求不高、价格低廉、可靠性高、灵活性好、开发较为容易,广泛应用于智能生产和工业自动化上。本系统为基于DS1302的多功能电子钟 ,以AT89C51单片机 作为主控芯, 采用实时时钟芯片DS1302,使用1602液晶作为显示输出。该系统走时精确,具有闹钟设置,时间模式切换,秒表以及可同时显示时间、日期等多种功能。本文将详细介绍AT89C5
3、1单片机和DS1302 时钟芯片的基本原理,从软件和硬件电路的实现两大方面进行分析。关键词:AT89C51;单片机;液晶屏;时钟芯片;蜂鸣器1 设计目的基于51单片机设计一个能够支持年、月、日、星期、时、分、秒的电子时钟。并且支持闹钟功能,及整点报时功能。在设计过程中,学习利用DXP软件进行硬件电路设计或者利用仿真软件进行仿真,进行单片机的软件编程。学习芯片的选择及方案选择,熟悉单片机的I/O口原理;掌握LCD显示的原理;掌握定时计数器的使用;要求设计出程序流程图和程序。2 设计要求1设计能支持年、月、日、星期、时、分、秒的时钟,时钟有时间调整功能及闹钟功能;2时钟具有装卸电池时掉电保护功能,
4、保护时间大于5分钟;3时钟功耗小于0.5MA/5V。4能够提供生日提醒指示;能够每天提供3个时间点的闹钟报时功能;5非易失定时闹铃6整点报时3 设计内容3.1电子时钟的工作原理本次设计时钟电路,使用了AT89C51单片机芯片控制电路,单片机控制电路简单且省去了很多复杂的线路,使得电路简明易懂,用C语言程序来控制整个时钟的显示,使得编程变得更容易,这样通过五个模块:芯片、显示屏、看门狗、电源、时钟即可满足设计要求。此设计原理图框图如图3.1所示,此电路包括以下五个部分:单片机、时钟电路、看门狗、液晶屏、电源模块、时钟振荡电路。图3.1 主电路设计框图本设计采用C语言程序设计,使单片机控制液晶显示
5、年、月、日、时、分、秒,当秒计数满60时就向分进位,分计数器计满60后向时计数器进位,小时计数器按“23翻0”规律计数。时、分、秒的计数结果经过数据处理可直接送显示器显示。当计时发生误差的时候可以用校时电路进行校正。设计采用的是时、分、秒显示,单片机对数据进行处理同时在LCD上显示。3.2 系统硬件电路设计及元件3.2.1 AT89C51芯片AT89C51 是美国ATMEL 公司生产的8 位Flash ROM 单片机。其最突出的优点是片内ROM 为Flash ROM,可擦写1000 次以上,应用并不复杂的通用ROM 写入器就能方便的擦写,读取也很方便,价格低廉,具有片程序ROM 二级保密系统。
6、因此可灵活应用于各种控制领域。AT89C51 包含以下一些功能部件:(1)一个8 位CPU ;(2)一个片内振荡器和时钟电路;(3)4KB Flash ROM ;(4)128B 内RAM;(5)可寻址64KB 的外ROM 和外RAM 控制电路;(6)两个16 位定时/计数器;(7)21 个特殊功能寄存器;(8)4 个8 位并行I/O 口;(9)一个可编程全双工串行口;(10)5 个中断源,可设置成2 个优先级。AT89C51 单片机一般采用双列直插DIP 封装,共40 个引脚,图3.2 为其引脚排列图。40 个引脚大致可分为4 类:电源、时钟、控制各I/O 引脚。图3.2 AT89C51引脚图
7、(1)控制线控制线共有4 根,其中3 根是复用线。所谓复用线是指具有两种功能,正常使用时是一种功能,在某种条件下是另一种功能。1、ALE/ PROG 地址锁存允许/片内EPROM 编程脉冲。(1)ALE 功能:用来锁存P0 口送出的低八位地址。AT89C51 在并行扩展外存储器时,P0 口用于分时传送低8 位地址和数据信号,且均为二进制数。当ALE 信号有效时,P0 口传送的是低8 位地址信号;ALE 信号无效时,P0 口传送的是低8 位地址信号。在ALE 信号的下降沿,锁定P0 口传送的内容,即低8 位地址信号。需要指出的是,当CPU 不执行访问外RAM 指令,ALE 以时钟振荡频率1/6
8、的固定频率输出,因此ALE 信号也可作为外部芯片CLK 时钟或其他需要。但是,当CPU 执行MOVX 指令时,ALE 将跳过一个ALE 脉冲。(2) PROG 功能:片内EPROM 的芯片,在EPROM 编程期间,此引脚输入编程脉冲。2、PSEN 外ROM 读选通信号。89C51 读外ROM 时,每个机器周期内PSEN 两次有效输出。PSEN 可作为外ROM芯片输出允许OE 的选通信号。在读内ROM 或读外RAM 时, PSEN 无效。3、RST/VPD复位/备用电源。(1)正常工作时,RST 端为复位信号输入端,只要在该引脚上连续保持两个机器周期以上高电平,AT89C51 芯片即实现复位操作
9、,复位后一切从头开始,CPU 从0000H 开始执行指令。(2)VPD 功能:在VCC 掉电情况下,该引脚可接上备用电源,由VPD 向片内RAM供电,以保持片内RAM 中的数据不丢失。4、EA /VPP内外ROM 选择/片内EPROM 编程电源。(1) EA 功能:正常工作时, EA 为内外ROM 选择端。AT89C51 单片机ROM 寻址范围为64KB,其中4KB 在片内,60KB 在片外。当EA 保持高电平时,先访问内ROM,但当PC 值超过4KB 时,将自动转向执行外ROM 中的程序。当EA 保持低电平时,则只访问外ROM,不管芯片内有否内ROM。(2)VPP 功能:片内有EPROM 的
10、芯片,在EPROM 编程期间,此引脚用于施加编程电源。(2) I/O引脚AT89C51 有P0、P1、P2、P3 4 个8 位并行I/O 端口,共32 个引脚。P0 口是一组8 位漏级开路型双向I/O 口,也即地址/数据总线复用口。作为输出口用时,每位能以吸收电流的方式驱动8 个TTL 逻辑门电路,对端口写1 时,又可作高阻抗输入端用。在访问外部程序和数据存储器时,它是分时多路转换的地址(低8 位)/数据总线,在访问期间激活了内部的上拉电阻。在Flash 编程时,P0 端口接收指令字节;而在验证程序时,则输出指令字节。验证时,要求外接上拉电阻。P1口是带内部上拉电阻的双向I/O口,向P1口写入
11、1时P1口被内部上拉为高电平,可用作输入口。当作为输入脚时被外部信号拉低的P1口会因为内部上拉而输出一个电流。Flash编程和程序校验期间,P1接收低8位地址。P2口是带内部上拉电阻的双向I/O口,向P2口写入1时P2口被内部上拉为高电平可用作输入口,当作为输入脚时被外部拉低的P2口会因为内部上拉而输出电流。在访问外部程序存储器或16位地址的外部数据存储器(例如执行MOVX DPTR指令)时,P2口送出高8位地址数据,当使用8位寻址方式(MOVXRI)访问外部数据存储器时,P2口发送P2特殊功能寄存器的内容,在整个访问期间不改变。Flash编程和程序校验时,P2也接收高位地址和一些控制信号。P
12、3口是带内部上拉电阻的双向I/O口,向P3口写入1时P3口被内部上拉为高电平可用作输入口,当作为输入脚时被外部拉低的P3口会因为内部上拉而输出电流。P3口除了作为一般的I/O口线外,更重要的是它的第二功能,如表3-1所示:表3-1 P3端口的特殊功能 端口引脚兼 用 功 能 P3.0RXD 串行输入口 P3.1TXD 串行输出口 P3.2/INT0 外部中断0 P3.3/INT1 外部中断1 P3.4T0 定时器0的外部输入 P3.5T1 定时器1的外部输入 P3.6/WR 外部数据存储器写选通 P3.7/RD 外部数据存储器读选通 3.2.2 DS1302芯片DS1302是美国DALLAS公
13、司推出的一种高性能、低功耗的实时时钟日历芯片,附加31字节静态RAM,采用SPI三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号和RAM数据。实时时钟可提供秒、分、时、日、星期、月和年,一个月小于31天时可以自动调整,且具有闰年补偿功能。工作电压宽达2.55.5V。采用双电源供电(主电源和备用电源),可设置备用电源充电方式,提供了对后备电源进行涓细电流充电的能力。有主电源和备份电源双引脚,而且备份电源可由大容量电容(1F)来替代。需要强调的是,DS1302需要使用32.768KHz的晶振。DS1302 包含以下一些功能部件:(1)实时时钟,可对秒、分、时、日、周、月以及
14、带闰年补偿的年进行计数;(2)用于高速数据暂存的318位RAM;(3)最少引脚的串行I/O;(4)2.55.5V 电压工作范围;(5)2.5V时耗电小于300nA;(6)用于时钟或RAM数据读/写的单字节或多字节(脉冲方式)数据传送方式;(7)简单的3线接口;(8)可选的慢速充电(至VCC1)的能力。(1) DS1302数据操作原理DS1302在任何数据传送时必须先初始化,把RST脚置为高电平,然后把8位地址和命令字装入移位寄存器,数据在SCLK的上升沿被输入。无论是读周期还是写周期,开始8位指定40个寄存器中哪个被访问到。在开始8个时钟周期,把命令字节装入移位寄存器之后,另外的时钟周期在读操
15、作时输出数据,在写操作时写入数据。时钟脉冲的个数在单字节方式下为8加8,在多字节方式下为8加字节数,最大可达248字节数。DS1302的内部结构图如图3.3所示。图3.3 DS1302内部结构图(2) DS1302 的引脚图及功能DS1302 的引脚图如图3.4所示。图3.4 DS1302引脚图DS1302 各引脚功能:Vcc1:主电源;Vcc2:备份电源。当Vcc2Vcc1+0.2V时,由Vcc2向DS1302供电,当Vcc2 Vcc1时,由Vcc1向DS1302供电。 SCLK:串行时钟,输入,控制数据的输入与输出; I/O:三线接口时的双向数据线; CE:输入信号,在读、写数据期间,必须
16、为高。该引脚有两个功能:第一,CE开始控制字访问移位寄存器的控制逻辑;其次CE提供结束单字节或多字节数据传输的方法。引脚功能如表3-2所示:表3-2 DS1302引脚功能说明引脚号名称功能1VCC1备份电源输入2X132.768KHz晶振输入3X232.768KHz晶振输出4GND地5RST控制移位寄存器/复位6I/O数据输入/输出7SCLK串行时钟8VCC2主电源输入(3) DS1302的控制字DS1302的控制字如表3-3所示:表3-3控制字(即地址及命令字节) 765432101RAMA4A3A2A1A0RD控制字的最高有效位(位7)必须是逻辑1,如果它为0,则不能把数据写入到DS130
17、2中。位6:如果为0,则表示存取日历时钟数据,为1表示存取RAM数据;位5至位1(A4A0):指示操作单元的地址;位0(最低有效位):如为0,表示要进行写操作,为1表示进行读操作。控制字总是从最低位开始输出。在控制字指令输入后的下一个 SCLK时钟的上升沿时,数据被写入 DS1302,数据输入从最低位(0位)开始。同样,在紧跟8位的控制字指令后的下一个 SCLK脉冲的下降沿,读出 DS1302的数据,读出的数据也是从最低位到最高位。(4) DS1302时序CE 输入驱动高启动所有的数据传输。CE 输入有两个功能。首先,CE打开控制逻辑,允许访问的移位寄存器的地址/命令序列。其次,CE 提供了一
18、个终止单字节或多字节数据传输方法。一个时钟周期是由一个下降沿之后的上升沿序列。对于数据传输而言,数据必须在有效的时钟的上升沿输入,在时钟的下降沿输出。如果CE 为低,所有的I/O 引脚变为高阻抗状态,数据传输终止。对于数据输入:开始的8个SCLK 周期,输入写命令字节,数据字节在后8个SCLK 周期的上升沿输入。数据输入位0 开始。对于数据输出:开始的8个SCLK 周期,输入一个读命令字节,数据字节在后8个SCLK 周期的下降沿输出。注意,第一个数据字节的第一个下降沿发生后,命令字的最后一位被写入,命令字节的最后一位被写入。当CE 仍为高时。如果还有额外的SCLK 周期,DS1302 将重新发
19、送数据字节,这使DS1302 具有连续突发读取的能力。DS1302数据读写时序如图3.5所示:图3.5 数据读写时序3.2.3 LCD1602液晶显示LCD1602是一种用5x7点阵图形来显示字符的液晶显示器模块,它显示的容量为2行16个字共32个字符。它由若干个57或者511点阵字符位组成,每个点阵字符位都可以显示一个字符。模块采用数字式接口,能够方便地与单片机等控制类芯片进行通信。由于其具有体积小、重量轻、显示质量高、功耗低等诸多优点而被广泛用于智能化仪器仪表的显示器件。(1)LCD1602引脚及功能LCD1602的引脚如图3.6所示:VSS:电源地。VDD:接电源正极。VL:液晶显示偏压
20、信号。RS:数据/命令选择端(H/L)。:读/写选择端(H/L)。E:使能端。当E端由高电平跳变成低电平时,液晶模块执行命令。D1D8:8位双向数据线。 BLA:背光源正极;BLK:背光源负极。图3.6 LCD1602引脚图LCD1602引脚功能表如下表3-4所示:表3-4 LCD1602引脚功能表编号符号引脚说明编号符号引脚说明1VSS电源地9D2数据2VDD电源正极10D3数据3VL液晶显示偏压11D4数据4RS数据/命令选择12D5数据5R/W读/写选择13D6数据6E使能信号14D7数据7D0数据15BLA背光源正极8D1数据16BLK背光源负极液晶显示模块是一个慢显示器件,所以在执行
21、每条指令之前一定要确认模块的忙标志位是不是为低电平,是低电平则表示不忙,否则此指令失效。要显示字符时要先输入显示字符地址,也就是告诉模块在哪里显示字符。表3-5为 LCD1602的内部显示地址。表3-5 LCD1602的内部显示地址123141516第一行80H81H82H8DH8EH8FH第二行0C0H0C1H0C2H0CDH0CEH0CFH3.3系统软件电路设计3.3.1 系统流程图及源代码设计(1) 主程序流程图设计3.7 主程序流程图(2)子程序流程图设计1、DS1302 定时器中断子程序流程图图3.8 DS1302中断流程图程序主要实现对DS1302写保护、充电,对年、月、日、时、分
22、、秒等寄存器的读写操作。在读写操作子程序中都执行了关中断指令,因为在串行通信时对时序要求比较高,而且在此是用I/O口软件模拟串行时钟脉冲,所以在通信过程中最好保证传输的连续性,不要允许中断,如图3.8所示。2、LCD1602 流程图程序主要实现对信息的显示,包括年、月、日、时、分、秒等信息,在这里要注意它的读写控制指令。其流程图如图3.9所示。 图3.9 LCD1602初始化流程图总结与致谢通过这次对基于单片机的电子时钟设计的设计与制作过程,加强了我们动手、思考和解决问题的能力。在设计过程中我们利用Altium软件进行原理图及PCB图的绘制,最后再利仿真软件进行检查,看程序是否能显示其功能。在
23、设计过程中让我进一步深刻的学习各种软件的利用以及各种软件给我们带来的便利。通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,可以说得是困难重重,难免会遇到过各种各样的问题,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。这次课程设计终于顺利完成了,在设计中遇到了很多专业知识问题,最后在老师的辛勤指导下,终于游逆而解。同时,在老师的身上我们学也到很多实用的知识,在次我们表示感谢!同时
24、,对给过我帮助的所有同学和各位指导老师再次表示忠心的感谢!参考文献1 马潮. AVR单片机嵌入式系统原理与应用实践 M.北京: 北京航空航天大学出版社,2007.2 杨欣,王玉凤,刘湘黔. 51单片机应用从零开始 M.北京: 清华大学出版社,2008.3 陈在平. 现场总线及工业控制网络技术M.北京: 电子工业出版社,2008.4 沈建华,杨艳琴. MSP430系列16位超低功耗单片机原理与实践M. 北北京航空航天大学出版社,2008.5 张成伟. 基于嵌入式Linix的GSM/GPRS无线通信模块的设计与实现D. 华中科技大学6 赵亮GPRS无线网络在远程数据采集中的应用计算机工程与设计.2
25、005. 26(9).7 马忠梅.单片机的C语言应用程序设计M.北京:北京航空航天大学出版社,2003. 8 胡汉才.单片机原理及其接口技术M.北京:清华大学出版社,2004.9 雷霖. 现场总线及工业控制网络技术M.北京: 电子工业出版社,2004. 10 许洪华. 现场总线与工业以太网技术M. 北京: 电子工业出版社,2007. 附录一#include #include/*/#define uchar unsigned char #define uint unsigned int#define TIME (0X10000-50000)#define FLAG 0XEF /闹钟标志/*/引脚
26、连接图sbit CLK=P12;sbit DAT=P13;sbit RST=P14;sbit RS=P15;sbit RW=P16;sbit E=P17;sbit P33=P33;sbit KEY1 = P20;sbit KEY2 = P21;sbit KEY3 = P22;sbit KEY4 = P23;/*/全局变量及常量定义uchar i=20,j;uchar DataBuf16 = ;/日期uchar TimeBuf16 = ;/时间 uchar alarm2,time3;uchar code Day=31,28,31,30,31,30,31,31,30,31,30,31;/12个月的
27、最大日期(非闰年) /闰年月星期表 const unsigned char WeekTab = (3 5) + 31,/1月 (6 5) + 29,/2月 (0 5) + 31,/3月 (3 5) + 30,/4月 (5 5) + 31,/5月 (1 5) + 30,/6月 (3 5) + 31,/7月 (6 5) + 31,/8月 (1 5) + 30,/9月 (4 5) + 31,/10月 (0 5) + 30,/11月 (2 5) + 31 /12月 ; /音律表uint code table1=64260,64400,64524,64580,64684,64777,64820,6489
28、8,64968,65030,65058,65110,65157,65178,65217;/发声部分的延时时间uchar code table2=0x82,1,0x81,0xf4,0xd4,0xb4,0xa4,0x94,0xe2,1,0xe1,0xd4,0xb4,0xc4,0xb4,4,0;/闹钟中用的全局变量uchar th1,tl1;/*/延时1ms函数delay1ms(uchar time) uchar i,j; for(i=0;itime;i+) for(j=0;j250;j+); /*/LCD控制函数Enable() RS=0; RW=0; E=0; delay1ms(3); E=1;/*/LCD1602写入字符函数LCD1602_WriteSChr(uchar i) P0=i; RS=1; R
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1