基于51单片机抢答器毕业设计-毕业设计论文.doc

上传人:小小飞 文档编号:3919537 上传时间:2019-10-10 格式:DOC 页数:22 大小:416.52KB
返回 下载 相关 举报
基于51单片机抢答器毕业设计-毕业设计论文.doc_第1页
第1页 / 共22页
基于51单片机抢答器毕业设计-毕业设计论文.doc_第2页
第2页 / 共22页
基于51单片机抢答器毕业设计-毕业设计论文.doc_第3页
第3页 / 共22页
基于51单片机抢答器毕业设计-毕业设计论文.doc_第4页
第4页 / 共22页
基于51单片机抢答器毕业设计-毕业设计论文.doc_第5页
第5页 / 共22页
点击查看更多>>
资源描述

《基于51单片机抢答器毕业设计-毕业设计论文.doc》由会员分享,可在线阅读,更多相关《基于51单片机抢答器毕业设计-毕业设计论文.doc(22页珍藏版)》请在三一文库上搜索。

1、电子电路课程设计 基于单片机的简单抢答器 学 院 计算机科学与技术 专 业 计算机科学与技术 学 号 学 生 姓 名 指导教师姓名 2013 年 11 月 17 日 摘摘 要要 数字抢答器是由扩展电路和主体电路构成的。在显示器上输出的参赛队的输入信号是由优先编 码电路、锁存器和译码器电路等生成的;扩展电路是在显示器上输出实现计时功能,由定时电路、 译码电路将秒脉冲产生的信号构成。主体电路是由控制电路、主持人开关启动报警电路构成。数字 抢答器成形是经过布线、调试和焊接等工作。 单片机为了试外围电路的实现更加简单,简化了外围硬件电路,把很多任务都交给了软件编程。 单片机不仅应用方便,而且体积小价格

2、低,还很稳定可靠。 本设计是以八路抢答为基本理念。考虑到依需设定限时回答的功能,利用 AT89C51 单片机及外 围接口实现的抢答系统,利用单片机的定时器/计数器定时和记数的原理,将软、硬件有机地结合起 来,使得系统能够正确地进行计时,同时使数码管能够正确地显示时间。用开关做键盘输出,扬声 器发生提示。同时系统能够实现:在抢答中,只有开始后抢答才有效,如果在开始抢答前抢答为无 效;抢答限定时间和回答问题的时间可在 1-99s 设定;可以显示是哪位选手有效抢答和无效抢答, 正确按键后有音乐提示;抢答时间和回答问题时间倒记时显示,满时后系统计时自动复位及主控强 制复位;按键锁定,在有效状态下,按键

3、无效非法。 关键词:关键词:AT89C51 LED 数码管 抢答电路 定时电路 抢答电路 I 目目 录录 1 1 绪绪 论论1 2 2 实验目的和意义实验目的和意义1 3 3 抢答器的系统概述抢答器的系统概述2 3.13.1系统的主要功能系统的主要功能.2 3.23.2抢答器的工作过程抢答器的工作过程.3 3.33.3器件选型方案及详细清单器件选型方案及详细清单3 3.43.4AT89C51AT89C51 的功能及简介的功能及简介.4 3.53.5抢答器的优点及组成抢答器的优点及组成.5 4 4 系统总体方案的设计系统总体方案的设计.6 4.14.1 硬件电路的设计硬件电路的设计.6 4.24

4、.2 总体原理图总体原理图7 4.34.3 时钟频率电路的设计时钟频率电路的设计.8 4.44.4 复位电路的设计复位电路的设计.9 4.54.5 显示电路的设计显示电路的设计.9 4.64.6 键盘扫描电路的设计键盘扫描电路的设计.10 4.74.7 发声电路发声电路11 4.84.8 系统复位系统复位11 5 5 软件设计软件设计.12 5.15.1 软件设计流程图软件设计流程图.12 5.25.2 软件设计代码软件设计代码.13 6 6 总结总结16 参参 考考 文文 献献17 1 1 1绪绪 论论 抢答器是一种应用非常广泛的设备,在各种竞赛、抢答场合中,它能迅速、客观地分辨出最先 获得

5、发言权的选手。早期的抢答器只由几个三极管、可控硅、发光管等组成,能通过发光管的指示 辩认出选手号码。现在大多数抢答器均使用单片机(如MCS-51型)和数字集成电路,并增加了许多新 功能,如选手号码显示、抢按前或抢按后的计时、选手得分显示等功能。 本课题利用AT89C51单片机及外围接口实现的抢答系统,利用单片机的定时器/计数器定时和记 数的原理,将软、硬件有机地结合起来,使得系统能够正确地进行计时,同时使数码管能够正确地 显示时间和选手号码。用开关做键盘输出,扬声器发生提示。 2 实验目的和意义实验目的和意义 通过这次设计,掌握 51 单片机的原理,了解简单多功能抢答器组成原理,初步掌握多功能

6、抢答 器的调整及测试方法,提高动手能力和排除故障的能力。同时通过本课题设计与装配、调试,提高 自己的动手能力,巩固已学的理论知识,建立单片机理论和实践的结合,了解多功能抢答器各单元 电路之间的关系及相互影响,从而能正确设计、计算定时计数的各个单元电路。初步掌握多功能抢 答器的调整及测试方法。提高动手能力和排除故障的能力。 本系统采用模块化设计智能抢答器,在抢答比赛中广泛应用,各组分别有一个抢答按钮。主持 人有开始和结束、复位键。在后台主持人可以修改,抢答时间和选手回答问题的时间设置,原始状 态下抢答时间为 20s,回答问题时间为 30s。通过加键和减键修改上述时间,改完后结束键确定。新 时间开

7、始有效,主持人按键开始后,选手开始抢答为有效,数码显示屏显示抢答时间倒计时和选手 号,在最后五秒扬声器发生提示。如果主持人没有按下开始键而选手就抢答视为犯规,数码显示屏 显示犯规者的代号,扬声器持续发生。主持人可按键结束,新一轮抢答开始。 通过研究并在设计验证后发现,采用单片机技术设计的抢答器与目前常用的抢答器相比,首先, 电路连接简单,因为大多数功能单元都通过程序设计在单片机内部,第二,工作性能可靠,抗干扰 能力优于目前抢答器。所以本研究是一个实用的工程设计,具有创新性。 2 3 3抢答器的系统概述抢答器的系统概述 3.13.1系统的主要功能系统的主要功能 本系统是借用单片机采用模块化设计的

8、八路抢答器,包括 8 路抢答按纽、计时显示、提示功能 等(根据需要可另设或多设相关功能) 、开始与结束控制按钮、时限设定、各种相关显示调控功能等 (根据需要也可另设或多设相关功能) 。 参赛者系统,除享有抢答按纽的权利功能外,还有人性化的提示功能和时间提示功能,也可设 定由主控控制在参赛者终端表现的趣味性功能等;主控系统的控制按钮做开始与结束控制,根据活 动参赛者的层次,对提前抡答者的行为设定为非法或阻隔,若设有非法抢答控制功能时,在主控处 带有公示性显示的非法抡答者的台位号,对抢答限时及回答问题限时设为倒计时,并有显示提示。 系统的主要功能模块方框图如图 1 所示。 AT89C51 单片机

9、七段 数码 管显 示 声音电路 = 8 路抢答 按键输入 复位电路 开始、结束 按键输入 加一、减一 按键输入 时钟 图 1 系统主要功能模块 本系统采用模块化设计的八路抢答器,在抢答比赛中广泛应用,各组分别有一个抢答按钮。一 共有 8 个按键输入,分别对应 8 路选手的抢答按键。 主持人有开始和结束键。在后台主持人可以修改,抢答时间和选手回答问题的时间设置,原始 状态下抢答时间为 20s,回答问题时间为 30s。通过加键和减键修改上述时间,改完后结束键确定。 3 新时间开始有效,主持人按键开始后,选手开始抢答为有效,数码显示屏显示抢答时间倒计时和选 手号,在最后五秒扬声器发生提示。如果主持人

10、没有按下开始键而选手就抢答视为犯规,数码显示 屏显示犯规者的代号,扬声器持续发生。主持人可按键结束,新一轮抢答开始。 单片机是整个抢答器的核心,内部电路设计用汇编语言编写。它完成了时间参数的设定,抢按 号码的译码,保存;显示;输出,抢按及答题倒计时功能等。 抢答器的工作流程 抢答器的基本工作原理4:在抢答竞赛或呼叫时,有多个信号同时或不同时送入主电路中,抢 答器内部的寄存器工作,并识别、记录第一个号码,同时内部的定时器开始工作,记录有关时间并 产生超时信号。在整个抢答器工作过程中,显示电路、声音电路等还要根据现场的实际情况向外电 路输出相应信号。抢答器的工作流程分为:系统复位、正常流程、违例流

11、程等几部分,如图2所示, 下面分别予以介绍。 3.23.2抢答器的工作过程抢答器的工作过程 1、如果想调节抢答时间或答题时间,按“加一”键或“减一”键进入调节状态,此时会显示现 在设定的抢答时间或回答时间值,如想加一秒按一下“加 1s“键,如果想减一秒按一下“减 1s”键, 时间 LED 上会显示改变后的时间,调整范围为 099s, 0s 时再减 1s 会跳到 99,99s 时再加 1s 会变 到 0s。 2、主持人按“抢答开始“键,会有提示音,并立刻进入抢答倒计时(预设 20s 抢答时间) ,如有选 手抢答,会有提示音,并会显示其号数并立刻进入回答倒计时(预设 30s 抢答时间) ,不进行抢

12、答查 询,所以只有第一个按抢答的选手有效。倒数时间到小于 5s 会每秒响一下提示音。 3、如倒计时期间,主持人想停止倒计时可以随时按“停止”按键,系统会自动进入准备状态, 等待主持人按“抢答开始”进入下次抢答计时。 4、如果主持人未按“抢答开始”键,而有人按了抢答按键,犯规抢答,LED 上不断闪烁 FF 和 犯规号数并响个不停,直到按下“停止” 键为止。 总而言之,本课题利用AT89C51单片机及外围接口实现的抢答系统设计了抢答器,该抢答器增 加了新功能、提高了系统的可靠性、简化了电路结构、节约了成本,是一个实用的工程设计。 4 3.33.3器件选型方案及详细清单器件选型方案及详细清单 微控制

13、器选用 ATMAL 公司生产的 AT89C51,该芯片货源充足,并且价格也比较便宜。如表 1 所示。 表 1 器件选型方案的详细清单 元件名称型号数量/个用途元件名称型号数量/个用途 单片机AT89C511控制核心按键7选手输入 晶振12MHz1按键1 主持人输 入 电容30pF2 晶振电路 三极管2N39051 电解电容 10 1蜂鸣器1 按键1电阻 10k 1 蜂鸣器及 驱动电路 电阻 10k 1 复位电路 数码管1 位共阴1显示电路 电源5V1电源电路 3.43.4AT89C51AT89C51 的功能及简介的功能及简介 AT89C51 单片机是 ATMAL 公司 89 系列单片机的一种

14、8 位 Flash 单片机。它最大特点是片内含 有 Flash 存储器,用途十分广泛,特别是在生产便携式商品,手提式仪器等方面,有着十分广泛的应 用6。 AT89C51 单片机内部主要有以下部件:8031CPU、振荡电路、总线控制部件、中断控制部件、 片内 Flash 存储器、片内 RAM、并行 I/O 接口、定时器和串行 I/O 接口 AT89C51 是 89 系列单片机的标准型,它是与 MSC-51 系列单片机兼容的。在内部含有 4KB 或 8KB 可重复编程的 Flash 存储器,可进行 1000 次擦写操作。全静态工作为 0-24MHZ,有 3 级程序锁 存器,内部含有 128-256

15、 字节的 RAM,有 32 条可编程 I/O 口线,2-3 个 16 位定时/计数器,6-8 个中 断源,通用的串行接口,低电压空闲及电源下降方式。 AT89C51 单片机内部由 CPU、4KB 的 FPEROM ,128B 的 RAM,两个 16 位的定时/计数器 T0 和 T1,4 个 8 位的 I/O 端 P0、P1、P2、P3 等组成。单片微机内部最核心的部分是 CPU。CPU 主要 功能是产生各种控制信号,控制存储器、输入/输出端口的数据传输、数据的算术运算、逻辑运算以 及位操作处理等,CPU 按其功能可分为运算器和控制器两部分。控制器由程序计数器 PC、指令储存 器、指令译码器、实

16、时控制与条件转移逻辑电路等组成。它的功能是对来自存储器中的指令进行译 5 码,通过实时控制电路,在规定的时刻发出各种操作所需的内部和外部的控制信号,使各部分协调 工作,完成指令所规定的操作。运算器由算术逻辑器部件 ALU、累加器 ACC、暂存器、程序状态字 寄存器 PSW,BCD 码运算调整电路等组成。 外部定 时元件 复位 中断 电源 系统时钟 ROM CPU 定时/计数器 串行 I/O 口 并行 I/O 口 RAM 图 3 AT89C51 单片机的内部结构图 为了提高数据处理和位操作功能,片内增加了一个通用寄存器 B 和一些专用寄存器,还增加了 位处理逻辑电路的功能。其内部结构如图 3 所

17、示。 AT89C51 的主要性能包括:AT89C51 与 MCS51 控制器系列产品兼容,片内有 4K 可在线重复 编程闪速电擦除存储器(Flash Memory) ,存储器可循环写入/擦除 1000 次;存储器数据保存时间 可达 10 年;工作电压范围宽:Vcc 可由 2.7V 到 6V;全静态工作可由 0Hz 到 16MHz;程序存储器 具有 3 级锁存保护;128*8 位内部 RAM;32 条可编程 I/O 线;两个 16 位定时器/计数器;中断结构 具有 5 个中断源和 2 个中断优先级;可编程全双工串行通信;空闲状态维持低功耗和掉电状态保存 存储内容。 3.53.5抢答器的优点及组成

18、抢答器的优点及组成 在知识比赛中,特别是做抢答题目的时候,在抢答过程中,为了知道哪一组或哪一位选手先答 题,必须要设计一个系统来完成这个任务。如果在抢答中,靠视觉是很难判断出哪组先答题。利用 单片机系统来设计抢答器,使以上问题得以解决,即使两组的抢答时间相差几微秒,也可分辨出哪 组优先答题。本文主要介绍了单片机抢答器设计及工作原理,以及它的实际用途。系统工作原理本 系统采用 AT89C51 单片机作为核心。控制系统的四个模块分别为:存储模块、显示模块、声音模块、 抢答开关模块。该抢答器系统通过八个个按键输入抢答信号;利用存储程序来完成软件的设计;利 用一个 4 位七段共阴数码管来完成显示功能。

19、工作时,用按键通过开关电路输入各路的抢答信号, 6 经单片机的处理,输出控制信号,控制 4 位七段共阴数码管和喇叭工作。在数码管上显示哪一组先 答题,从而实现整个抢答过程。 4 4系统总体方案的设计系统总体方案的设计 4.14.1硬件电路的设计硬件电路的设计 本设计分为硬件设计和软件设计,这两者相互结合,不可分离;从时间上看,硬件设计的绝大 部分工作量是在最初阶段,到后期往往还要做一些修改。只要技术准备充分,硬件设计的大返工是 比较少的,软件设计的任务贯彻始终,到中后期基本上都是软件设计任务,随着集成电路技术的飞 速发展,各种功能很强的芯片不断出现,使硬件电路的集成度越来越高,硬件设计的工作量

20、在整个 项目中的所占的比重逐渐下降。为使硬件电路设计尽可能合理,应注意以下几方面7: (1) 尽可能采用功能强的芯片,以简化电路,功能强的芯片可以代替若干普通芯片,随着生产工 艺的提高,新型芯片的的价格不断下降,并不一定比若干普通芯片价格的总和高。 (2) 留有设计余地。在设计硬件电路时,要考虑到将来修改扩展的方便。因为很少有一锤定音的 电路设计,如果现在不留余地,将来可能要为一点小小的修改或扩展而被迫进行全面返工。 (3) 程序空间,选用片内程序空间足够大的单片机,本设计采用 AT89C51 单片机。 (4) RAM 空间,AT89C51 内部 RAM 不多,当要增强软件数据处理功能时,往往

21、觉得不足。如 果系统配置了外部 RAM,则建议多留一些空间。如选用 8155 作 I/O 接口,就可以增强 256 字节 RAM。 如果有大批数据需要处理,则应配置足够的 RAM,如 6264,62256 等。随着软件设计水平 的提高,往往只要改变或增加软件中的数据处理算法,就可以使系统功能提高很多,而系统的硬件 不必做任何更换就使系统升级换代。只要在硬件电路设计初期考虑到这一点,就应该为系统将来升 级留足够的 RAM 空间,哪怕多设计一个 RAM 的插座,暂不插芯片也好。 (5) I/O 端口:在样机研制出来后进行现场试用时,往往会发现一些被忽视的问题,而这些问 题不是靠单纯的软件措施来解决

22、的。如有些新的信号需要采集,就必须增加输入检测端;有些物理 量需要控制,就必须增加输出端。如果在硬件电路设计就预留出一些 I/O 端口,虽然当时空着没用, 那么用的时候就派上用场了。 7 4.24.2总体原理图总体原理图 图中中央为单片机 AT89C51。右下角为 8 个按键,分别为 8 路抢答按键,分别接到单片机的 P1.0P1.7 端口。此处默认设计,S1 按键为主持人按键,其余 7 按键为选手按键。蜂鸣器输出端口为 P2.7。7 段数码管(图中左下角所示)管脚从左至右依次为 agop 段,分别接至单片机的 P2.0P2.7 口。 8 4.34.3时钟频率电路的设计时钟频率电路的设计 单片

23、机必须在时钟的驱动下才能工作。在单片机内部有一个时钟振荡电路,只需要外接一个振 荡源就能产生一定的时钟信号送到单片机内部的各个单元,决定单片机的工作速度。时钟电路如图 5 所示。 图 5 外部振荡源电路 一般选用石英晶体振荡器。此电路在加电大约延迟 10ms 后振荡器起振,在 XTAL2 引脚产生幅 度为 3V 左右的正弦波时钟信号,其振荡频率主要由石英晶振的频率确定。电路中两个电容 C1,C2 的作用有两个:一是帮助振荡器起振;二是对振荡器的频率进行微调。C1,C2 的典型值为 30PF。 单片机在工作时,由内部振荡器产生或由外直接输入的送至内部控制逻辑单元的时钟信号的周 期称为时钟周期。其

24、大小是时钟信号频率的倒数,常用 fosc表示。图中时钟频率为 12MHz,即 fosc=12MHz,则时钟周期为 1/12s。 9 4.44.4复位电路的设计复位电路的设计 单片机的第 9 脚 RST 为硬件复位端,只要将该端持续 4 个机器周期的高电平即可实现复位,复 位后单片机的各状态都恢复到初始化状态,其电路图如图 6 所示: 图 6 复位电路 图 6 中由按键 RESET1 以及电解电容 C3、电阻 R2 构成按键及上电复位电路。由于单片机是高电 平复位,所以当按键 RESET1 按下时候,单片机的 9 脚 RESET 管脚处于高电平,此时单片机处于复位 状态。当上电后,由于电容的缓慢

25、充电,单片机的 9 脚电压逐步由高向低转化,经过一段时间后, 单片机的 9 脚处于稳定的低电平状态,此时单片机上电复位完毕,系统程序从 0000H 开始执行。 值得注意的是,在设计当中使用到了硬件复位和软件复位两种功能,由上面的硬件复位后的各 状态可知寄存器及存储器的值都恢复到了初始值,而前面的功能介绍中提到了倒计时时间的记忆功 能,该功能的实现的前提条件就是不能对单片机进行硬件复位,所以设定了软复位功能。软复位实 际上就是当程序执行完毕之后,将程序指针通过一条跳转指令让它跳转到程序执行的起始地址。 4.54.5显示电路的设计显示电路的设计 显示功能与硬件关系极大,当硬件固定后,如何在不引起操

26、作者误解的前提下提供尽可能丰富 的信息,全靠软件来解决。 在这里我们使用的是数码管显示,通常在显示上我们采用的方法一般包括两种:一种是静态显 示,一种是动态显示。其中静态显示的特点是显示稳定不闪烁,程序编写简单,但占用端口资源多; 动态显示的特点是显示稳定性没静态好,程序编写复杂,但是相对静态显示而言占用端口资源少。 在本设计中根据实际情况采用的是动态显示方法。 通过查表法,将其在数码管上显示出来,其中 P0 口为字型码输入端,P2 口低 3 位为字选段输 入端。在这里我们通过查表将字型码送给 7 段数码管显示的数字。 10 4.64.6键盘扫描电路的设计键盘扫描电路的设计 键盘是人与单片机打

27、交道的主要设备。关于键盘硬件电路的设计方法也可以在文献和书籍中找 到,配合各种不同的硬件电路,这些书籍中一般也提供了相应的键盘扫描程序。站在系统监控软件 设计的立场上来看,仅仅完成键盘扫描,读取当前时刻的键盘状态是不够的,还有不少问题需要妥 善解决,否则,人们在操作键盘就容易引起误操作和操作失控现象。在单片机应用中键盘用得最多 的形式是独立键盘及矩阵键盘。 它们各有自己的特点,其中独立键盘硬件电路简单,而且在程序设计上也不复杂,一般用在对 硬件电路要求不高的简单电路中;矩阵键盘与独立键盘有很大区别,首先在硬件电路上它要比独立 键盘复杂得多,而且在程序算法上比它要烦琐,但它在节省端口资源上有优势

28、得多,因此它更适合 于多按键电路。其次就是消除在按键过程中产生的“毛刺”现象。这里采用最常用的方法,即延时 重复扫描法,延时法的原理为:因为“毛刺”脉冲一般持续时间短,约为几 ms,而我们按键的时间 一般远远大于这个时间,所以当单片机检测到有按键动静后再延时一段时间(这里我们取 5ms)后再判 断此电平是否保持原状态,如果是则为有效按键,否则无效。 在本文设计中采用了独立键盘的方式,本设计中有 8 个抢答按键输入,一个开始按键、一个结 束按键,此外还有抢答时间调整键、回答时间调整键,加一按键、减一按键各一个。8 个抢答按键 分别接入单片机的 P1.0P1.7 端口,单片机通过读取 P1.0P1

29、.7 的值来判断当前输入的是 8 个抢答按 键中的哪一个。抢答时间调整和回答时间调整接到单片机的 P3.3 和 P3.4 接口,加一及减一按键接到 单片机的 P3.5 和 P3.6 接口。 图 9 键盘按键电路 在图 9 中,开始及结束按键接到单片机的 10、11 脚,这里用到了单片机 10、11 脚复合功能中 的 IO 端口功能,单片机通过读取 10、11 脚的 P3.0、P3.1 的 IO 端口值来判断当前是否处于抢答开始 11 状态或抢答结束状态。 按键的触点在闭合和断开时均会产生抖动,这时触点的逻辑电平是不稳定的,如不妥善处理, 将会引起按键命令的错误执行或重复执行。现在一般均用软件延

30、时的方法来避开抖动阶段,这一延 时过程一般大于 5ms,例如取 10-20ms。如果监控程序中的读键操作安排在主程序(后台程序)或键 盘中断(外部中断)子程序中,则该延时子程序便可直接插入读键过程中。如果读键过程安排在定 时中断子程序中,就可省去专门的延时子程序,利用两次定时中断的时间间隔来完成抖动处理。 4.74.7发声发声电路电路 我们知道,声音的频谱范围约在几十到几千赫兹,若能利用程序来控制单片机某个口线的“高” 电平或低电平,则在该口线上就能产生一定频率的矩形波,接上喇叭就能发出一定频率的声音,若 再利用延时程序控制“高” “低”电平的持续时间,就能改变输出频率,从而改变音调,使喇叭发

31、出 不同的声音。 本文设计如图 10 所示。图中单片机的 14 脚输出具有复合功能,此处用到了单片机 17 脚的 IO 端口功能,单片机通过内部定时器的操作实现交替变换的波形输出驱动扬声器发声。 图 10 发声电路 4.84.8系统复位系统复位 使 CPU 进入初始状态,从 0000H 地址开始执行程序的过程叫系统复位。从实现系统复位的方法 来看,系统复位可分为硬件复位和软件复位。硬件复位必须通过 CPU 外部的硬件电路给 CPU 的 RESET 端加上足够时间的高电位才能实现。上电复位,人工按钮复位和硬件看门狗复位均为硬件复 位。硬件复位后,各专用寄存器的状态均被初始化,且对片内通用寄存器的

32、内容没有影响。但是, 12 硬件复位还能自动清除中断激活标志,使中断系统能够正常工作,这样一个事实却容易为不少编码 人员所忽视。软件复位就是用一系列指令来模拟硬件复位功能,最后通过转移指令使程序从 0000H 地址开始执行。对各专用寄存器的复位操作是容易的,也没有必要完全模拟,可根据实际需要去主 程序初始化过程中完成。而对中断激活标志的清除工作常被遗忘,因为它没有明确的位地址可供编 程。有的编程人员用 020000(LJMP 0000H)作为软件陷阱,认为直接转向 0000H 地址就完成了软 件复位,就是这类错误的典型代表。软件复位是使用软件陷阱和软件看门狗后必须进行的工作,这 时程序出错完全

33、有可能发生在中断子程序中,中断激活标志已置位,它将阻止同级中断响应。由于 软件看门是高级中断,它将阻止说要中断响应,由此可见清除中断激活标志的重要性。 在所有的指令中,只有 RETI 指令能够清除中断激活标志。出错处理程序 ERR 主要完成这一功 能,其他的善后工作交由复位后的系统去完成。 程序一般先关中断,以便后续处理能顺利进行,然后用两个 RETI 指令代替两个 LJMP 指令,从 而清除了两级中断激活标志。有相应软件陷阱捕捉来的程序可能没有全部激活两个标志,这也无妨。 5 5软件设计软件设计 5.1 软件设计流程图软件设计流程图 电路初始化 按键模块 主持人按键(S1) 选手抢答按键 电

34、源按键 复位按键 数码管显示 图 13 软件系统结构图 13 5.2 软件软件设计代码设计代码 #include / STC12C5A60S2 单片机头文件 #define uint unsigned int #define uchar unsigned char #define INIT_TH0 (65536 - 50000) / 256)/ 定时器 T0 初始化每 50ms 中断一次 #define INIT_TL0 (65536 - 50000) % 256) #define INIT_TH1 (65536 - 5000) / 256)/ 定时器 T1 初始化每 5ms 中断一次 #de

35、fine INIT_TL1 (65536 - 5000) % 256) uchar code DIS_7SEG = / 数码管显示编码 0x7e, 0x0c, 0xb6, 0x9e, 0xcc, 0xda, 0xfa, 0x0e, 0xfe, 0xde, 0xce, 0xf8, 0x72, 0xbc, 0xf2, 0xe2 ; sbit S1 = P10;/ 按键定义 sbit S2 = P11; sbit S3 = P12; sbit S4 = P13; sbit S5 = P14; sbit S6 = P15; /sbit beeper = P20; uchar keyval, t0 =

36、0, t1 = 0, flag1 = 0, over = 0; uchar countdown = 5; /void beep(); / 延时函数 void delayms(uint ms) uint t; while(ms-) for(t = 0; t = 20) t0 = 0; if (countdown != 0)/ 倒计时 5ms 判断 P2 = DIS_7SEGcountdown; countdown-; delayms(2000); else TR1 = 0; / Time out and timer1 shutdown void timer1() interrupt 3 TH1

37、= INIT_TH1; TL1 = INIT_TL1; t1+; if(flag1) if(t1 = 1)/ 每 5ms 检测一次按键 t1 = 0; key_scan(); switch(keyval) case 2: TR0 = 0;/ 关定时器 0,从而达到数码管显示数字不变的效果 showpalyer(keyval - 1); break; case 3: 16 TR0 = 0; showpalyer(keyval - 1); break; case 4: TR0 = 0; showpalyer(keyval - 1); break; case 5: TR0 = 0; showpaly

38、er(keyval - 1); break; case 6: TR0 = 0; showpalyer(keyval - 1); break; 6 6总结总结 通过这次课程设计,总体上了解了单片机设计的流程:从硬件设计到后半部分的软件设计。 本次实验中,我主要负责软件设计。从最初的什么都不懂,到现在初步掌握了简单中断程序的 设计。通过这两周的课程设计的学习,极大的丰富了自己在单片机上的空白,对于单片机的工作原 理,驱动方法,中断调用,乃至于keil和protues软件使用等等,还是学到很多知识的。正因为如此, 为日后学习乃至工作打下了基础。 当然,在本次实验过程中也是有很多不足的地方: 1.小组

39、分工不是特别的明确。由于小组分工,彼此之间职责没有严格确定下来,导致后期硬 件电路对于软件设计部分不透明。硬件电路的不完善,设计上面的欠缺等等问题,导致软 件设计部分无法进行。这点侧面也反应了,与老师沟通的不够。 2.小组交流。由于前期分工不是特别的明确,后期的交流也不是很到位。设计过程中有很多 矛盾的地方。这点在日后的工作学习,尤其是在团队合作的时候,要尤其注意。 3.软件设计上的不成熟。由于是从零开始,写代码过程中难免有不足的地方,日后慢慢补进, 学习。 4.缺乏与老师沟通。 尽管在设计过程中,小组成员之间产生过矛盾。总体上,从个人角度上看,学到的 西还是很多的。 17 参参 考考 文文 献献 1 程相波,卫安军. 基于 MCS-51 单片机的八路抢答器设计方法研究J. 北京工业职业技术学院 学报,2007. 2 林凌,李刚,等. 新型单片机接口器件与技术M. 西安: 西安电子科技大学出版社,2005 年. 3 李增生. 对抢答器的改进J. 电子制作,2000. 4 马轲瀛. 八路数字抢答器系统J. 华商,2007. 5 高伟. AT89 单片机原理及应用M. 北京:国防工业出版社,2008 年. 6 蔡朝阳. 单片机控制实习与专题制作M. 北京:北京航空航天大学出版社, 2006 年. 7 杨凌霄.微型计算机原理及应用M. 江苏:中国矿业大学出版社, 2004 年.

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1