ImageVerifierCode 换一换
格式:DOCX , 页数:28 ,大小:670.73KB ,
资源ID:7364565      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7364565.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(单片机课程设计万年历.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

单片机课程设计万年历.docx

1、单片机课程设计万年历单片机系统课 程 设 计成绩评定表设计课题 : 万年历 学院名称 : 电气工程学院 专业班级 : 学生姓名 : 学 号 : 指导教师 : 设计地点 : 设计时间 : 指导教师意见:成绩: 签名: 年 月 日单片机系统课 程 设 计课程设计名称: 万年历 专 业 班 级 : 学 生 姓 名 : 学 号 : 指 导 教 师 : 课程设计地点: 课程设计时间: 单片机系统 课程设计任务书学生姓名专业班级学号题 目课题性质工程设计课题来源选题指导教师主要内容(参数)1、 显示阳历年、月、日、时、分、秒、星期2、 可用按键对时间、日期进行调整任务要求(进度)第1-2天:熟悉课程设计任

2、务及要求,查阅技术资料,确定设计方案。第3-4天:按照确定的方案设计单元电路。要求画出单元电路图,元件及元件参数选择要有依据,各单元电路的设计要有详细论述。第5-6天:软件设计,编写程序。第7-8天:实验室调试。第9-10天:撰写课程设计报告。要求内容完整、图表清晰、文理流畅、格式规范、方案合理、设计正确,篇幅合理。主要参考资料1 张迎新单片微型计算机原理、应用及接口技术(第2版)M北京:国防工业出版社,20042伟福LAB6000系列单片机仿真实验系统使用说明书3 阎石数字电路技术基础(第五版)北京:高等教育出版社,2006审查意见系(教研室)主任签字: 年 月 日 摘 要:随着当今世界经济

3、的快速发展和信息化时代的来临,各种各样的小型智能家电产品陆续出现在我们的生活中。日历是人们不可或缺的日常用品。但一般日历都为纸制用品,使用不便,寿命不长。电子万年历采用智能电子控制和显示技术,改善了纸制日历的缺陷。本设计以AT89C52单片机为核心,构成单片机控制电路,结合DS1302时钟芯片,完成时间的调整和掉电保护,全部信息用LED数码管显示。时间、日期调整由按键来实现。日历能显示阳历和时、分、秒。关键词:万年历;52系列单片机;时钟芯片1 概述在日新月异的21世纪里,家用电子产品得到了迅速发展。许多家电设备都趋于人性化、智能化,这些电器设备大部分都含有CPU控制器或者是单片机。单片机以其

4、高可靠性、高性价比、低电压、低功耗等一系列优点,近几年得到迅猛发展和大范围推广,广泛应用于工业控制系统、通讯设备、日常消费类产品和玩具等。并且已经深入到工业生产的各个环节以及人民生活的各个方面,如车间流水线控制、自动化系统等、智能型家用电器(冰箱、空调、彩电)等。用单片机来控制的小型家电产品具有便携实用,操作简单的特点。本文设计的电子万年历属于小型智能家用电子产品。利用单片机进行控制,实时时钟芯片进行记时,外加掉电存储电路和显示电路,可实现时间的调整和显示。电子万年历既可广泛应用于家庭,也可应用于银行、邮电、宾馆、医院、学校、企业、商店等相关行业的大厅,以及单位会议室、门卫等场所。因而,此设计

5、具有相当重要的现实意义和实用价值。2 总体方案设计由于现在市面上的电子万年历的种类比较多,因此到底选择什么样的方案在设计中是至关重要的。正确地选择方案就可以使产品更加人性化,并且可以减小开发的难度,缩短开发的周期,降低产品的成本等等,因此就会被人们普遍接受,并且能够更快地将产品推向市场实现其自身的价值。下面我们就拟订了两种方案,希望能够选择一种性价比高的方案。2.1 方案1基于AT89C52单片机的万年历设计不使用时钟芯片,而直接用AT89C52单片机来实现电子万年历设计。AT89C52是一种带8K字节闪烁可编程可擦除只读存储器的低电压,高性能CMOS 8位微处理器,俗称单片机。单片机的可擦除

6、只读存储器可以反复擦写1000余次。由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C52是一种高效微控制器,为很多嵌入式控制系统提供了一种灵活性高且价廉的方案。若采用单片机计时,利用它的一个16位定时器/计数器每50ms产生一个中断信号,中断20次后产生一个秒信号,然后根据时间进制关系依次向分、时、日、星期、月、年进位。这样就实现了直接用单片机来实现电子万年历设计。用单片机来实现电子万年历设计,无须外接其他芯片,充分利用了单片机的资源。但是精度不够高,误差较大,掉电后丢失所有数据,软件编程较复杂。2.2 方案2基于AT89C52单片机和DS1302的万年历设计在以单片

7、机为核心构成的装置中,经常需要一个实时的时钟和日历,以便对一些实时发生事件记录时给予时标,实时时钟芯片便可起到这一作用。过去多用并行接口的时钟芯片,如MC146818,DS12887等。它们已能完全满足单片机系统对实时时钟的要求,但是这些芯片与单片机接口复杂、占用地址, 数据总线接线多、芯片体积大占用空间多、近年来串行接口的各种芯片在单片机系统中应用愈来愈多,串行接口的实时时钟芯片也出现了不少,DS1302是一个综合性能较好且价格便宜的串行接口实时时钟芯片。利用单片机进行控制,采用DS1302作为实时时钟芯片,其三线接口 SCLK、I/O、 与单片机进行同步通信,外加掉电存储电路、显示电路、键

8、盘电路,即构成一个基本的电子万年历系统,若还要添加其他功能,在这基础上外扩电路即可。由于在系统设计时,需要考虑以下几点因素:功耗低、精确度高、软件编程较简单,芯片的体积小、芯片成本低等,而DS1302芯片有上面所述的诸多优点,所以本设计采用方案2基于DS1302的电子万年历设计。2.3 总体方案本设计以AT89C52单片机为核心,构成单片机控制电路,结合DS1302时钟芯片,显示阳历的年、月、日、星期、时、分、秒同时完成对它们的手动调整和掉电保护,全部信息用8位八段数码管显示出来。输入接口由按键来实现,用按键可以对日期和时间进行调整。整机电路使用+5V稳压电源,可稳定工作。其软硬件设计简单,时

9、间记录准确,可广泛应用于长时间连续显示的系统中。按照系统设计功能的要求,确定硬件系统由主控制器、时钟模块、显示模块、键盘接口共4个模块组成,总体系统构成框图如图2-1所示。图2-1 电子万年历系统构成框图3 硬件电路设计电子万年历电路原理图见附录B,系统由主控制器AT89C52、时钟芯片DS1302、显示电路及键盘扫描电路组成。按照系统设计功能的要求,初步确定设计系统由主控模块、时钟模块、显示模块、键盘接口模块组成。主控芯片使用52系列AT89C52单片机,时钟芯片使用美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟芯片DS1302, DS1302作为主要计时芯片,可以做到计时

10、准确。更重要的是,DS1302可以在很小电流的后备 (2.55.5V电源,在2.5V时耗电小于300nA)下继续计时,并可编程选择多种充电电流来对后备电源进行慢速充电,可以保证后备电源基本不耗电。显示模块使用8位八段数码管,八段数码管虽然操作略显繁琐,但可视范围十分宽,而且经济实惠,也不需要复杂的驱动程序。键盘模块使用若干个独立按键即可。3.1 主控器 AT89C52ATMEL公司生产的AT89C52单片机采用高性能的静态80C51设计,由先进工艺制造,并带有非易失性Flsah程序存储器。它是一种高性能、低功耗的8位CMOS微处理芯片,市场应用最多。其引脚封装如图3-1所示。图3-1 AT89

11、C52引脚封装图3.1.1 AT89C52的主要性能8KB Flash ROM,可以檫写1000次以上,数据保存10年。256字节内部RAM。电源控制模式时钟可停止和恢复;空闲模式;掉电模式。 6个中断源。4个中断优先级。4个8位I/O口。全双工增强型UART。3个16位定时/计数器,T0、T1(标准80C51)和增加的T2(捕获和比较)。全静态工作方式:024MHz。3.1.2 AT89C52的引脚及其功能AT89C52单片机的管脚说明如下:(1) 主要电源引脚VCC 电源端GND 接地端(2) 外接晶体引脚XTAL1和XTAL2XTAL1 接外部晶体的一个引脚。在单片机内部,它是构成片内振

12、荡器的反相放大器的输入端。当采用外部振荡器时,该引脚接收振荡器的信号,既把此信号直接接到内部时发生器的输入端。XTAL2 接外部晶体的另一个引脚。在单片机内部,它是上述振荡器的反相放大器的输出端。采用外部振荡器时,此引脚应悬浮不连接。(3)控制或与其它电源复用引脚RST、ALE/、和/VPP复位输入端。当振荡器运行时,在该引脚上出现两个机器周期的高电平将使单片机复位。ALE/当访问外部存储器时,ALE(地址锁存允许)的输出用于锁存地址的低位字节。即使不访问外部存储器,ALE端仍以不变的频率(此频率为振荡器频率的1/6)周期性地出现正脉冲信号。因此,它可用作对外输出的时钟,或用于定时目的。然而要

13、注意的是:每当访问外部数据存储器时,将跳过一个ALE脉冲。在对Flash存储器编程期间,该引脚还用于输入编程脉冲()。 程序存储允许()输出是外部程序存储器的读选通信号。当AT89S52/LV52由外部程序存储器取指令(或常数)时,每个机器周期两次有效(既输出2个脉冲)。但在此期间内,每当访问外部数据存储器时,这两次有效的信号将不出现。/VPP 外部访问允许端。要使CPU只访问外部程序存储器(地址为0000HFFFFH),则端必须保持低电平(接到GND端)。当端保持高电平(接VSS端)时,CPU则执行内部程序存储器中的程序。(4) 输入/输出引脚 P0.0 P0.7、P1.0P1.7、P2.0

14、 P2.7 和P3.0P3.7P0端口(P0.0 P0.7) P0是一个8位漏极开路型双向I/O端口。作为输出口用时,每位能以吸收电流的方式驱动8个TTL输入,对端口写1时,又可作高阻抗输入端用。P1端口(P1.0 P1.7) P1是一个带有内部上拉电阻的8位双向I/O端口。P1的输出缓冲器可驱动(吸收或输出电流方式)4个TTL输入。对端口写1时,通过内部的上拉电阻把端口拉到高电位,这时可用作输入口。作输入口时,因为有内部的上拉电阻,那些被外部信号拉低的引脚会输出一个电流。P2端口 (P2.0P2.7) P2是一个带有内部上拉电阻的8位双向I/O端口。P2的输出缓冲器可驱动(吸收或输出电流方式

15、)4个TTL输入。对端口写1时,通过内部的上拉电阻把端口拉到高电位,这时可用作输入口。P2作输入口使用时,因为有内部的上拉电阻,那些被外部信号拉低的引脚会输出一个电流。P3端口(P3.0P3.7) P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流,这是由于上拉的缘故。P3口也可作为AT89S52的一些特殊功能,这些特殊功能见表3-1。表3-1 P3端口的特殊功能 端口引脚 兼 用 功 能 P3.0RXD (串行输入口) P3.1TXD (串行输出口) P3.2 (

16、外部中断0) P3.3 (外部中断1) P3.4T0 ( 定时器0的外部输入) P3.5T1 (定时器1的外部输入) P3.6 (外部数据存储器写选通) P3.7 (外部数据存储器读选通)本系统即采用AT89C52作为主控芯片,本系统中其管脚分配如图3-2所示。其中VCC接5V稳压电源,GND接地,RST接复位电路,P3端口作为独立按键的接口,XTAL1,XTAL2接外部可换晶振,P0端口作为数据总线接到两片74LS573上作为其输入信号,P2.7口向DS1302提供CLK时钟信号,P2.6向DS1302提供I/O信号,P2.5口向DS1302提供RST复位/片选线信号,P2.4和P2.3口分

17、别向两片74LS573提供段选和片选信号。图3-2 主控芯片及其管脚分配3.2 时钟电路的设计3.2.1 DS1302的性能特性实时时钟,可对秒、分、时、日、周、月以及带闰年补偿的年进行计数;用于高速数据暂存的318位RAM;最少引脚的串行I/O;2.55.5V电压工作范围;2.5V时耗电小于300nA;用于时钟或RAM数据读/写的单字节或多字节(脉冲方式)数据传送方式;简单的3线接口;可选的慢速充电(至Vcc1)的能力。DS1302时钟芯片包括实时时钟/日历和31字节的静态RAM。它经过一个简单的串行接口与微处理器通信。实时时钟/日历提供秒、分、时、日、周、月和年等信息。对于小于31天的月和

18、月末的日期自动调整,还包括闰年校正的功能。时钟的运行可以采用24h或带AM(上午)/PM(下午)的12h格式。采用三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302有主电源/后备电源双电源引脚:Vcc1在单电源与电池供电的系统中提供低电源,并提供低功率的电池备份;Vcc2在双电源系统中提供主电源,在这种运用方式中,Vcc1连接到备份电,以便在没有主电源的情况下能保存时间信息以及数据。DS1302由Vcc1或Vcc2中较大者供电。当Vcc2大于Vcc1+0.2V时,Vcc2给DS1302供电;当Vcc2小于Vcc时, DS13026由Vcc1供电。

19、3.3.2 DS1302数据操作原理DS1302在任何数据传送时必须先初始化,把RST脚置为高电平,然后把8位地址和命令字装入移位寄存器,数据在SCLK的上升沿被输入。无论是读周期还是写周期,开始8位指定40个寄存器中哪个将被访问到。在开始8个时钟周期,把命令字节装入移位寄存器之后,另外的时钟周期在读操作时输出数据,在写操作是写入时写入数据。时钟脉冲的个数在单字节方式下为8加8,在多字节方式下为8加字节数,最大可达248字节数。如果在传送过程中置RST脚为低电平,则会终止本次数据传送,并且I/O引脚变为高阻态。上电运行时,在Vcc大于等于2.5V之前,RST脚必须保持低电平。只有在SCLK为低

20、电平时,才能将RST置为高电平。DS1302内部结构图如图3-3所示,表3-2为各引脚的功能。图3-3 DS1302内部结构表 3-2 DS1302引脚功能引脚号引脚名称功 能1Vcc2主电源2,3X1,X2振荡源,外界32.768kHz晶振4GND地线5RST复位/片选线6I/O串行数据输入/输出端(双向)7SCLK串行数据输入端8Vcc1后备电池DS1302的控制字如图3-4所示。控制字节的最高位(位7)必须是逻辑1;如果它为0,则不能把数据写入到DS1302中。位6如果为0,则表示存取日历时钟数据;为1表示存取RAM数据。位51(A4A0)指示操作单元的地址。最低有效位(位0)如为0,表

21、示要进行写操作;为1表示进行读操作。控制字节总是从最低位开始输入/输出。图3-4 DS1302的控制字为了提高对32个地址的寻址能力(地址/命令位15=逻辑1),可以把时钟/日历或RAM寄存器规定为多字节(burst)方式。位6规定时钟或RAM,而位0规定读或写。在时钟/日历寄存器中的地址931或RAM寄存器中的地址31不能寄存数据。在多字节方式中,读或写从地址0的位0开始。必须按数据传送的次序写最先的8个寄存器。但是,当以多字节方式写RAM时,为了传送数据不必写所有31字节。不管是否写了全部31字节,所写的每一字节都将传送至RAM。DS1302共有12个寄存器,其中有7个寄存器与日历、时钟相

22、关,存放的数据位为BCD码形式。其日历、时间寄存器及其控制字见表3-3,其中奇数为读操作,偶数为写操作。表3-3 内部寄存器地址和内容积存器名命令字节取值范围积存器内容写读76543210秒积存器80H81H0059CH10SSEC分积存器82H83H0059010 minMIN小时积存器84H85H0023或011212/24010A/PHRHR日积存器85H87H0128,29,30,310010DATEDATE月积存器88H89H011200010MMONTH周积存器8AH8BH010700000DAY年积存器8CHD3H009910YEARYEAR时钟暂停:秒寄存器的位7定义位时钟暂停

23、位。当它为1时,DS1302停止震荡,进入低功耗的备份方式。通常在对DS1302进行写操作时(如进入时钟调整程序),停止震荡。当它为0时,时钟将开始启动。AMPM/1224小时方式:小时寄存器的位7定义为12或24小时方式选择位。它为高电平时,选择12小时方式。在此方式下,位5是AM/PM位,此位是高电平时表示PM低电平表示AM。在24小时方式下,位5为第二个10小时位(2023h)。DS1302的晶震选用32.768kHz,电容推荐值为33pF,因为震荡频率较低,也可以不接电容,对计时精度影响不大。本系统即采用了DS1302时钟芯片,其外部电路如图3-5所示。其中VCC2接5V系统稳压电源,

24、VCC1接备用干电池,SCLK、I/O、RST端口与主控制器相对应的端口相连接,X1、X2外界晶振。图3-5 时钟电路3.3 显示电路的设计显示部分采用普通的共阴极数码管显示,采用动态扫描,以减少硬件电路。为了减少I/O接口,在使用两个LG3641共阴极数码管的情况下,采用2片74HC573分别作为数码管的驱动,输出位选和段选信号驱动数码管显示相应内容。数码管的一种是半导体发光器件,数码管可分为七段数码管和八段数码管,区别在于八段数码管比七段数码管多一个用于显示小数点的发光二极管单元DP(decimal point),其基本单元是发光二极管。本系统采用动态显示驱动。动态显示驱动是将所有数码管通

25、过分时轮流控制各个数码管的的COM端,就使各个数码管轮流受控显示。将所有数码管的8个显示笔划a,b,c,d,e,f,g,dp的同名端连在一起,另外为每个数码管的公共极COM增加位选通控制电路,位选通由各自独立的I/O线控制,当单片机输出字形码时,所有数码管都接收到相同的字形码,但究竟是那个数码管会显示出字形,取决于单片机对位选通COM端电路的控制,所以我们只要将需要显示的数码管的选通控制打开,该位就显示出字形,没有选通的数码管就不会亮。图3-6 74HC573引脚图74HC573包含八进制3态非反转透明锁存器,是一种高性能硅门CMOS器件。SL74HC573跟LS/AL573的管脚一样,其引脚

26、图见图3-6。器件的输入是和标准CMOS输出兼容的,加上拉电阻他们能和LS/ALSTTL输出兼容。当锁存使能端为高时,这些器件的锁存对于数据是透明的(也就是说输出同步)。当锁存使能变低时,符合建立时间和保持时间的数据会被锁存。本系统所采用的显示电路接线图如图3-7所示。其中,第一片74LS573作为数码管的段码驱动,输入端与单片机的P0口相连接,输出端接八位共阴数码管相应的段码输入端(a-dp),端口C与单片机相应的段码输出端相连接,VCC接主电源,GND、OC接地。相应的,第二片74LS573作为数码管的位码驱动,输入端与单片机的P0口相连接,输出端接八位共阴数码管相应的位码端口相连接,CC

27、接主电源,GND、OC接地。图3-7 数码管显示电路3.4 键盘接口的设计由于按键有8个,用普通按钮接10K上拉电阻,用查询法完成读键功能。其线路连接图下图所示。图3-8 按键电路4 系统软件设计本系统软件分为主程序、中断服务程序、子程序三个模块进行编写。由于本系统程序相对来讲比较简单,用轮询法对键盘进行反复扫描,用中断法进行数码管显示,每隔一段时间,定时器向CPU申请中断,调用中断服务子程序,根据当前的键值,显示日期、时间或者周秒。而子程序为一些常用的延时函数、显示函数等。4.1 主程序设计由于本系统程序相对来讲比较简单,主程序流程图如图4-1所示。系统上电启动后,定义后续过程中要使用到的全

28、局变量,对定时器和DS1302进行初始化之后,进入主循环对键盘进行扫描,若检测到有按键按下,进入相应的键处理程序;若没有检测到按键按下,继续扫描键盘。图4-1 主程序流程图4.2 中断服务程序设计定时器0定时时间到,向CPU申请中断而进入中断服务程序。进入中断服务程序后,先清中断标志位,再对定时器0赋初始值,接着调用数码管扫描子程序达到数码管动态显示的目的,延时100ms后,读标志位置1,这里的“读”是指从时钟芯片DS1302中读取相关数据。图4-2 中断服务程序流程图4.3 子程序设计4.3.1 延时子程序此延时子程序可用于对延时时间不是特别精确的场合,其程序流程图如图4-3所示,主体是一个

29、循环结构,先对t赋初始值255,通过循环执行“t-”指令而达到延时的目的。图4-3 延时子程序流程图4.3.2 数码管动态扫描子程序本系统使用8位八段共阴极数码管用于显示时间和日期,而74LS73作为数码管的驱动芯片,如要控制数码管的显示只需要用程序控制74LS73即可。子程序中定义i为需要显示的位数,通过对段码和位码的锁存达来到数码管动态显示的目的。图4-4 数码管动态扫描子程序流程图4.3.3 定时器初始化子程序首选选择定时器/计数器的工作方式为定时器0工作方式1,再对其赋初始值,然后打开总中断,打开定时器0中断,打开定时器0开关,定时器初始化工作完成。图4-5 定时器初始化子程序流程图4

30、.3.4 键盘扫描子程序键盘扫描用于向系统输入数据,其工作流程如图4-6所示。简单描述为:(1) 判断有无闭合键,若无则退出;(2) 延时10ms去抖动;(3) 再次判断有无闭合键,若无则退出;(4) 识别闭合键并取得键值;(5) 退出键盘扫描子程序。图4-6 键盘扫描子程序流程图4.3.5 显示子程序为了使主程序结构上更加紧凑和清晰,故将显示部分的程序代码单独拿出来定义为一个子函数来调用。其功能相对比较简单,将数据从时钟芯片取出来经过简单运算放入输出缓冲区。图4-7 显示子程序流程图5 系统调试与总结系统研制完成后,在自己的单片机开发板上进行了系统功能测试。系统上电后显示正常。按下按键K1,LED数码管能够在日期、时间之间切换显示;按下按键K3调节小时数值,其能够在0-23之间循环递增调节;按下按键K5调节分钟数值,其能够在0-59之间循环递增调节;按下按键K2,K4调节年份数值,按K2年份数值递增,按K4年份数值递减,年份可设定为0-99;按下按键K6可进行分钟数值的调节,调节范围为0-59;按下按

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1