找回密码
 注册

QQ登录

只需一步,快速开始

搜索

一款基于51单片机技术的电子抢答器protues仿真

[复制链接]
coolice 发表于 2020-1-22 23:54:47 | 显示全部楼层 |阅读模式
本文介绍用单片机技术设计的电子抢答器,除能完成基本的抢答功能外,还可进行加分、减分、存贮显示各组分数、答题限时抢答限时等功能.主要有选手抢答部分、主持人控制部分和数码管显示部分。优点是利用单片机来设计抢答器,使以上问题得以解决,即使两组的抢答时间相差几微秒,也可分辨出哪组优先答题。硬件电路简单,功能齐全,操作方便,是一款即先进又实用的电子抢答器.

一、使用说明:首先由主持按下开始键,单片机开始倒计时,选手们才可以开始抢答,单片机从30秒开始倒计时,如果在30秒内无人抢答,则自动放弃,进入下一题,若有人抢答,则单片机会自动检测是几号首先抢答,做出判断,之后数码管会显示,然后单片机重新倒计时,从90秒开始,若在90秒内回答完并回答正确,主持人可以按加分键,则所的分数会显示在选手的数码管上,若回答错误,则主持人可以通过减分键进行减分,然后进入下一题。
1.jpg
  1. #include<reg52.h>
  2. Static unsigned char dm[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
  3. static unsigned char px2[11]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f,0xff,0xff,0xff};
  4. static unsigned char px3[11]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xdf,0xbf,0x7f};
  5. static unsigned char xs[11]={0xc0,0xa4,0xc0,0xa4,0xc0,0xa4,0xc0,0xa4,0xc0,0xb0,0xc0};
  6. static unsigned char dj[4]={0};
  7. static unsigned char n,r;
  8. static unsigned char t=30;            //t:时间,k:溢出
  9. static unsigned char k,k2=0;
  10. static unsigned char kk,p;
  11. static unsigned char fen1=20,fen2=20,fen3=20,fen4=20;
  12. ///////////////////////////////////////////////////////
  13. void djxs1(unsigned char t)             //倒计时函数1
  14. {
  15. unsigned char i;
  16. if(t>23)           dj[3]=~((~dj[3])>>1);
  17. if((t>16)&&(t<24)) dj[2]=~((~dj[2])>>1);
  18. if((t>8)&&(t<17))  dj[1]=~((~dj[1])>>1);
  19. if((t>0)&&(t<9))   dj[0]=~((~dj[0])>>1);
  20. for(i=0;i<4;i++)
  21. {
  22.     SBUF=dj[i];
  23.         while(!TI){}
  24.         TI=0;
  25. }
  26. }
  27. /////////////////////////////////////////////
  28. void djxs2(unsigned char t)             //倒计时函数2
  29. {
  30. unsigned char i;
  31. if(t>69)           dj[3]=~((~dj[3])>>1);
  32. if((t>48)&&(t<70)) dj[2]=~((~dj[2])>>1);
  33. if((t>24)&&(t<49))  dj[1]=~((~dj[1])>>1);
  34. if((t>0)&&(t<25))   dj[0]=~((~dj[0])>>1);
  35. for(i=0;i<4;i++)
  36. {
  37.     SBUF=dj[i];
  38.         while(!TI){}
  39.         TI=0;
  40. }
  41. }
  42. //////////////////////////////////////////////////////////
  43. void t1(void)interrupt 3              //定时器1中断
  44. {
  45. TH1=0X15;
  46. TL1=0XA0;
  47. k++;
  48. if(k>20)
  49. {
  50. k=0;
  51. k2++;
  52. // if(t==90)
  53. // for(r=0;r<4;r++)dj[r]=0;
  54. if(kk)djxs1(t);
  55. if(p&&(k2==3)){k2=0;djxs2(t);}     //3秒
  56.                      //1秒                        //灯倒计时
  57.   t--;
  58.   xs[9]=dm[t/10];
  59.   xs[10]=dm[t%10];
  60.   if(t==0){for(r=0;r<4;r++)
  61.             dj[r]=0;
  62.            TR1=0;
  63.            xs[9]=dm[3];
  64.            xs[8]=dm[0];}
  65. }
  66. }
  67. ////////////////////////////////////////////////////////////

  68. void t0(void)interrupt 1         //定时器2中断
  69. {
  70. P0=xs[n];
  71. P2=px2[n];
  72. P3=px3[n];
  73. n++;
  74. if(n>10)n=0;
  75. TH0=0Xfe;
  76. TL0=0X00;
  77. }
  78. ////////////////////////////////////////////////////////////////
  79. char jianpan()                    //键盘函数
  80. {
  81. unsigned char x,d=500;
  82. P1=0xff;
  83. while(P1==0xff);
  84. x=P1;
  85. while(d--);
  86. d=500;
  87. while(P1!=0xff);
  88. return x;
  89. }
  90. ////////////////////////////////////////////////////////
  91. main()
  92. {unsigned char x,y,m;
  93. // unsigned char k;
  94. IE=0X8a;
  95. //TMOD=0X01;
  96. TMOD=0X11;
  97. TH0=0Xfe;
  98. TL0=0Xb8;
  99. TR0=1;                                             //数码管显示
  100. TH1=0X15;
  101. TL1=0XA0;
  102. loop: TR1=0;
  103.       t=30;
  104.       xs[8]=dm[0];
  105.       xs[9]=dm[3];
  106.       xs[10]=dm[0];
  107.       for(m=0;m<4;m++)
  108.       {dj[m]=0;
  109.       }
  110. for(m=0;m<4;m++)
  111.      {
  112.          SBUF=dj[m];
  113.          while(!TI){}
  114.          TI=0;
  115.      }                                               //灯全亮
  116.     while(1)
  117.    {
  118.      x=jianpan();                                 //扫描键盘
  119.      switch(x)
  120.     {
  121.         case 0xef:                                //开始键按下
  122.           { kk=1;
  123.             p=0;
  124.             t=30;                                      //音乐
  125.             TR1=1;                                  //灯逐个灭,数码管减一
  126.             while(t)                                //30秒内
  127.            { y=jianpan();
  128.                //if(y&&0x0f!=0x0f)
  129.                 for(m=0;m<4;m++)
  130.                 {
  131.                   dj[m]=0;}
  132.                   k2=0;
  133.                   t=90;
  134.                   p=1;
  135.               switch(y)
  136.              {
  137.                case 0xfe:{xs[8]=dm[1];                       //一键按下
  138.                            kk=0;t=90;k2=0;                                       
  139.                            while(1)
  140.                           {                                  //重新倒计时
  141.                             if(P1==0xdf){fen1+=5;
  142.                                        xs[0]=dm[fen1%10];            //加分
  143.                                        xs[1]=dm[fen1/10];goto loop;}
  144.                           if(P1==0xbf){fen1-=5;
  145.                                        xs[0]=dm[fen1%10];            //减分
  146.                                        xs[1]=dm[fen1/10];goto loop;}
  147.                            }
  148.                          break;}           //显示一
  149.                 case 0xfd:{xs[8]=dm[2];                              //二键按下
  150.                                kk=0;t=90;k2=0;
  151.                            while(1)
  152.                           {
  153.                           if(P1==0xdf){fen2+=5;
  154.                                        xs[2]=dm[fen2%10];
  155.                                        xs[3]=dm[fen2/10];goto loop;}
  156.                           if(P1==0xbf){fen2-=5;
  157.                                        xs[2]=dm[fen2%10];
  158.                                        xs[3]=dm[fen2/10];goto loop;}
  159.                            }
  160.                           break;}   //显示二
  161.                 case 0xfb:{xs[8]=dm[3];                            //三键按下
  162.                            kk=0;t=90;k2=0;
  163.                            while(1)
  164.                       {                                //重新倒计时
  165.                           if(P1==0xdf){fen3+=5;
  166.                                        xs[4]=dm[fen3%10];
  167.                                        xs[5]=dm[fen3/10];goto loop;}
  168.                           if(P1==0xbf){fen3-=5;
  169.                                        xs[4]=dm[fen3%10];
  170.                                        xs[5]=dm[fen3/10];goto loop;}
  171.                            }
  172.                            break;}   //显示三
  173.                 case 0xf7:{xs[8]=dm[4];                             //四键按下
  174.                            kk=0;t=90;k2=0;                          //重新倒计时
  175.                            while(1)
  176.                           {
  177.                           if(P1==0xdf){fen4+=5;
  178.                                        xs[6]=dm[fen4%10];
  179.                                        xs[7]=dm[fen4/10];goto loop;}
  180.                           if(P1==0xbf){fen4-=5;
  181.                                        xs[6]=dm[fen4%10];
  182.                                        xs[7]=dm[fen4/10];goto loop;}
  183.                            }
  184.                            break;}   //显示四
  185.                 default:break;
  186.               }
  187.               }
  188.       goto loop;}         //无人抢答
  189.       default:break;}    //开始switch
  190.     }                    //总while
  191. }
复制代码
抢答器文档及其proteus仿真资料.zip (30.71 KB, 售价: 1 E币)
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|ELEOK |网站地图

GMT+8, 2024-12-23 15:11

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表