您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > 基于80C51的八路抢答器的单片机课程设计
1目录1引言............................................................................................................................42总体方案设计............................................................................................................43硬件电路设计............................................................................................................53.1单片机及其外围电路......................................................................................53.2硬件电路组成..................................................................................................64系统软件设计..........................................................................................................104.1初始化程序设计............................................................................................104.2主程序设计..................................................................................................................114.3倒计时30s子程序的设计............................................................................124.4外部中断T1中断子程序设计.....................................................................144.5定时器T1中断子程序设计.........................................................................174.6选手按键程序的设计....................................................................................184.7数码管显示程序的设计................................................................................195系统调试与总结......................................................................................................21附录A系统原理图....................................................................................................22附录B源程序............................................................................................................2221引言此次设计提出了用80C51单片机为核心控制元件,设计一个简易的抢答器,本方案以80C51单片机作为主控核心,与数码管、蜂鸣器等构成八路抢答器,利用了单片机的延时电路、按键复位电路、时钟电路、定时/中断等电路,设计的八路抢答器具有倒计时和实时显示抢答选手的号码的特点,还有复位电路,使其再开始新的一轮的答题和比赛。它的功能实现是比赛开始,主持人读完题之后按下总开关,倒计时开始,此时数码管开始进行30s的倒计时,是选手的思考时间,倒计时完后,才允许开始抢答,若有人答题,对应的会在数码管上显示出该选手的编号并由蜂鸣器发出声音,在30s倒计时内答题无效。2总体方案设计图2.1总体电路设计框图总体程序设计思路图为如图2.1所示。复位电路:当一轮进行完时,由主持人按下,下一轮倒计时开始,复位电路蜂鸣电路AT89C51复位电路///主持人案件抢答器倒计时显示电路独立式按键键盘3接P3.3口。独立式按键键盘:用于输入高低电平,连接到P1口,由P1口检测电平的变化。抢答器倒计时显示电路:有三位数码管组成,前两位显示30s倒计时,由第三位显示成功抢答选手编号。蜂鸣电路:有选手抢答成功,P3.1口发出脉冲,使蜂鸣器发出声音。3硬件电路设计3.1单片机最小系统微控制器采用AT89C51。AT89C51是美国ATMEL公司生产的与MCS-51系列单片机完全兼容的高性能CMOS8位单片机,MCS-51系列单片机以其推出时间早、配套资源丰富、开发手段完善、性价比高等特点而得到了广泛的应用,是单片机的主流品种。AT89C51的内部资源主要包括:·与MCS--51系列完全兼容的高性能8位CPU;·4K字节可重复编程的Flash存储器;·256字节的SRAM;·4个8位的并行口,共32条I/O口线;·3个16位的定时器/计数器;·6个中断源,2个中断优先级的中断系统;·一个全双工的串行口;·内部振荡器;·可编程串行通道·低功耗的闲置和掉电模式·片内振荡器和时钟电路其最小系统主要包括复位电路,时钟电路,如下图3.1所示。4图3.1单片机最小系统电路图3.2硬件电路功能说明(1)复位电路的设计MCS-5l的复位输入引脚RST为MCS-51提供了初始化的手段,可以使程序从指定处开始执行,在MCS-5l的时钟电路工作后,只要RST引脚上出现超过两个机器周期以上的高电平时,即可产生复位的操作.只要RST保持高电平,则MCS-5l循环复位.只有当RST由高电平变低电平以后。MCS-51才从0000H地址开始执行程序。本系统采用按键复位方式的复位电路。复位电路:当一轮进行完时,由主持人按下,下一轮倒计时开始,如图3.2所示。5图3.2复位控制电路(2)独立式按键键盘设计键盘接口中使用多少根I/O线,键盘中就有几个按键,键盘接口使用了8根I/O口线,该键盘就有8个按键,这种类型的键盘,其按键比较少,且键盘中各按键的工作互不干扰。因此可以根据实际需要对键盘中的按键灵活的编码。最简单的编码方式就是根据I/O输入口所直接反映的相应按键,按下的状态进行编码,称按键直接状态码,对于这样编码的独立式键盘,CPU可以通过直接读取I/O口的状态来获取按键的直接状态编码值,根据这个值直接进行按键识别,这样形式的键盘结构简单,按键识别容易。独立式键盘的缺点是需要占用比较多的I/O口线,当单片机应用系统键盘中需要的按键比较少或I/O口线比较富余时,可以采用这样类型的键盘。独立式按键键盘:用于输入高低电平,八位选手抢答时高低电平发生变化,如图3.3所示。6图3.3抢答按键部分(3)数码管显示部分设计LED动态显示是单片机中应用最为广泛的一种显示方式,其接口电路是把所有显示器的8个笔划段a-dp同名端并联在一起,而每一个显示器的公共极COM是各自独立地受I/O线控制,CPU的字段输出口送出字形码时,所有显示器由于同名端并连接收到相同的字形码,但究竟哪个显示器亮,则取决于COM端,而这一端是由I/O控制的,所以就可以自行决定何时显示哪一位了,在轮流点亮扫描过程中,每位显示器的点亮时间表是极为短暂的,但由于人的视觉暂留现象及发光二极管的余辉将就尽管实际上各位显示器并非间时点亮,但只要扫描速度足够快,给人的印象就是一组稳定的显示数据,不会有闪烁感。抢答器倒计时显示电路:有三位数码管组成,前两位显示30s倒计时,第三位显示成功抢答选手编号,如图3.4所示。7图3.4显示控制部分图(4)蜂鸣器电路设计我们知道,声音的频谱范围约在几十到几千赫兹,若能利用程序来控制单片机某个口线的“高”电平或低电平,则在该口线上就能产生一定频率的巨型波,接上喇叭就能发出一定频率的声音,若再利用延时程序控制“高”“低”电平的持续时间,就能改变输出频率,从而改变音调,使喇叭发出不同的声音。单片机通过内部定时器的操作实现交替变换的波形输出驱动扬声器发声,有选手抢答成功,使蜂鸣器发出声音,如图3.5所示。8图3.5蜂鸣器提示时间部分图4系统软件设计系统软件分为主程序、中断服务程序和子程序三部分4.1主程序(主程序流程框图见图4.1)9开始设置堆栈倒计时设置设置定时方式赋值初值标志位设置中断允许设置键盘扫描程序显示程序无中断显示000等待中断结束图4.1主程序流程框图主程序是系统上电或复位后首先要执行的程序,主程序主要完成系统的初始化、扫描显示、扫描键盘等工作。程序流程如图4.1所示,对单片机进行初始化,包括设置堆栈、倒计时30S设置、定时器T0设置,外部中断设置,键盘扫描设置,初始化状态时显示000。4.3倒计时30s子程序:(定时器T0中断子程序框图如图4.2所示)10开始把A、PSW放入堆栈倒计时设置1S到否倒计时存入59H中十位存入61H、个位存入60H中调用显示子程序弹出A、PSW退出中断结束YN图4.2定时器T0中断子程序框图首先要把累加器ACC和程序状态字PSW放入堆栈保护,然后进行倒计时的设置,设置为30S倒计时,先看看1S到没,如果到,倒计时自动减1,并在数码管显示,再判断倒计时的30s到没,没到继续倒计时并显示,倒计时计完为止,然后弹出累加器ACC与程序状态字PSW,中断退出,返回到中断入口处。4.4外部中断T1中断子程序:(外部T1中断子程序框图如图4.3所示)11开始把A、PSW放堆栈20H位置0调用显示子程序使三个标志位清零T0开始定时T1停止使(21H)置0、30S倒计时设置退出ACC、PSW中断返回图4.3外部T1中断子程序框图外部中断T1中断时要先把累加器ACC和程序状态字PSW放入堆栈保护,然后把20H标志位置0,再调用显示程序,T0开始定时,T1停止,然后设置30S倒计时,设置之后弹出累加器ACC与程序状态字PSW,中断退出,返回到中断12入口处。4.5定时器T1中断子程序:(定时器T1中断程序框图如图4.4所示)开始把ACC、PSW放入堆栈响铃中断返回图4.4定时器T1中断程序框图定时器T1中断时要先把累加器ACC和程序状态字PSW放入堆栈保护,然后就是响铃,接上喇叭,利用延时程序控制“高”“低”电平的持续时间,就能改变输出频率,从而改变音调,使喇叭发出不同的声音。设置之后弹出累加器ACC与程序状态字PSW,中断退出,返回到中断入口处。4.6选手按键程序:(键盘扫描程序框图如图4.5所示)13开始(20H)、(21H)是否为0扫描P1口选手号保存置位(20H)开始响铃返回调用结束是否扫描到最后0Y1YNN图4.5键盘扫描程序框图键盘扫描时先判断20H单元和21H单元标志位是否为0,是的话说明允许键盘扫描,否的话即不允许键盘扫描,不允许扫描就返回调用,结束,允许扫描时开始扫描P1口看有没有选手按下答题键,按下时此口变为低电平0,如果没有选手按键,则判断P1口有没有扫描完,没有扫描完就继续扫描,扫面完没有选手按下就检查20H和21H4.7数码管显示程序:(显示子程序框图如图4.6所示)14开始选手号在数码管显示出来倒计时显示
本文标题:基于80C51的八路抢答器的单片机课程设计
链接地址:https://www.777doc.com/doc-6298286 .html