基于单片机的八路抢答器.docx
- 文档编号:27614193
- 上传时间:2023-07-03
- 格式:DOCX
- 页数:31
- 大小:166.03KB
基于单片机的八路抢答器.docx
《基于单片机的八路抢答器.docx》由会员分享,可在线阅读,更多相关《基于单片机的八路抢答器.docx(31页珍藏版)》请在冰豆网上搜索。
基于单片机的八路抢答器
基于单片机的八路抢答器
第1章绪论
1.1课题研究现状
随着我国抢答器市场的迅猛发展,与之相关的核心生产技术应用与研发必将成为业内企业关注的焦点。
技术工艺,是衡量一个企业是否具有先进性,是否具备市场竞争力,是否能不断领先于竞争者的重要指标依据。
了解国内外抢答器生产核心技术的研发动向、工艺设备、技术应用及趋势对于企业提升产品技术规格,提高市场竞争力十分关键。
目前市场上抢答器种类繁多,功能各异,价格差异也很大。
那么选择一款真正适合的抢答器就非常重要。
抢答器一般分为电子抢答器和电脑抢答器。
目前电子抢答器的中心构造一般都是由数字电子集成电路组成,其搭配的配件不同又分为,非语音非记分抢答器和语音记分抢答器。
非语音记分抢答器构造很简单,就是一个抢答器的主机和一个抢答按钮组成,在抢答过程中选手是没有记分的显示屏。
语音记分抢答器是由一个抢答器的主机、主机的显示屏以及选手的记分显示屏等构成,具有记分等功能。
电子抢答器多适用于学校和企事业单位举行的简单的抢答活动。
电脑抢答器又分为无线电脑抢答器和有线电脑抢答器。
无线电脑抢答器是由主机和抢答器专用的软件和无线按钮构成。
无线电脑抢答器利用电脑和投影仪,可以把抢答气氛活跃起来,一般多使用于电台等大型的活动。
有线电脑抢答器也是由主机和电脑配合起来,电脑再和投影仪配合起来,利用专门研发的配套
八路智能抢答器的设计的抢答器软件,可以十分完美的表现抢答的气氛。
抢答器作为一种电子产品,早已广泛应用于各种智力和知识竞赛场合,但目前所使用的抢答器有很多的缺点,有的电路较复杂不便于制作,可靠性低,实现起来很困难;有的则用一些专用的集成块,而专用集成块的购买又很困难。
而我所设计的八路智能抢答器,具有元件普通,易于购买等优点,很好地解决了制作困难和难于购买的问题。
在国内外已经开始普遍应用。
1.2目的与意义
在知识比赛中,特别是做抢答题目的时候,在抢答过程中,为了知道哪一组或哪一位选手先答题,必须要设计一个系统来完成这个任务。
如果在抢答中,靠视觉是很难判断出哪组先答题。
怎样来设计抢答器,能使以上问题得以解决?
即使两组的抢答时间相差几微秒,也可分辨出哪组优先答题?
通过研究并在设计验证后发现,采用单片机技术设计的抢答器与传统的抢答器相比,首先,电路连接简单,因为大多数功能单元都通过程序设计在单片机内部。
第二,工作性能可靠,抗干扰能力优于传统抢答器,并能够解决以上提出的问题。
所以本研究是一个实用的工程设计,具有创新性。
通过这次设计,掌握51单片机的原理,了解简单多功能抢答器组成原理,初步掌握多功能抢答器的调整及测试方法,提高动手能力和排除故障的能力。
同时通过本课题设计与装配、调试,提高自己的动手能力,巩固已学的理论知识,建立单片机理论和实践的结合,了解多功能抢答器各单元电路之间的关系及相互影响,从而能正确设计、计算定时计数的各个单元电路。
初步掌握多功能抢答器的调整及测试方法。
提高动手能力和排除故障的能力。
1.3课题研究的内容
本系统采用模块化设计智能抢答器,在抢答比赛中广泛应用,各组分别有一个抢答按钮。
主持人有开始抢答键、复位键。
并可根据具体情况,修改抢答时间和答题时间,原始状态下抢答时间为30s,回答问题时间为15s。
通过加键和减键修改上述时间,改完后断电后重新上电即可。
新时间开始有效,主持人按键开始后,选手开始抢答为有效,数码显示屏显示抢答时间倒计时和选手号,在最后五秒扬声器发生提示。
如果主持人没有按下开始键而选手就抢答视为犯规,数码显示屏显示犯规者的代号,扬声器持续发生。
主持人可按复位键,新一轮抢答开始。
通过研究并在设计验证后发现,采用单片机技术设计的抢答器与目前常用的抢答器相比,首先,电路连接简单,因为大多数功能单元都通过程序设计在单片机内部,第二,工作性能可靠,抗干扰能力优于目前抢答器。
所以本研究是一个实用的工程设计,具有创新性。
第2章系统总体方案设计
2.1设计要求
设计并制作一个功能稳定,外观简洁的实用八路抢答器,基本的要求有:
1)可同时提供最多包括8个人(组)的抢答数量。
2)需由主持人按下开始抢答按键后才视为抢答时间,在这个时间前抢答的,视为违规抢答,要求能显示出违规抢答的选手编号。
3)要求当主持人按下开始抢答的按键后,数码管进行抢答时间的倒计时,在这个倒计时结束后,若无人抢答,蜂鸣器报警,提示本轮抢答结束,且这个抢答时间可设置。
4)要求具有抢答锁定功能,即某一选手抢到后,其它选手的抢答功能被锁定,无法进行抢答,直至下一轮抢答开始。
5)对于抢到题目的选手,要求能显示出该选手的编号,并将其答题时间进行倒计时显示,在倒计时结束后,蜂鸣器报警,提示本次答题时间到,且这个抢答时间可设置。
2.2方案选择
根据目前市场上抢答器的种类,抢答器的种类可以大体分为三种,以下我们对这三种进行详细比较。
方案一:
抢答器系统的各部分均采用中小规模集成数字电路,利用硬件电子元器件实现,用机械开关按钮作为控制开关,完成抢答输入信号的触发。
如采用74LS148优先编码器来实现抢答功能等。
该方案的特点是中小规模集成电路应用技术成熟,性能可靠,能方便地完成选手抢答的基本功能,没有软件的设计部分,不需要编程,但是电路结构复杂,调试困难,涉及到的外围元器件很多,造成抢答器的成本较高,并且制作过程工序比较烦琐,不便于安装与调试,给实际操作带来很大的麻烦。
方案二:
系统设计主要基于可编程的PLC设计,系统包括硬件和软件两大部分,依据控制系统的工作原理和技术性能,将硬件和软件分开设计。
硬件设计部分包括电路原理图、合理选择元器件、绘制线路图,然后对硬件进行调试、测试,以达到设计要求。
软件设计部分,首先在总体设计中完成系统总框图和各模块的功能设计,选择合适的编程语言和工具,进行代码设计等;最后是对软件进行调试、测试,达到所需功能要求。
方案三:
系统采用STC89C52单片机作为控制核心,其片内带有8KflashROM,128的RAM,以及32根I/O口线能满足设计要求。
该系统可以完成运算控制、信号识别以及显示功能的实现。
利用单片机程序判断选手按键是否有效,但是选手违规抢答,利用简答程序显示,启动蜂鸣器报警,告诉主持人有人违规操作,抢答无效。
给出相应的延时,选手按正常的操作抢答,软件倒计时,利用数码管的动态扫描,实现倒计时显示时间,到5秒相应时间提醒选手时间快到了,要及时作答,并启动蜂鸣器。
由于用了单片机,使其技术比较成熟,应用起来方便、简单并且单片机周围的辅助电路也比较少,便于控制和实现。
整个系统具有极其灵活的可编程性,能方便地对系统进行功能的扩张和更改性。
方案比较分析:
从第一个方案我们可以看出,这个抢答器是由抢答电路,定时电路,报警电路,时序控制电路四个关键电路部分组成。
扩展电路是由秒钟脉冲信号产生电路,译码电路,显示电路等,它的功能很齐全,设计的电路也很稳定。
但是它的造价却很高,仅仅是集成电路他就用了八个,这个跟我们当初的设计理念是相冲突的。
我们要的是功能齐全,但是造价比较低的设计。
所以我们放弃这个方案。
而方案二采用可编程PLC设计实现的抢答器,但该系统的投入成本过于高昂,软件编程过于繁琐,对编程的语言掌握程度要求很高,而且其PLC在该领域的应用很少,普通人对PLC的理解及掌握都不是很深入,鉴于通用性和节省的原则,我们依然不采用该方案。
方案三采用单片机为核心器件,外围电路采用集成芯片,其可靠性好,结构简单,不但从性能上优于方案一和方案二,而且在使用上及其功能的实现上都较其他方案简洁,并且由于单片机具有优越的高集成电路性,使其工作速度更快、效率更高。
另外单片机采用12MHz的晶振,提高了信号的测量精度,并且使该系统可以通过软件改进来扩张功能。
该模式充分体现了原有系统性能的改进,功能的扩展及其他同类系统的不同之处,它包括硬件逻辑图与软件流程图,比较经济实用,所以我们选用单片机的方案。
第3章系统硬件设计
3.1八路抢答器整体方案设计
3.1.1系统概述
整个系统以STC89C52单片机为核心器件,其它个模块围绕着单片机展开。
输入部分包括2个内容,一个是选手的抢答输入,另一个是主持人的控制输入,由于这两个内容都是通过按键控制的,所以这里统一使用普通的轻触开关作为本设计的输入模块,一共包括8个选手输入按键和2个主持人输入按键。
输出部分则采用蜂鸣器加四位共阳数码管进行声光的输出,蜂鸣器主要起到报警的作用,这里主要有几个需蜂鸣器发出报警的地方,如最后5秒仍无人抢答、答题剩余最后5秒、抢答时间结束以及答题时间结束等。
而数码管则主要用于信息的输出,包括当主持人按下开始抢答按键后,显示30秒(默认)的倒计时,当有选手违规抢答时,显示违规选手的编号,有人抢到题目时,显示选手编号以及该选手剩余的答题时间。
3.1.2系统框图
3.1对讲机系统框图
3.2最小系统模块
3.2.1STC89C52简介
(1)概述
STC89C52是一个低电压,高性能CMOS8位单片机,片内含8kbytes的可反复擦写的Flash只读程序存储器和256bytes的随机存取数据存储器(RAM),器件采用ATMEL公司的高密度、非易失性存储技术生产,兼容标准MCS-51指令系统,片内置通用8位中央处理器和Flash存储单元,功能强大的AT89C52单片机可为您提供许多较复杂系统控制应用场合。
STC89C52有40个引脚,32个外部双向输入/输出(I/O)端口,同时内含2个外中断口,3个16位可编程定时计数器,2个全双工串行通信口,2个读写口线。
STC89C52有PDIP、PQFP/TQFP及PLCC等三种封装形式,以适应不同产品的需求。
(2)主要功能特性
兼容MCS51指令系统;
8k可反复擦写(>1000次)FlashROM;
32个双向I/O口;
256x8bit内部RAM;
3个16位可编程定时/计数器中断;
时钟频率0-24MHz;
2个串行中断;
可编程UART串行通道;
2个外部中断源;
共8个中断源;
2个读写中断口线;
3级加密位;
低功耗空闲和掉电模式;
软件设置睡眠和唤醒功能;
(3)8051单片机的引脚功能
MCS-51系列单片机一般采用40个引脚,双列直插式封装,用HMOS工艺制造,其外部引脚排列如图3.2所示。
其中,各引脚的功能为:
u图3.2STC89C52
(1)主电源引脚
Vcc(40脚),接+5V电源正端;
Vss(20脚),接+5V电源地端;
一般Vcc和Vss间应接高频去耦电容和低频滤波电容。
(2)外接晶体或外部振荡器引脚
XTAL1(19脚),接外部晶振的一个引脚。
在单片机内部,它是一个反相放大器的输入端,这个放大器构成了片内振荡器OSC。
当采用外部振荡器时,此引脚应接地。
XTAL2(18脚),接外部晶振的另一个引脚。
在片内接至反相放大器的输出端和内部时钟电路的输入端。
当采用外部振荡器时,此脚接外部振荡器的输出端。
(3)控制信号线
RST/VPD(9脚),复位信号输入端,复位/掉电时内部RAM的备用电源输入端。
ALE/(30脚),地址锁存允许/编程脉冲输入,用ALE锁存从P0口输出的低8位地址;在对片内EPROM编程时,编程脉冲由此输入。
PSEN/(29脚),外部程序存储器读选通信号,低电平有效。
EA(31脚),访问外部存储器允许/编程电压输入。
EA为高电平时,访问内部存储器;低电平时,访问外部存储器。
(4)多功能I/O口引脚
8051单片机设有4个双向I/O口(P0、P1、P2、P3),每一组I/O口线都可以独立地用作输入或输出口,其中:
P0口(32~39脚)——双向口(三态),可作为输入/输出口,可驱动8个LSTTL门电路。
实际应用中常作为分时使用的地址/数据总线口,对外部程序或数据存储器寻址时低8位地址与数据总线分时使用P0口:
先送低8位地址信号到P0口,由地址锁存信号ALE的下降沿将地址信号锁存到地址锁存器后,再作为数据总线的口线对数据进行输入或输出。
P1口(1~8脚)——准双向口(三态),可驱动4个LSTTL门电路。
用作输入线时,口锁存器必须由单片机先写入“1”,每一位都可编程为输入或输出线。
P2口(21~28)——准双向口(三态),可驱动4个LSTTL门电路。
可作为输入/输出口,实际应用中一般作为地址总线的高8位,与P0口一起组成16位地址总线,用于对外部存储器的接口电路进行寻址。
P3口(10~17脚)——准双向口(三态),可驱动4个LSTTL门电路。
双功能口,作为第一功能使用时,与P1口一样;作为第二功能使用时,每一位都有特定用途,其特殊用途如表3.1所示:
端口引脚
第二功能
注释
P3.0
RXD
串行口数据接收端
P3.1
TXD
串行口数据发送端
P3.2
/INT0
外中断请求0
P3.3
/INT1
外中断请求1
P3.4
T0
定时/计数器0外部计数信号输入
P3.5
T1
定时/计数器1外部计数信号输入
P3.6
/WR
外部RAM写选通信号输出
P3.7
/RD
外部RAM读选通信号输出
表3.1P3口第二用途
3.2.2最小系统电路
STC89C52的最小系统如图3.3所示,整个最小系统由4个部分组成,晶振电路部分、复位电路部分、P0口上拉电路部分以及程序下载口部分。
30pF的电容C4和C5,以及12M的晶振X1构成了单片机的晶振电路,2个小电容的作用是帮助X1起振。
复位电路由10uF的极性电容C1和10K的电阻R2构成,本复位电路包括上电自复位和按键复位2个功能。
由于STC89C52的P0口是漏极开路输出,而本设计是将P0口用作数码管的数据口,因此在P0口接了一个10K的排阻,使得P0口可以作为普通的I/O口使用,
最后,为了方便调试和下载,还把P30、P31、GND和VCC这4个引脚通过排针引出来作为程序的下载口。
图3.3单片机最小系统
3.3键盘扫描电路
键盘是人与单片机打交道的主要设备。
站在系统监控软件设计的立场上来看,仅仅完成键盘扫描,读取当前时刻的键盘状态是不够的,还有不少问题需要妥善解决,否则,人们在操作键盘就容易引起误操作和操作失控现象。
在单片机应用中键盘用得最多的形式是独立键盘及矩阵键盘。
它们各有自己的特点,其中独立键盘硬件电路简单,而且在程序设计上也不复杂,一般用在对硬件电路要求不高的简单电路中;矩阵键盘与独立键盘有很大区别,首先在硬件电路上它要比独立键盘复杂得多,而且在程序算法上比它要烦琐,但它在节省端口资源上有优势得多,因此它更适合于多按键电路。
其次就是消除在按键过程中产生的“毛刺”现象。
这里采用最常用的方法,即延时重复扫描法,延时法的原理为:
因为“毛刺”脉冲一般持续时间短,约为几ms,而我们按键的时间一般远远大于这个时间,所以当单片机检测到有按键动静后再延时一段时间后再判断此电平是否保持原状态,如果是则为有效按键,否则无效。
本设计中采用了独立键盘的方式,本设计中有8个抢答按键输入,一个复位按键以及一个主持人使用的开始抢答按键,同时为了简化电路设计,节约单片机的IO口资源,将设置抢答时间和答题时间等这些功能按键复合到了8个选手的抢答按键中。
按键的连接图3.4所示:
图3.4按键电路
3.4蜂鸣器报警电路
由于蜂鸣器工作时,需要的电流比较大,单片机的IO口输出的电流又比较小,所以这里利用三极管的开关管功能来控制蜂鸣器发音,本设计选用的三极管型号是PNP三极管S8550,而且本设计选用的蜂鸣器属于有源蜂鸣器,即在蜂鸣器内部已经内置了震荡电路,单片机无需连续发出高低电平来驱动它,而只要输出高(或低)电平即可,这大大简化了单片机程序的设计,由于选用的是PNP型而单片机上电IO口默认是高电平的,所以上电时蜂鸣器是不会发出鸣叫的。
蜂鸣器电路如图3.5所示。
图3.5蜂鸣器电路
3.5数码管显示模块
显示功能与硬件关系极大,当硬件固定后,如何在不引起操作者误解的前提下提供尽可能丰富的信息,全靠软件来解决。
在这里我们使用的是七段数码管显示,通常在显示上我们采用的方法一般包括两种:
一种是静态显示,一种是动态显示。
其中静态显示的特点是显示稳定不闪烁,程序编写简单,但占用端口资源多;动态显示的特点是显示稳定性没静态好,程序编写复杂,但是相对静态显示而言占用端口资源少。
在本设计中
根据实际情况采用的是动态显示方法。
数码管还分共阳型和共阴型,本设计采用的是4位共阳数码管。
通过查表法,将其在数码管上显示出来,其中P0口为字型码输入端,P2口低4位为字选段输入端。
在这里我们通过查表将字型码送给7段数码管显示的数字,4位七段数码管显示电路如图3.6所示。
其中A、B、C、D、E、F、G、DP段分别接到单片机的P0口,由单片机输出的P0口数据来决定段码值,位选码W1、W2、W3、W4分别接到单片机的P2^0、P2^1、P2^2以
及P2^3上,由单片机来决定当前该显示的是哪一位。
由于单片机的IO口驱动电流不够,这里还使用了4个NPN的三极管S8050作为开关管,来驱动数码管的位选。
图3.6数码管显示电路
第4章系统软件设计
4.1总体程序设计
八路抢答器的整体程序流程图如图4.1所示,程序从定时器的初始化开始,这里用到了单片机的2个定时器,1个用于数码管的动态扫描,另一个用于答题时间的计时。
接着程序开始判断是否进入抢答时间设置,如果有则进入抢答时间设置模式,没有则继续判断是否进入答题时间设置,如果有则进入答题时间设置模式,没有则跳出,进入主程序的大循环。
进入大循环之后,就扫描是否有按键按下,有的话就判断是哪个按键,如果是主持人按下了开始抢答按键,则进入抢答模式,如果是选手按下了抢答减,则蜂鸣器报警,此时有选手违规抢答(即在主持人按下开始抢答按键前就抢答了),同时将违规选手的编号显示在数码管上,直至主持人按下复位键,则清除报警状态。
如果一直没检测到按键按下,则一直在大循环里面扫描按键。
进入抢答模式后,数码管开始将抢答时间倒计时并显示在数码管上,如果在抢答时间内无人抢答,则在最后5秒发出滴滴上的报警,并且5秒结束后,蜂鸣器一直鸣叫,表示此轮抢答结束,并且数码管显示“----”,直至主持人按下复位键退出报警。
如果在抢答时间内有选手抢答题目时,则在数码管将选手的编号显示出来,并显示答题时间的倒计时,同抢答时间一样,在最后5秒会发出滴滴的报警声,答题时间结束后,蜂鸣器也会一直鸣叫,表示此轮抢答结束,直至主持人按下复位键退出报警。
是
是否设置抢答时间
设置抢答时间
否
是
设置答题时间
是否设置答题时间
否
等待按键按下
是
是否违规抢答
否
是
发出警报
结束
答题倒计时
是否有选
手抢答
否
图4.1八路抢答器程序流程图
4.2抢答/答题时间设置
为了简化抢答器的硬件电路,所以将抢答时间和答题时间的设置按键和抢答键合并到了一起。
如需设置抢答时间时,操作是这样的,先断开抢答器的电源,然后按下按键一(选手一的抢答键),然后上电,系统上电检测到按键一被按下了,那么就进入到抢答时间的设置,通过按键七(减)和按键八(加)来设置答题时间的大小。
答题时间的设置也基本类似,只不过是在上电前按下按键二而已。
4.3数码管动态扫描程序
为了简化程序,合理利用单片机的内部资源,所以将数码管的动态扫描程序通过定时器来实现。
本设计设置的定时器发生中断的时间为2毫秒,每次显示四位中的一位,因此,完成四位数码管的扫描需要8毫秒的时间,即发生四次定时器中断。
第5章总结
本文研究设计的八路抢答器采用了通用的电子元器件,利用STC89C52单片机及外围接口实现强大系统,利用单片机的定时器、计数器定时和计数的原理,将软硬件有机的结合起来。
理论联系实践,体现出大学生的动手能力。
通过查资料和收集有关的文献,培养了自学能力和动手能力。
并且有原先的被动接受只是转换为主动寻求知识,这可以说是学习方法上的一个很大突破。
在以往的传统学习模式下,我们可能会记住很多书本知识,但是通过毕业设计,我们学会了如何将学到的知识化为自己的东西,学会了怎么更好的处理知识和实践相结合的问题,把握重点,攻克难关,学到用到活学活用。
在设计过程中由于时间仓促有很多地方难免存在不足之处,但在以后的工作中,我们会严格
要求自己最求完美。
在这次毕业设计中,我最想感谢的就是我的指导老师。
从我确定课题之后,老师就开始悉心指导我。
整个过程多次询问我的进度和遇到的问题,积极引导我如何解决问题,帮我开拓思路。
老师一丝不苟的作风,严谨的求实态度,不进只是传授我知识那么简单,更加让我懂得了做人的道理。
所以在完成毕业设计之余,不得不感谢我的指导老师。
参考文献
[1]苏平.单片机的原理与接口技术[M].北京:
电子工业出版社,2006.
[2]王忠民.微型计算机原理[M].西安:
西安科技大学出版,2003
[3]纪宗南.单片机外围器件使用手册[M].北京:
北京航空航天大学出版社.
[4]余永权.单片机在控制系统中的应用[M].北京:
电子工业出版社
[5]周润景.张丽娜.基于PROTEUS的电路及单片机系统设计与仿真[M].
北京:
航空航天大学出版社
[6]唐俊翟.单片机原理与应用[M].北京:
冶金工业出版社.252-267
[7]康华光.电子技术基础.数字部分(第四版)[M].高等教育出版社.2003
附录
附录一:
原理图
附图1对讲机原理图
附录二:
元件清单
STC89C52
1片
12M晶振
1个
30pF独石电容
2个
电解电容10uF
1个
电阻1K
1个
电阻10K
1个
排阻10K
1片
红色led
1个
轻触按键
10个
4位共阳数码管
1个
电源开关
1个
DC5.5电源座/电池盒
1个
排针(用于下载程序)
4针
有源蜂鸣器
1个
PNP三极管8550
1个
NPN三极管8050
4个
40脚IC座
1个
洞洞板(万用板)
1张
电源线(若用电池盒供电则没有)
1根
附录三:
C语言程序
#include
#include
#defineucharunsignedchar
#defineuintunsignedint
sfrISP_DATA=0xe2;sfrISP_ADDRH=0xe3;
sfrISP_ADDRL=0xe4;sfrISP_CMD=0xe5;
sfrISP_TRIG=0xe6;
sfrISP_CONTR=0xe7;
sbitw1=P2^3;sbitw2=P2^2;/sbitw3=P2^1;sbitw4=P2^0;sbitk1=P1^0;sbitk2=P1^1;sbitk4=P1^3;sbitk5=P1^4;
sbitk7=P1^6;sbitk8=P1^7;sbitk9=P3^7;sbitbp=P2^6;/UcharcodeShowDig[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 单片机 八路 抢答