找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3568|回复: 2
收起左侧

单片机四位竞赛抢答器系统Proteus仿真程序设计

[复制链接]
ID:795080 发表于 2021-1-5 17:49 | 显示全部楼层 |阅读模式
四位竞赛抢答器系统设计
1、设计一个四位竞赛抢答单片机系统,可同时供 4 名选手或 4 个代表队参加比赛,
每队设置单独的抢答按钮,编号为 1、2、3、4;
2、给节目主持人设置一个“抢答开始”控制开关,用来控制抢答开始;
3、给节目主持人设置一个“系统清除”控制开关,用来控制系统清零;
4、抢答器具有编号锁存、抢答计分、时间显示和声响提示等功能。
1)主持人按下“抢答开始”后,系统以减计时方式,显示抢答剩余时间。
2)如果抢答时间计时结束,却没有选手抢答时,本次抢答无效,系统报警提示(显
示单音,持续 2 秒);
3)抢答时间内,若有选手按动对应的抢答按钮,此对编号立即锁存,数码管上显
示出队伍编号和此队累计分数,同时系统给出音响提示(显示单音,持续 2 秒)。
4)在主持人启动“抢答开始”键前,选手提前抢答,抢答无效,系统报警提示(显
示单音,持续 2 秒)。
5、抢答成功后,禁止其他选手抢答,优先抢答选手的编号一直保持到主持人将系
统清零为止;
6、抢答器具有利用旋钮调整抢答时间功能,时间范围 20 秒~50 秒。
  我们需要硬件操作,仿真图中的显示是根据我们用的试验箱调整的,另外我加了正误判断。其中还是有一些小的问题要改的。(懒不想改了)
需要其他功能可以自己看着改。

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)

仿真图

仿真图


单片机源程序如下:
  1. #include<reg52.h>
  2. #include<intrins.h>

  3. #define u8 unsigned char
  4. #define u16 unsigned int
  5. #define LED_xianshi P0   //数码管显示端口
  6. #define LED_wei P2  //位选
  7. #define KEY_COL P3  //P3口计时信号输ru

  8. sbit start=P1^5;  //P1^5 开始抢答
  9. sbit clear=P1^4;  //清零信号

  10. sbit man1=P1^0;  //4人抢答口
  11. sbit man2=P1^1;
  12. sbit man3=P1^2;
  13. sbit man4=P1^3;

  14. sbit s1=P3^0;//对错判断
  15. sbit s2=P3^1;

  16. sbit k1=P2^0;//位选
  17. sbit k2=P2^1;
  18. sbit k3=P2^2;
  19. sbit k4=P2^3;

  20. char dc=0;

  21. int man=0;
  22. int score[4]={0,0,0,0}; //分数存储开始为0
  23. int cont=0;
  24. int state=0;  //状态

  25. int sec0=20;  //起始值
  26. int sec=20;   //调节后的值
  27. char ji=0;
  28. char si=0;
  29. sbit warningLED =P1^7;  //蜂鸣器声响控制

  30. char biaozhi=0;

  31. //u8 code seg[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00,0x40};
  32. u8 code seg[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0x11,0xbf};
  33. unsigned int T0RH,T0RL,T1RH,T1RL;
  34. u8 duan[]={0x5f,0x5f,0x5f,0x40};
  35. u8 ad0;
  36. u8 KEY_up_flag=1;
  37. u8 KEY_use=0;

  38. char code dx516[3] _at_ 0x003b;

  39. u8 flag500ms=0;  //设置标志位
  40. u8 startflag=0;
  41. u8 warning=0;
  42. unsigned char GetADCValue(unsigned char chn);  //函数申明调用
  43. extern void I2CStart();
  44. extern void I2CStop();
  45. extern unsigned char I2CReadNAK();
  46. extern bit I2CWrite(unsigned char dat);
  47. unsigned char KEYscan();  //键盘扫描
  48. void reset_init();
  49. void KEYexe(u8 val);
  50. void Duanmove(u8 Movedir);
  51. void shanshuo();

  52. int scanduicuo();



  53. void delay2s()
  54. {
  55.         TMOD=0x11;
  56.         TH1=0x3c;
  57.         TL1=0xb0;
  58.         ET1=1;
  59.         TR1=1;
  60.         EA=1;
  61. }

  62. void delay(u16 t)
  63. {
  64.         while(t--);
  65. }

  66. void chushihua()
  67. {
  68.         TMOD=0x11;
  69.         TH0=0x3c;
  70.         TL0=0xb0;
  71.         EA=1;
  72.         ET0=1;
  73.         TR0=1;
  74. }

  75. void display()
  76. {
  77.                 k4=0;
  78.                 LED_xianshi=duan[0];
  79.                 delay(255);
  80.                 k4=1;
  81.                 LED_xianshi=0x00;
  82.                
  83.                 k3=0;
  84.                 LED_xianshi=duan[1];
  85.                 delay(255);
  86.                 k3=1;
  87.                 LED_xianshi=0x00;
  88.                
  89.                 k2=0;
  90.                 LED_xianshi=duan[2];
  91.                 delay(255);
  92.                 k2=1;
  93.                 LED_xianshi=0x00;
  94.                
  95.                 k1=0;
  96.                 LED_xianshi=duan[3];
  97.                 delay(255);
  98.                 k1=1;
  99.                 LED_xianshi=0x00;
  100. }

  101. void main()
  102. {


  103.        
  104.         chushihua();
  105.        
  106.         warningLED=0;
  107.        
  108.         while(1)
  109.         {
  110.                 k4=0;
  111.                 LED_xianshi=duan[0];
  112.                 delay(255);
  113.                 k4=1;
  114.                 LED_xianshi=0x00;
  115.                
  116.                 k3=0;
  117.                 LED_xianshi=duan[1];
  118.                 delay(255);
  119.                 k3=1;
  120.                 LED_xianshi=0x00;
  121.                
  122.                 k2=0;
  123.                 LED_xianshi=duan[2];
  124.                 delay(255);
  125.                 k2=1;
  126.                 LED_xianshi=0x00;
  127.                
  128.                 k1=0;
  129.                 LED_xianshi=duan[3];
  130.                 delay(255);
  131.                 k1=1;
  132.                 LED_xianshi=0x00;
  133.                
  134.                
  135.                 KEYscan();  //判断是那个人按下
  136.                 if(state==0)    //在未开始时能进行的操作
  137.                 {
  138.                         ad0=GetADCValue(0);  //在未开始时可以设置倒计时初值;
  139.                         sec0=ad0*30/255+20;
  140.                        
  141.                         duan[3]=0xbf;
  142.                         duan[2]=0xbf;
  143.                         duan[1]=seg[sec0/10];
  144.                         duan[0]=seg[sec0%10];       
  145.                        
  146.                         delay(255);
  147.                        
  148.                         if(man!=0)
  149.                         {
  150.                                 man=0;
  151.                                 warning=1;
  152.                         }
  153.                        
  154.                         if(start==0)
  155.                         {
  156.                                 reset_init();//按下开始后倒计时 state标志位置1
  157.                                 state=1;
  158.                         }
  159.                 }
  160.                
  161.                 if(state==1)  //处于开始的状态时
  162.                 {
  163.        
  164.                         if(man!=0)
  165.                         {
  166.                                 dc=0;
  167.                                 while(!dc)
  168.                                 {
  169.                                         scanduicuo();
  170.                                        
  171.                                         k4=0;
  172.                                         LED_xianshi=seg[man];
  173.                                         delay(255);
  174.                                         k4=1;
  175.                                         LED_xianshi=0x00;
  176.                                        
  177.                                         k3=0;
  178.                                         LED_xianshi=0xbf;
  179.                                         delay(255);
  180.                                         k3=1;
  181.                                         LED_xianshi=0x00;
  182.                                        
  183.                                         k2=0;
  184.                                         LED_xianshi=0xbf;
  185.                                         delay(255);
  186.                                         k2=1;
  187.                                         LED_xianshi=0x00;
  188.                                        
  189.                                         k1=0;
  190.                                         LED_xianshi=0xbf;
  191.                                         delay(255);
  192.                                         k1=1;
  193.                                         LED_xianshi=0x00;
  194.                                        
  195.                                         if(clear==0)
  196.                                         {
  197.                                                 state=2;
  198.                                                 break;
  199.                                         }
  200.                                 }
  201.                                 score[man-1]=score[man-1]+cont; //抢到后判断对错。对了加一分,错了不加分
  202.                                 duan[3]=seg[man];
  203.                                 duan[2]=seg[17];
  204.                                 duan[1]=seg[score[man-1]/10%10];
  205.                                 duan[0]=seg[score[man-1]%10];
  206.                                
  207.                                 display();
  208.                                
  209.                                 state=2;
  210.                                 warning=1;
  211.                         }
  212.                         else
  213.                         {
  214.                                 if(flag500ms)
  215.                                 {
  216.                                         flag500ms=0;
  217.                                         sec--;
  218.                                         duan[3]=0xff;
  219.                                         duan[2]=0xff;
  220.                                         duan[1]=seg[sec/10%10];
  221.                                         duan[0]=seg[sec%10];
  222.                                         if(sec==0)
  223.                                         {
  224.                                                 warning=1;
  225.                                                 state=2;
  226.                                         }
  227.                                 }
  228.                         }
  229.                 }
  230.                 else if(state==2)
  231.                 {
  232.                         if(start==1)
  233.                         {
  234.                                 man=0x0000;
  235.                                 delay(255);
  236.                                 state=0;
  237.                         }
  238.                 }
  239.                 if(clear==0)
  240.                 {
  241.                         state=0;
  242.                         score[3]=0;
  243.                         score[2]=0;
  244.                         score[1]=0;
  245.                         score[0]=0;
  246.                         duan[3] = seg[17];
  247.                         duan[2] = seg[17];
  248.                         duan[1] = seg[17];
  249.                         duan[0] = seg[17];
  250.                        
  251.                         display();
  252.                        
  253.                         warningLED=0;
  254.                         delay(1000);
  255.                         while(!clear)  //直到清零状态结束
  256.                         {
  257.                                 display();
  258.                         }
  259.                 }
  260.                 if(warning)
  261.                 {
  262.                         warning=0x0000;
  263.                         shanshuo();
  264.                 }
  265.         }
  266. }

  267. unsigned char GetADCValue(unsigned char chn)
  268. {
  269.         unsigned char val;

  270.         I2CStart();
  271.         if(!I2CWrite(0x48<<1))
  272.         {
  273.                 I2CStop();
  274.                 return 0;
  275.         }
  276.         I2CWrite(0x40 | chn);
  277.         I2CStart();
  278.         I2CWrite(0x48<<1 | 0x01);

  279.         val = I2CReadNAK();
  280.         I2CStop();

  281.         return val;
  282. }

  283. unsigned char KEYscan()
  284. {
  285.         if(man1==0)
  286.         {
  287.                 delay(1000);
  288.                 if(man1==0)
  289.                 {
  290.                         man=1;
  291.                 }
  292.         }
  293.         if(man2==0)
  294.         {
  295.                 delay(1000);
  296.                 if(man2==0)
  297.                 {
  298.                         man=2;
  299.                 }
  300.         }
  301.         if(man3==0)
  302.         {
  303.                 delay(1000);
  304.                 if(man3==0)
  305.                 {
  306.                         man=3;
  307.                 }
  308.         }
  309.         if(man4==0)
  310.         {
  311.                 delay(1000);
  312.                 if(man4==0)
  313.                 {
  314.                         man=4;
  315.                 }
  316.         }  //扫描谁按下的
  317.         if(start==1)
  318.         {
  319.                 state=0;
  320.         }
  321.         if(start==0)
  322.         {
  323.                 state==1;
  324.         }
  325.         if(clear==0)
  326.         {
  327.                 state==2;
  328.         }
  329. }

  330. void reset_init()
  331. {
  332.         sec=sec0;
  333.         duan[3] = 0;
  334.         duan[2] = 0;
  335.         duan[1] = seg[sec/10%10];
  336.         duan[0] = seg[sec%10];
  337.        
  338.         man=0;
  339.         flag500ms=0;
  340.         TH0=0x3c;
  341.         TL0=0xb0;
  342. }

  343. void shanshuo()
  344. {

  345.         warningLED=1;
  346.         delay2s();
  347.         while(warningLED)
  348.         {
  349.                 display();
  350.         }
  351.         if(warningLED==0 || si==0)
  352.         {
  353.                 TR1=0;
  354.                 ET1=0;
  355.         }
  356. }
  357. //定时
  358. void time() interrupt 1
  359. {       
  360.         TH0=0x3c;
  361. ……………………

  362. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
设计1.1.zip (165.13 KB, 下载次数: 75)
回复

使用道具 举报

ID:865245 发表于 2021-5-15 18:49 | 显示全部楼层
我想知道这个break是怎么使用的
回复

使用道具 举报

ID:996762 发表于 2021-12-25 14:07 | 显示全部楼层
Chen1108 发表于 2021-5-15 18:49
我想知道这个break是怎么使用的

这个程序那里有break
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

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