53 基于单片机的8路抢答器加记分

目录

一、主要功能

二、硬件资源

三、程序编程

四、实现现象


一、主要功能

首先有三个按键 分别为开始 暂停 复位,然后八个选手按键,开机显示四条杠,然后按一号选手按键,数码管显示30,这时候二号选手按键是加时间,三号宣誓减时间,这个是抢答倒计时,再按一次一号选手按键,数码管显示30是答题倒计时时间,同样二号和三号按键可以加减时间,然后再按1号按键,此时进入计分时刻,此时数码管是显示是1-00,然后2号键和3号键加减分数,此时数码管显示四条杠,此时按开始键,数码管开始抢答倒计时,此时比如1号按键按下,直接跳到答题倒计时,此时数码管显示1-30,这个30比如就是答题时间,开始倒计时,之前得抢答最后五秒内没人按就蜂鸣器报警,这个答题也是如此,然后答题30秒倒计时完后,,按复位键再按开始建可以重新开始抢答。还有一个违规抢答的功能 就是如果主持人没按开始,选手按抢答了会报警

二、硬件资源

基于KEIL5编写C++代码,PROTEUS8.15进行仿真,全部资源在页尾,提供安装包。

三、程序编程

#include<reg51.h>
#include<intrins.h>
sbit smg1=P2^4;		//定义数码管第一位
sbit smg2=P2^6;		//定义数码管第二位
sbit smg3=P2^7;		//定义数码管第三位
sbit smg4=P2^5;sbit keyks=P2^2;	//定义开始按键
sbit keytz=P2^1;	//定义停止按键
sbit keyqc=P2^0;	//定义清除按键sbit key1=P1^4;		//定义1号抢答选手		 
sbit key2=P1^5;		//定义2号抢答选手
sbit key3=P1^6;		//定义3号抢答选手
sbit key4=P1^7;		//定义4号抢答选手
sbit key5=P3^4;		//定义5号抢答选手
sbit key6=P3^5;		//定义6号抢答选手
sbit key7=P3^6;		//定义7号抢答选手
sbit key8=P3^7;		//定义8号抢答选手
sbit spk=P1^0;		//定义蜂鸣器
static int djs=30,djs2=30,djs3=30,js=0,xh=1,fs1,fs2,fs3,fs4,fs5,fs6,fs7,fs8;		   //djs和bt是初始倒计时时间,可修改
int fs[8];
unsigned char flag=0,flag1=0,flag2=0,flag3=0;
//int table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
int table[]={0x5f,0x44,0x9d,0xd5,0xc6,0xd3,0xdb,0x45,0xdf,0xd7,0x80};void delayms(int x)	   //延时函数
{
char i;
while(x--){for(i=500;i>0;i--); }
}void djsxsjf() 
{int b1,b2;b1=fs[xh]/10;b2=fs[xh]%10;				  // 将倒计时时间分成高低位P0=table[b1];smg2=0;delayms(3);smg2=1;					 //显示十位数字P0=table[b2];smg3=0;delayms(3);				 //显示个位数字smg3=1;P0=0x80;smg4=0;delayms(3);				 //显示个位数字smg4=1;P0=table[xh];smg1=0;delayms(3);				 //显示个位数字smg1=1;
}void djsxs200()
{int b1,b2;b1=djs2/10;b2=djs2%10;				  // 将倒计时时间分成高低位P0=table[b1];smg2=0;delayms(3);smg2=1;					 //显示十位数字P0=table[b2];smg3=0;delayms(3);				 //显示个位数字smg3=1;
}void djsxs()				   //显示倒计时函数
{	int b1,b2;b1=djs/10;b2=djs%10;				  // 将倒计时时间分成高低位P0=table[b1];smg2=0;delayms(3);smg2=1;					 //显示十位数字P0=table[b2];smg3=0;delayms(3);				 //显示个位数字smg3=1;
}
void djsxs30() //第二位数码管显示-{P0=0x80;			//第二位数码管smg4=0;delayms(3);smg4=1;}
void djsxs22()				 {	P0=0x80;smg1=0;delayms(3);smg1=1;//第一位数码管显示-P0=0x80;			//第二位数码管smg4=0;delayms(3);smg4=1;P0=0x80;smg2=0;delayms(3);			   //第三位数码管显示-smg2=1;P0=0x80;smg3=0;delayms(3);smg3=1;				  //第四位数码管显示-
}void djsxs1(){P0=table[1];smg1=0;delayms(3);smg1=1;				   //第一位数码管显示1}
void djsxs2(){P0=table[2];smg1=0;delayms(3);smg1=1;				//第一位数码管显示2}
void djsxs3(){P0=table[3];smg1=0;delayms(3);smg1=1;			  //第一位数码管显示3}
void djsxs4(){P0=table[4];smg1=0;delayms(3);smg1=1;			 //第一位数码管显示4}
void djsxs5(){P0=table[5];smg1=0;delayms(3);smg1=1;		   //第一位数码管显示5}
void djsxs6(){P0=table[6];smg1=0;delayms(3);smg1=1;			//第一位数码管显示6}
void djsxs7(){P0=table[7];smg1=0;delayms(3);smg1=1;		  //第一位数码管显示7
}
void djsxs8(){P0=table[8];smg1=0;delayms(3);smg1=1;		 //第一位数码管显示8}
void main()
{
int djs1=30;
Timer0_init();	 //初始化定时器中断
spk=1;			  //蜂鸣器不响
djs=30;		//倒计时赋值
djs1=30;
while(1)
{LOOP1:   djs=djs1;djs2=djs3;
djsxs22();	//LOOP1是标号,显示 -  --if(key1==0)		 //在定时器运行状态下,key1==0 则说明1号选手按下按键{delayms(3);if(key1==0){ flag3 = 1;flag1++;if(flag1>3){flag1=0;}while(!key1);	  //去除按键抖动后,重新在判断,是否确实按下djs=30;djs2=30;while(1){TR0=0;		  //定时器停止if(flag1==1){djsxs();	}if(flag1 == 2){djsxs200();//答题}if(flag1 == 3){djsxsjf();//记分}if(key2==0)	  //复位按下按下{	delayms(8);		   //去除抖动if(key2==0)	   //再次判断是否按下复位按键{do{ while(!key2); //如果按下复位键,则回到- --状态delayms(5);}while(key2!=1);if(flag1 == 1){djs++;djs1=djs;}if(flag1 == 2){djs2++;djs3=djs2;}if(flag1 == 3){switch(xh){case 1:fs1++;fs[1]=fs1;break;case 2:fs2++;fs[2]=fs2;break;case 3:fs3++;fs[3]=fs3;break;case 4:fs4++;fs[4]=fs4;break;case 5:fs5++;fs[5]=fs5;break;case 6:fs6++;fs[6]=fs6;break;case 7:fs7++;fs[7]=fs7;break;case 8:fs8++;fs[8]=fs8;break;}}}}if(key3==0)	  //复位按下按下{	delayms(8);		   //去除抖动if(key3==0)	   //再次判断是否按下复位按键{ do{while(!key3); //如果按下复位键,则回到- --状态delayms(5);	}while(key3!=1);if(flag1 == 1){djs--;djs1=djs;}if(flag1 == 2){djs2--;djs3=djs2;}if(flag1 == 3){switch(xh){case 1:fs1--;fs[1]=fs1;break;case 2:fs2--;fs[2]=fs2;break;case 3:fs3--;fs[3]=fs3;break;case 4:fs4--;fs[4]=fs4;break;case 5:fs5--;fs[5]=fs5;break;case 6:fs6--;fs[6]=fs6;break;case 7:fs7--;fs[7]=fs7;break;case 8:fs8--;fs[8]=fs8;break;}}}}if(key1==0)	  //复位按下按下{	delayms(3);		   //去除抖动if(key1==0)	   //再次判断是否按下复位按键{ flag1++;if(flag1>3){flag1 = 0;}while(!key1); //如果按下复位键,则回到- --状态if(flag1 == 0){goto LOOP1;		  //goto语句,回到loop1表号处}}}										   }}}if(keyks==0){	delayms(3);		 //去除按键抖动if(keyks==0){ flag3 = 1;flag2++;while(!keyks);	  //以上表示按下开始按键 TR0=1;			   //启动定时器 开始倒计时while(1){if(flag2>2){flag2 = 1;}if(flag2 == 1){djsxs();}if(flag2 == 2){djsxs200();}if(keytz==0){delayms(3);			 //此处表示出去抖动, 以后不一一标出if(keytz==0){ while(!keytz);	   //以上表示按下停止按键后 {TR0=0;		   //定时器停止flag=0;//spk=1;}}}if(keyks==0){delayms(3);if(keyks==0){ while(!keyks);	   //以上表示按下清楚按键后 TR0=1;		   //定时器启动}}
/***************************以下是八个选手抢答,key1表示1号选手,依次类推,注释只写第一位选手,其他和第一个完全一致,************************************/if((key1==0)&&(TR0==1))		 //在定时器运行状态下,key1==0 则说明1号选手按下按键{		spk=0;		 //蜂鸣器响delayms(3);if(key1==0){ while(!key1);	  //去除按键抖动后,重新在判断,是否确实按下{xh = 1;flag2=2;spk=1;		  //蜂鸣器不响flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs1();	  //显示选手编号djsxs30();	  //第二位数码管显示djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);		   //去除抖动if(keyqc==0){ while(!keyqc); //如果按下清楚键,则回到- --状态goto LOOP1;		  //goto语句,回到loop1表号处}}										   }}}if((key2==0)&&(TR0==1)){	spk=0;delayms(3);if(key2==0){ while(!key2);{xh = 2;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs2();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key3==0)&&(TR0==1)){	spk=0;delayms(3);if(key3==0){ while(!key3);{xh = 3;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs3();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key4==0)&&(TR0==1)){	spk=0;delayms(3);if(key4==0){ while(!key4);{xh = 4;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs4();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key5==0)&&(TR0==1)){	spk=0;delayms(3);if(key5==0){ while(!key5);{xh = 5;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs5();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key6==0)&&(TR0==1)){  spk=0;delayms(3);if(key6==0){ while(!key6);{xh = 6;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs6();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}										   }}}if((key7==0)&&(TR0==1)){	spk=0;delayms(3);if(key7==0){ while(!key7);{xh = 7;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs7();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}	   }}}if((key8==0)&&(TR0==1)){	spk=0;delayms(3);if(key8==0){ while(!key8);{xh = 8;flag2=2;spk=1;flag=0;//清0最后五秒响蜂鸣器}while(1){djsxs8();djsxs30();	  //第二位数码管显示-djsxs200();	  //显示剩余倒计时时间if(djs2<=5) {flag=1; }if(djs2==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;goto LOOP1;	} if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);goto LOOP1;	}}	   }}} if(djs<=5)  {flag=1; }//spk=0;	  //到倒计时小于5是,蜂鸣器响if(djs==0)			   //当倒计时时间等于0后,需要按清楚键恢复{flag=0;spk=1;while(1){if(keyqc==0){	delayms(3);if(keyqc==0){ while(!keyqc);spk=1;		  goto LOOP1;	}}}} }}}if(flag3 == 0){if(key2==0){delayms(3);if(key2 == 0){spk = 0;while(!key2);}}if(key3==0){delayms(3);if(key3 == 0){spk = 0;while(!key3);}}if(key4==0){delayms(3);if(key4 == 0){spk = 0;while(!key4);}}if(key5==0){delayms(3);if(key5 == 0){spk = 0;while(!key5);}}if(key6==0){delayms(3);if(key6 == 0){spk = 0;while(!key6);}}if(key7==0){delayms(3);if(key7 == 0){spk = 0;while(!key7);}}if(key8==0){delayms(3);if(key8 == 0){spk = 0;while(!key8);}}}}}

四、实现现象

具体动态效果看B站演示视频:

基于单片机的8路抢答器加记分_哔哩哔哩_bilibili

全部资料(源程序、仿真文件、安装包、原理图、演示视频):
链接: https://pan.baidu.com/s/1bYm0-YgFOqER36jrQ_xpTQ?pwd=49kj 提取码: 49kj 
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/483054.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深度学习基础03_BP算法(下)过拟合和欠拟合

目录 一、BP算法(下) 0、反向传播代码回顾 写法一&#xff1a; 写法二(更常用)&#xff1a; 1、BP中的梯度下降 1.数学描述 2.传统下降方式 3.优化梯度下降方式 指数加权平均 Momentum AdaGrad RMSProp Adam(常用) 总结 二、过拟合和欠拟合 1、概念 1.过拟合 …

WPF+MVVM案例实战与特效(三十)- 封装一个系统日志显示控件

文章目录 1、运行效果2、日志控件封装1、文件创建2、DisplayLogPanel.xaml 代码3、DisplayLogPanel.cs 代码4、数据模型5、枚举类型3、自定义控件使用1、LogPanelWindow.xaml2、LogPanelViewModel.cs4、总结1、运行效果 2、日志控件封装 1、文件创建 打开 Wpf_Examples ,在 …

Ubuntu 20.04 Server版连接Wifi

前言 有时候没有网线口插网线或者摆放电脑位置不够时&#xff0c;需要用Wifi联网。以下记录Wifi联网过程。 环境&#xff1a;Ubuntu 20.04 Server版&#xff0c;无UI界面 以下操作均为root用户&#xff0c;如果是普通用户&#xff0c;请切换到root用户&#xff0c;或者在需要权…

计算机网络:IP协议详细讲解

目录 前言 一、IP网段划分 二、IP报头 三、解决IP地址不足-->NAT技术 前言 在之前&#xff0c;我们学习了传输层中的TCP和UDP&#xff0c;重点是TCP协议&#xff0c;他帮我们解决具体到主机的哪个应用&#xff08;端口&#xff09;、传输的可靠&#xff08;序列号、校验和…

基于大数据python 电商数据分析及推荐可视化系统(源码+LW+部署讲解+数据库+ppt)

&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 很对人不知道选题怎么选 不清楚自己适合做哪块内容 都可以免费来问我 避免后期給自己答辩找麻烦 增加难度&#xff08;部分学校只有一次答辩机会 没弄好就延迟…

三种方式(oss、本地、minio)图片的上传下载

一、OSS 1、前期准备 1.1 注册阿里云账号&#xff0c;开启对象存储oss功能&#xff0c;创建一个bucket&#xff08;百度教程多的是&#xff0c;跟着创建一个就行&#xff0c;创建时注意存储类型是标准存储&#xff0c;读写权限是公共读&#xff09; 有的在创建桶时读写属性是…

Z2400032基于Java+Mysql+SSM的校园在线点餐系统的设计与实现 代码 论文

在线点餐系统 1.项目描述2. 技术栈3. 项目结构后端前端 4. 功能模块5. 项目实现步骤注意事项 6.界面展示7.源码获取 1.项目描述 本项目旨在开发一个校园在线点餐系统&#xff0c;通过前后端分离的方式&#xff0c;为在校学生提供便捷的餐厅点餐服务&#xff0c;同时方便餐厅和…

【前端】理解 JavaScript 中 typeof 操作符的独特行为

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: 前端 文章目录 &#x1f4af;前言&#x1f4af;typeof 操作符的基本使用&#x1f4af;为什么 typeof 数组是 "object"&#xff1f;&#x1f4af;为什么 typeof {} 返回 "object"&#xff1f;&…

Github提交Pull Request教程 Git基础扫盲(零基础易懂)

1 PR是什么&#xff1f; PR&#xff0c;全称Pull Request&#xff08;拉取请求&#xff09;&#xff0c;是一种非常重要的协作机制&#xff0c;它是 Git 和 GitHub 等代码托管平台中常见的功能&#xff0c;被广泛用于参与社区贡献&#xff0c;从而促进项目的发展。 PR的整个过…

C/C++ 数据结构与算法【线性表】 顺序表+链表详细解析【日常学习,考研必备】带图+详细代码

1&#xff09;线性表的定义 线性表&#xff08;List&#xff09;&#xff1a;零个或多个数据元素的有限序列。 线性表的数据集合为{a1,a2,…,an}&#xff0c;假设每个元素的类型均为DataType。其中&#xff0c;除第一个元素a1外&#xff0c;每一个元素有且只有一个直接前驱元素…

浏览器的数据六种存储方法比较 :LocalStorage vs. IndexedDB vs. Cookies vs. OPFS vs. WASM-SQLite

在构建该 Web 应用程序&#xff0c;并且希望将数据存储在用户浏览器中。也许您只需要存储一些小标志&#xff0c;或者甚至需要一个成熟的数据库。 我们构建的 Web 应用程序类型发生了显着变化。在网络发展的早期&#xff0c;我们提供静态 html 文件。然后我们提供动态渲染的 h…

【C++boost::asio网络编程】有关异步读写api的笔记

异步读写api 异步写操作async_write_someasync_send 异步读操作async_read_someasync_receive 定义一个Session类&#xff0c;主要是为了服务端专门为客户端服务创建的管理类 class Session { public:Session(std::shared_ptr<asio::ip::tcp::socket> socket);void Conn…

芯片测试-RF中的S参数,return loss, VSWR,反射系数,插入损耗,隔离度等

RF中的S参数&#xff0c;return loss, VSWR&#xff0c;反射系数&#xff0c;插入损耗&#xff0c;隔离度 &#x1f4a2;S参数&#x1f4a2;&#x1f4a2;S11与return loss&#xff0c;VSWR&#xff0c;反射系数&#x1f4a2;&#x1f4a2;S21&#xff0c;插入损耗和增益&#…

2024年Java面试八股文大全(附答案版)

很多人会问Java面试八股文有必要背吗&#xff1f; 我的回答是&#xff1a;很有必要。你可以讨厌这模式&#xff0c;但你一定要去背&#xff0c;因为不背你就进不了大厂。 国内的互联网面试&#xff0c;恐怕是现存的、最接近科举考试的制度。 而且&#xff0c;我国的八股文确…

我不是挂王-用python实现燕双鹰小游戏

一.准备工作 1.前言提要 作为程序员在浩瀚的数字宇宙中&#xff0c;常常感觉现实世界是一台精密运作的虚拟机&#xff0c;其底层的物理逻辑如同铁律般难以撼动。然而我们拥有在虚拟世界中自由驰骋、创造无限可能的独特力量。突发奇我想用Python写出燕双鹰的小游戏,这样想想就很…

Python语法基础(七)

&#x1f308;个人主页&#xff1a;羽晨同学 &#x1f4ab;个人格言:“成为自己未来的主人~” 我们今天的这篇文章&#xff0c;主要和大家讲一下函数重写的问题。 首先&#xff0c;我们要知道的是&#xff0c;函数重写是有前提条件的&#xff0c;那就是继承。 自定义函数…

NaviveUI框架的使用 ——安装与引入(图标安装与引入)

文章目录 概述安装直接引入引入图标样式库 概述 &#x1f349;Naive UI 是一个轻量、现代化且易于使用的 Vue 3 UI 组件库&#xff0c;它提供了一组简洁、易用且功能强大的组件&#xff0c;旨在为开发者提供更高效的开发体验&#xff0c;特别是对于构建现代化的 web 应用程序。…

神经网络入门实战:(九)分类问题 → 神经网络模型搭建模版和训练四步曲

(一) 神经网络模型搭建官方文档 每一层基本都有权重和偏置&#xff0c;可以仔细看官方文档。 pytorch 官网的库&#xff1a;torch.nn — PyTorch 2.5 documentation Containers库&#xff1a;用来搭建神经网络框架&#xff08;包含所有的神经网络的框架&#xff09;&#xff1b…

以AI算力助推转型升级,暴雨亮相CCF中国存储大会

2024年11月29日-12月1日&#xff0c;CCF中国存储大会&#xff08;CCF ChinaStorage 2024&#xff09;在广州市长隆国际会展中心召开。本次会议以“存力、算力、智力”为主题&#xff0c;由中国计算机学会&#xff08;CCF&#xff09;主办&#xff0c;中山大学计算机学院、CCF信…

Java中的“抽象类“详解

1.抽象类的定义 在面向对象的概念中,所有的对象都是通过,类来描述的,但是反过来,不是所有的类都是用来描述对象的,如果一个类中没有包含足够的信息来描述一个具体的对象,这样的类就是抽象类 抽象类的概念是比较抽象的,比如现在有一个"父类"是"动物类",继…