《基于单片机的4位抢答器设计--论学士学位论文.doc》由会员分享,可在线阅读,更多相关《基于单片机的4位抢答器设计--论学士学位论文.doc(25页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、通信#班, # 基于单片机的抢答器设计 单片机课程设计报告项目名称 基于单片机的抢答器设计 专业班级 通信111班 学生姓名 # 指导教师 # 2013年12 月28日摘 要此次设计提出了用STC89C52单片机为核心控制元件,设计一个简易的抢答器, 本方案以STC89C52单片机作为主控核心,发光二极管、数码管、蜂鸣器等构成四路抢答器,利用了单片机的按键复位电路、时钟电路、定时/中断等电路,设计的抢答器具有实时显示抢答选手的号码的特点,还有复位电路,使其再开始新的一轮的答题和比赛,同时还利用C语言编程,使其实现一些基本的功能。本设计的系统实用性强、判断精确、操作简单、扩展功能强。它的功能实现
2、是比赛开始,主持人读完题之后按下总开关,此时数码管显示初始状态0,直到有一个选手抢答时,对应的会在数码管上显示出该选手的编号,同时发光二极管出现闪烁状态,蜂鸣器也会发出声音,以提示有人抢答本题,主持人按下复位键,示意可以答题。关键字:STC89C52单片机;动态显示;中断;按键控制AbstractThis design use STC89C52as the core control element is presented to design a simple responder, this scheme is STC89C52 single chip microcomputer as con
3、trol core, light-emitting diode, digital tube, buzzer and so on four road vies to answer first device, using the single chip microcomputer button reset circuit, clock circuit, timing/interrupt circuit, design of vies to answer first appliance has the characteristic of real-time display vies to answe
4、r first contestants number, and reset circuit, to start a new round of the answer and, at the same time also use of C language programming, make it implements some basic functionality. The design of the system is practical, accurate judgment, simple operation, strong extended functionality. Its func
5、tion realization is the match began, and the host to read the topic after press the main switch, the digital tube display initial condition 0, until there is a contestant vies to answer first, the corresponding in the contestants serial number is shown on the digital tube, light-emitting diodes, fli
6、cker status at the same time, the buzzer will sound, to remind someone vies to answer first ontology, host press the reset button, the signal can be the answer. Keywords: STC89C52 microcomputer; Dynamic display; Interrupt; The key controlIII目 录摘 要IAbstractII第1章 绪论11.1 单片机抢答器的背景11.2 单片机抢答器的意义11.3 抢答器
7、的应用1 第2章 系统硬件部分的设计22.1 设计要求22.2 总体设计方案22.3 单元模块设计32.3.1 单片机简介32.3.2 最小系统的设计52.3.3 数码管显示电路62.3.4 按键模块设计6第3章 系统的软件设计83.1 抢答器工作原理83.2 流程图83.3 KEIL软件简介9第4章 系统的仿真与调试114.1 软件的仿真与调试114.2 硬件的安装与调试114.2.1晶振电路的测试124.2.2复位电路的测试124.2.3显示电路的测试12总结13参考文献14附录1源程序代码15附录2 元件清单17附录3 仿真图18附录4 实物照片展示19致谢20第1章 绪论1.1 单片机
8、抢答器的背景二十世纪跨越了三个“电”的时代,即电气时代、电子时代和现已进入的电脑时代。不过,这种电脑,通常是指个人计算机,简称PC机。它由主机、键盘、显示器等组成。还有一类计算机,大多数人却不怎么熟悉。这种计算机就是把智能赋予各种机械的单片机(亦称微控制器)。顾名思义,这种计算机的最小系统只用了一片集成电路,即可进行简单运算和控制。因为它体积小,通常都藏在被控机械的“肚子”里。它在整个装置中,起着有如人类头脑的作用,它出了毛病,整个装置就瘫痪了。现在,这种单片机的使用领域已十分广泛,如智能仪表、实时工控、通讯设备、导航系统、家用电器等。各种产品一旦用上了单片机,就能起到使产品升级换代的功效,常
9、在产品名称前冠以形容词-“智能型”。在知识竞赛中,往往会用到抢答器。故此我们就选择利用单片机编程来设计抢答器,即使两组的抢答时间相差几微秒,也能轻松的分辨出哪一组(或哪个选手)先抢答到题。1.2 单片机抢答器的意义本系统采用单片机作为整个控制核心。控制系统的四个模块为:显示模块、存储模块、语音模块、抢答开关模块。该系统通过开关电路四个按键输入抢答信号,利用一个数码管来完成显示功能,用按键来让选手进行抢答,在数码管上显示哪一组先答题的,从而实现整个抢答过程。本文主要介绍了单片机抢答器设计及工作原理,以及它的实际用途。系统工作原理本系统采用STC89C52单片机作为核心。控制系统四个模块分别为:存
10、储模块、显示模块、语音模块、抢答开关模块。该抢答器系统通过开关电路四个按键输入抢答信号, 利用一个数码管来完成显示功能。工作时,用按键通过开关电路输入各路的抢答信号,经单片机的处理, 输出控制信号,单片机控制的智能抢答器设计。1.3 抢答器的应用随着我国经济和文化事业的发展,在很多公开竞争场合要求有公正的竞争裁决,诸如证券、股票交易及各种智力竞赛等,因此出现了抢答器。抢答器一般是由很多电路组成的,线路复杂,可靠性不高,功能也比较简单,特别是当抢答路数很多时,实现起来就更为困难。因此我们设计了以单片机为核心的新型智能的抢答器,在保留原始抢答器的基本功能的同时又增加了数码管显示电路实现了其它功能。
11、抢答器又称为第一信号鉴别器,其主要应用于各种知识竞赛、文艺活动等场合。第2章 系统硬件部分的设计2.1 设计要求(1)总共6个按键,两个供主持人用于“开始抢答”和“复位”操作,四个供四个选手用作“抢答”操作。(2)用1个发光二极管用作开始抢答的指示灯,用4个发光二极管分别显示4个选手的抢答状态。(3)开始抢答后,哪个选手抢答键最先按下,抢答指示灯点亮,蜂鸣器报警,数码管显示选手号码,表示该选手抢答成功,此时其他选手再按键为无效。(4)开始抢答前,若有选手按下抢答键,则其对应的指示灯变为闪烁,蜂鸣器报警,数码管显示选手号码,表示该选手犯规,此时所有选手按键都将无效。(5)出现犯规后,主持人可以利
12、用“复位键”重新开始。2.2 总体设计方案 方案:依据课题要求,基于STC89C52单片机制作的抢答器,其最大的好处就是处理准确性高、可靠性好、控制功能强。 采用STC89C52单片机作为控制中心,系统可以完成运算控制、信号的控制以及显示的功能。选手通过按键开光作为输入信号完成输入信号的触发,主持人根据选手的输入信号准确的判断最先按下的选手且屏蔽其他的抢答信号,让选手作答。使用外部中断方式来实现开始抢答,运用按键复位来实现系统的复位,其系统原理框图如下:图2-1 系统原理框图2.3 单元模块设计2.3.1 单片机简介STC89C51单片机是采用高性能的静态80C52 设计由先进CMOS 工艺制
13、造并带有非易失性Flash 程序存储器,全部支持12 时钟和6 时钟操作。P89C51X2 和P89C52X2/54X2/58X2 分别包含128 字节和256 字节RAM 32 条I/O 口线3 个16 位定时/计数器6 输入4 优先级嵌套中断结构1 个串行I/O 口可用于多机通信I/O 扩展或全双工UART以及片内振荡器和时钟电路。图2-2 STC89C52单片机引脚图各引脚功能介绍如下:VCC:供电电压 GND:接地 P0口:P0口为一个8位漏级开路双向I/O口,每个管脚可吸收8TTL门电流。当P1口的管脚写“1”时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/
14、地址的第八位。在FLASH编程时,P0口作为原码输入口,当FLASH进行校验时,P0输出原码,此时P0外部电位必须被拉高。P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入“1”后,电位被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。P2口:P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚电位被内部上拉电阻拉高,且作为输入。作为输入时,P2口的管脚电位被外部拉低,将输出电流,这
15、是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉的优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入时,由于外部下拉为低电平,P3口将输出电流(ILL),也是由于上拉的缘故。P3口也可作为AT89C51的一些特殊功能口:P3.0 RXD(串行输入口)P3.1 TXD(
16、串行输出口)P3.2 INT0(外部中断0)P3.3 INT1(外部中断1)P3.4 T0(记时器0外部输入)P3.5 T1(记时器1外部输入)P3.6 WR (外部数据存储器写选通)P3.7 RD (外部数据存储器读选通)同时P3口同时为闪烁编程和编程校验接收一些控制信号。RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高平时间。ALE / PROG :当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定
17、时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令时ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。PSEN:外部程序存储器的选通信号。在由外部程序存储器取址期间,每个机器周期PSEN两次有效。但在访问内部部数据存储器时,这两次有效的PSEN信号将不出现。EA/VPP:当EA保持低电平时,访问外部ROM;注意加密方式1时,EA将内部锁定为RESET;当EA端保持高电平时,访问内部ROM。在FLASH编程期间,此引脚也用于施加12V编程电源(
18、VPP)。XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。XTAL2:来自反向振荡器的输出。2.3.2 最小系统的设计单片机的最小系统电路图: 图2-3 单片机的最小系统图 说明: 复位电路:由电容串联电阻构成,由图并结合“电容电压不能突变”的性质,可以知道,当系统一上电,RST脚将会出现高电平,并且,这个高电平持续的时间由电路的RC值来决定。典型的51单片机当RST脚的高电平持续两个机器周期以上就将复位,所以,适当组合RC的取值就可以保证可靠的复位.一般教科书推荐C 取10,R取8.2K。当然也有其他取法的,原则就要让RC组合可以在RST脚上产生不少于2个机周期的高电平; 复位输入
19、高电平有效,当振荡器工作是,RST引脚出现两个机器周期以上的高电平,使单片机复位。此电路除具有上电复位功能外,若要复位只需按“RST”键,此电源Vcc经电阻分压,在RST端产生一个复位高电平; 晶振电路:典型的晶振取11.0592MHz(因为可以准确地得到9600波特率和19200波特率,用于有串口通讯的场合)/12MHz(产生精确的方波便于12分频,方便定时操作); 单片机:一片STC89C51/52或其他51系列兼容单片机; 注意:对于31脚(EA/Vpp),当接高电平时,单片机在复位后从内部ROM的0000H开始执行;当接低电平时,复位后直接从外部ROM的0000H开始执行;电源部分:接
20、+5伏特的电压。2.3.3 数码管显示电路其中数码管的显示可以分为两种:静态显示和动态显示。静态显示的段选位和位选位均单独连接,因此占用的I/O接口多,无法扩展多个数码管,在这种采用这种方式,必须要给LED恒定的电压,要求电压一直保持,所以一般在LED和单片机之间加锁存器,这种显示方式亮度高,编程较简单,结构清晰,管理也较简单,占用的CPU时间少。动态显示驱动:数码管动态显示接口是单片机中应用最为广泛的一种显示方式之一,动态驱动是将所有数码管的8个显示笔划a,b,c,d,e,f,g,dp的同名端连在一起,另外为每个数码管的公共端COM增加位选通控制电路,位选通由各自独立的I/O线控制,当单片机
21、输出字形码时,所有数码管都接收到相同的字形码,但究竟是那个数码管会显示出字形,取决于单片机对位选通COM端电路的控制,所以我们只要将需要显示的数码管选通控制打开,该位就显示出字形,没有选通的数码管就不会亮。通过分时轮流控制各个数码管的COM端,就使各个数码管轮流受控显示,这就是动态驱动。在轮流显示过程中,每位数码管的点亮时间为12ms,由于人的视觉暂留现象及发光二极管的余辉效应,尽管实际上各位数码管并非同时点亮,但只要扫描的速度足够快,给人的印象就是一组稳定的显示数据,不会有闪烁感,动态显示的效果和静态显示是一样的,能够节省大量的I/O端口,而且功耗更低。从电路上,按数码管的接法不同又分为共阴
22、和共阳两种。图2-4 是共阴和共阳极数码管的内部电路,它们的发光原理是一样的,只是它们的电源极性不同而已。其数码管的外形如下图所示:图2-4 数码管的共阴和共阳极接法2.3.4 按键模块设计4个抢答按键分别接入单片机的P3.0P3.3端口,单片机通过读取P3.0P3.3的值来判断当前输入的是4个抢答按键中的哪一个。 图2-5 按键电路按键的触点在闭合和断开时均会产生抖动,这时触点的逻辑电平是不稳定的,如不妥善处理,将会引起按键命令的错误执行或重复执行。现在一般均用软件延时的方法来避开抖动阶段,这一延时过程一般大于5ms,例如取10-20ms。如果监控程序中的读键操作安排在主程序(后台程序)或键
23、盘中断(外部中断)子程序中,则该延时子程序便可直接插入读键过程中。 图2-6 数码管显示电路第3章 系统的软件设计在软件设计中,一般采用模块化的程序设计方法,它具有明显的优点。把一个多功能的复杂的程序划分为若干个简单的、功能单一的程序模块,有利于程序的设计和调试,有利于程序的优化和分工,提高了程序的阅读性和可靠性,使程序的结构层次一目了然。3.1 抢答器工作原理抢答器是为智力竞赛参赛者答题时进行抢答而设计的一种优先判决器电路,广泛应用于各种知识竞赛、文娱活动等场合。在抢答竞赛或呼叫时,有多个信号同时或不同时送入主电路中,抢答器内部的寄存器工作,并识别、记录第一个号码,同时内部的定时器开始工作,
24、记录有关时间并产生超时信号。在整个抢答器工作过程中,显示电路、声音电路等还要根据现场的实际情况向外电路输出相应信号。3.2 流程图流程图是使用图形表示算法的思路是一种极好的方法,不论采用何种程序设计方法,程序总体结构确定后,一般以程序流程图的形式对其进行描述。总体框图中的各个子模块或各个子任务也应该结合具体的教学模型和算法画出较详细的程序流程图,供后面编写具体程序和阅读程序使用。流程图是由一些图框和流程线组成的,其中图框表示各种操作的类型,图框中的文字和符号表示操作的内容,流程线表示操作的先后次序。流程图的基本结构为顺序结构,分支结构(又称选择结构),循环结构。为便于识别,绘制流程图的习惯做法
25、是:方框表示:要执行的处理(Process)平行四边型表示:代表资料输入(Input)不规则图形代表资料输出(Output)或报表输出(Print)菱形表示:决策或判断(例如:If.Then.Else)图3-1 主程序流程图在抢答竞赛或呼叫时,有多个信号同时或不同时送入主电路中,抢答器内部的寄存器工作,并识别、记录第一个号码,同时内部的定时器开始工作,记录有关时间并产生超时信号。在整个抢答器工作过程中,显示电路还要根据现场的实际情况向外电路输出相应信号。3.3 KEIL软件简介单片机开发中除必要的硬件外,同样离不开软件,我们写的汇编语言源程序要变为CPU可以执行的机器码有两种方法,一种是手工汇
26、编,另一种是机器汇编,目前已极少使用手工汇编的方法了。机器汇编是通过汇编软件将源程序变为机器码,用于MCS-51单片机的汇编软件有早期的A51,随着单片机开发技术的不断发展,从普遍使用汇编语言到逐渐使用高级语言开发,单片机的开发软件也在不断发展,Keil软件是目前最流行开发MCS-51系列单片机的软件,这从近年来各仿真机厂商纷纷宣布全面支持Keil即可看出。Keil提供了包括C编译器、宏汇编、连接器、库管理和一个功能强大的仿真调试器等在内的完整开发方案,通过一个集成开发环境(uVision)将这些部份组合在一起。运行Keil软件需要Pentium或以上的CPU,16MB或更多RAM、20M以上
27、空闲的硬盘空间、WIN98、NT、WIN2000、WINXP等操作系统。掌握这一软件的使用对于使用51系列单片机的爱好者来说是十分必要的,如果你使用C语言编程,那么Keil几乎就是你的不二之选(目前在国内你只能买到该软件、而你买的仿真机也很可能只支持该软件),即使不使用C语言而仅用汇编语言编程,其方便易用的集成环境、强大的软件仿真调试工具也会令你事半功倍。Keil C51生成的目标代码效率非常之高,多数语句生成的汇编代码很紧凑,容易理解。在开发大型软件时更能体现高级语言的优势。打开Keil软件,首先,建立工程文件,然后新建一文档,输入自己编写的程序。点击保存,保存为.ASM文件(C语言为.C文
28、件)。然后,然后再单击Add Files to Group Source Group 1。然后勾选生成.HEX文件选项,最后点击编译,如图3-2所示。图3-2 Keil软件程序编写第4章 系统的仿真与调试4.1 软件的仿真与调试Proteus ISIS是英国Labcenter公司开发的电路分析与实物仿真软件,它可以仿真、分析(SPICE)各种模拟器件和集成电路。该软件的主要特点总结后有以下四点:实现了单片机仿真和SPICE电路仿真相结合的功能。支持目前主流单片机系统的仿真。提供了软件调试功能,并可以与WAVE联合仿真调试。具有强大的原理图绘制功能。总之,该软件是一款集单片机和SPICE分析于一
29、身的仿真软件,功能极其强大。在电子领域中也起到了很大的作用,它的出现仿真不需要先焊接电路,可以先仿真调试通过后在焊电路,节省了不少在硬件调试上所花的时间。Proteus ISIS的工作界面是一种标准的Windows界面。它包括标题栏、主菜单、状态栏、标准工具栏、绘图工具栏、对象选择按钮、预览对象方位控制按钮、仿真进程控制按钮、预览窗口、对象选择器窗口、图形编辑窗口等十几个工具,方便了使用者的使用。首先打开已经画好的proteus DSN文件,双击图中的STC89C52芯片,就弹出一个窗口,在Program File项中通过路径选择在WAVE中生成的HEX文件,双击选中后确定,这样仿真图中的ST
30、C89C51芯片就已经读取了本设计中的HEX文件。单击“三角形按钮”进行仿真。通过对仿真结果的观察来对程序进行修改,最终使程序到达设计要求。4.2 硬件的安装与调试按照之前设计好的抢答器原理图,详细计算系统中各个元件的参数,选择相应器件,焊接实际电路板。由于考虑到万能板大小的问题及元件之间连线的方便,在焊接元器件前必须考虑元件的布局然后进行实际操作。制作好的电路板可以用万用表(200欧姆档)的红、黑表笔测试电路板的每条走线,当其电阻非常小时,证明走线没有断开,当其电阻很大时,证明该条走线断了,应该重新走线,使电路板在电气上得到正确地连接。选用万用表的20K欧姆档,检测电路中是否存在短路。因为系
31、统采用的是共阴极数码管作为显示电路,必须确保数码管的公共端接的是低电平。4.2.1晶振电路的测试在单片机正常运行的必要条件是单片机系统的时钟稳定正常。实际中,因为各种原因导致系统时钟不正常而出现系统无法正常运行的情况时有,因此系统时钟是否振是通电检查的首要环节。在系统通电的状况下,用万用表的直流电压档(20V),分别测量XTAL1和XTAL2引脚的电压,看是否正常,在调试过程中,测得电压XTAL1引脚应为2.05V,XTAT2应为2.15V。4.2.2复位电路的测试复位不正常也会导致系统不能工作。如果复位引脚始终为高电平,系统将始终处于复位状态;如果始终为低电平,不能产生复位所需的高电平信号脉
32、冲,则系统也可能无法正常工作。单片机正常工作时,RST复位引脚应为0V,按下复位按键时,复位引脚为高电平5V左右。4.2.3显示电路的测试显示电路是抢答器正常运行最直观的观察窗口,我们可以通过观察显示电路的显示结果观察系统能否正常运行。当显示电路按照电路图焊接好后,用万用表的测二极管档位,将黑表笔接共阴数码管的公共段,然后将红表笔接数码管的各段,当数码管的段能正常显示,说明各点焊接正常。将R3到R9及共阴数码管焊好,再将集成电路插座焊上,这样这部分电路就制作完成了。接下来对这部分电路进行测试,接上电源,数码管全灭,用一导线的一端与地线相连,另一端依次碰集成电路插座的20脚到26脚,一边碰一边查
33、看数码管,正常时可以看到每碰一个脚,对应一段数码管灯亮。若不亮,仔细查看与该脚相连的电阻及数码管是否虚焊。将烧录好程序的AT89C2051芯片插上(我们提供的芯片中已烧录好程序),注意方向不要插错(反插容易损坏芯片),芯片上有一个小三角的标记处为1脚。只要元件焊接无误,按以上制作流程操作,装好后就可以正常工作。制作完成的4路抢答器见。所有元件全部制作完成后,接上电源,电源指示灯亮,按动4路抢答开关中的任何一路,音乐响起,同时数码管显示相应的抢答开关号。抢答成功后,按下复位键,系统返回抢答状态。总结本次课程设计结束了,在这次的课程设计中不仅检验了我所学习的知识,也培养了我如何去把握一件事情,如何
34、去做一件事情,又如何完成一件事情。通过这次课程设计,我对单片机的知识有了进一步的学习。通过这次设计,本人在多方面都有所提高。通过这次设计,综合运用本专业所学课程的理论,设计工作的实际训练从而培养和提高学生独立工作能力,巩固所学的内容,同时各科相关的课程都有了全面的复习,独立思考的能力也有了提高。在设计过程中遇到了很多问题,我都没有放弃,不明白的地方就及时查资料,问同学或是找老师帮忙。经过查阅有关方面的书籍,获取了很多专业方面的知识,拓展了视野,增加了我实际动手能力。 通过这次的实训在软件方面在进一步学习了汇编程序编译环境keil uVision3, 并且学习新的软件proteus 7,学习在上
35、面画电路图,硬件与程序相结合仿真路。在此感谢我们的老师.,老师严谨细致、一丝不苟的作风一直是我工作、学习中的榜样;老师循循善诱的教导和不拘一格的思路给予我无尽的启迪;这次设计的每个实验细节和每个结果,都离不开老师您的细心指导。 参考文献1 张毅刚 彭喜元 彭 宇 单片机原理及其应用 2010 , 05 :(101-113)2 谭浩强 C程序设计 2005 ,07 :(219-278) 3 戴佳. 单片机C51语言应用程序设计. 电子工业出版社, 2006.7:168-1694 朱民雄.计算机语言技术. 北京航空航天大学出版社,2002.1:103-1055 李鸿. 单片机原理及应用. 湖南大学
36、出版社. 2004:8:72-736 刘建清. 单片机技术. 国防工业出版社, 2006.8: 104-105 7 杨宁,胡学军单片机与控制技术北京航空航天大学出版社,2005-03:306-3228 马忠梅等单片机C语言应用程序设计北京航空航天大学出版社, 1997:201-21119附录1源程序代码 ORG000 MP BEGIN TABLE: ; 共阴极数码管显示代码表DB 3FH,06H,5cH,4FH,66H ; 01234DB 6DH,7DH,07H,7FH ; 46789DELAY: MOVR5,#20 ; 延时2020ms子程序 LOOP4: MOVR6,#50 LOOP5:
37、MOVR7,#100DJNZR7,$DJNZ6, LOOP5DJNZR5, LOOP4RETBEGIN: MOVP2, #0FFH;P2口置高电平,准备接收信号 MOV R4,#0 ; R4的位标志值清零。MOVA, R4 ; R4位标志值送A寄存AGAIN: MOV DPTR,#TABLE ;共阴极数码管代码表首址送 MOVCA, A+DPTR; 取出显示0的代码送P口显示 MOV P1, ALOOP1: MOVA,P3 ;接收P3口的抢答信号。 CPL A ;抢答信号求反 JZ LOOP1 ;如果没有抢答信号LOOP1LOOP2: RRC A;有抢答信号则逐次移动判断是那一位抢答INC R
38、4 ;每移一次位,R4位标志值加1JNC LOOP2 ;如果没有遇到抢答信号返回LOOP1继续移位MOV A,R4 ;遇到抢答信号把R4位标志的只送AMOVCA,A+DPTR ;找到相应位的显示代码MOVP1,A;送P1口显示 LOOP3: JNB P2.2, BEGIN;若主持人按了复位信号健则转向程序复位CPL P2.0 ;若没按复位信号键,则通过P2.2给出高低信号驱动蜂鸣器LCALLDELAY ;调用延时程序SJMP LOOP3 ;P2.2口反复间隔0.4秒变化,驱动蜂鸣器 END附录2 元件清单 元件名称型号数量/个用途 单片机 AT89S52 1控制核心晶振12MHz 1晶振电路电
39、容30pF 2 电解电容10F/10V 1复位电路按键 1电阻10k电源5V/0.5A电源电路按键4选手输入按键1 主持人输入三极管9015蜂鸣器及其驱动电路蜂鸣器1电阻10k1数码管1位共阴1显示电路集成块74L2451驱动附录3 仿真图附录4 实物照片展示致谢本设计是在#老师的悉心指导下完成的,老师严谨的治学态度,一丝不苟的工作作风,平易近人的性格都是我学习的楷模,感谢老师的指导让我很好的完成了我的作品以及论文。 虽然毕业设计内容繁多,过程繁琐,但我的收获却更加丰富。通过老师的悉心指导和其他老师的指导及其与同学们在制作作品时的交流,我了解到到了单片机最小系统的作用和设计方法,相关设备的选用标准,以及各种容易忽略的细节,我的能力得到了提高。虽然提高是有限的,但这次提高也是全面的,正是这一次设计让我积累了大量的实际经验,使我的头脑更好的被知识武装了起来,也必然会让我在未来的工作学习中表现出更高的理解能力,更强的沟通能力和更快的应变能力。指导教师渊博的知识、严谨的治学态度、兢兢业业的工作作风、忘我的工作精神和谦和的为人使我受益匪浅,老师的教诲和启发使我终生难忘。最终按质按量完成本次设计,我的收获是很难用语言来描述的,非常感谢老师的指导与帮助!
限制150内