本文主要是介绍0496-基于单片机的表决器(七人)系统设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
功能描述
1、采用51单片机作为主控芯片;
2、采用矩阵按键,每人两个按键,分别代表同意和反对;
3、按下"开始键"后,进入10秒倒计时,超时投票无效;
4、采用数码管显示:倒计时、表决结果、表决票数;
5、表决结果:"P"表示通过、"F"表示不通过,倒计时结束显示;
6、表决票数:"A"显示同意票数,"o"显示不同意票数,投票过程实时显示;
7、表决开始和结束,采用蜂鸣器声音提示;
8、按下"复位键"后,进行下一次投票。
电路设计
采用Altium Designer作为电路设计工具。Altium Designer通过把原理图设计、PCB绘制编辑、拓扑逻辑自动布线、信号完整性分析和设计输出等技术的完美融合,为设计者提供了全新的设计解决方案,使设计者可以轻松进行设计,熟练使用这一软件必将使电路设计的质量和效率大大提高。
单片机管脚说明:
P0端口(P0.0-P0.7):P0口为一个8位漏极开路双向I/O口,每个引脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。
P1端口(P1.0-P1.7):P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高电平,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。
P2端口(P2.0-P2.7):P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口,用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。
P3端口(P3.0-P3.7):P3口管脚是一个带有内部上拉电阻的8位的双向I/O端口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入端时,由于外部下拉为低电平,P3口将输出电流(ILL)。P3口同时为闪烁编程和编程校验接收一些控制信号。
仿真设计
采用Proteus作为仿真设计工具。Proteus是一款著名的EDA工具(仿真软件),从原理图布图、代码调试到单片机与外围电路协同仿真,一键切换到PCB设计,真正实现了从概念到产品的完整设计。
主程序设计
void main()
{//buzzbiaozhi1=0; //开始按键标志位//矩阵bjs=0; //总表决计数bjs1=0; //同意票数统计bjs2=0; //反对票数统计djs=10; //修改倒计时初始值Timer0_init(); //初始化定时器中断while(1){key_num=key_scan();if(djs<=0) //倒计时10s时间到{
// buzzbiaozhi1=0;flagD=0; //不再显示时间TR0=0; //关闭定时器flag1=0,flag2=0,flag3=0,flag4=0,flag5=0,flag6=0,flag7=0;flag8=0,flag9=0,flag10=0,flag11=0,flag12=0,flag13=0,flag14=0; //关闭选手的按键 /*****判断是否通过******/// //新方法好用if(bjs1>=4) djsxs01();if(bjs1<4) djsxs10(); //大于四票显示通过,P代表通过 ,否则不通过 ,F表示switch(bjs1) //显示倒计时结束后同意的人数{case 0: djsxs0();djsxs20();break;case 1: djsxs1();djsxs20();break; case 2: djsxs2();djsxs20();break;case 3: djsxs3();djsxs20();break;case 4: djsxs4();djsxs20();break;case 5: djsxs5();djsxs20();break; case 6: djsxs6();djsxs20();break;case 7: djsxs7();djsxs20();break; default: ; }switch(bjs2) //显示倒计时结束后不同意的人数{case 0: djsxs00();djsxs30();break;case 1: djsxs11();djsxs30();break; case 2: djsxs22();djsxs30();break;case 3: djsxs33();djsxs30();break;case 4: djsxs44();djsxs30();break;case 5: djsxs55();djsxs30();break; case 6: djsxs66();djsxs30();break;case 7: djsxs77();djsxs30();break; default: ; }}
源文件获取
关注公众号-电子开发圈,首页发送 “表决” 获取;
这篇关于0496-基于单片机的表决器(七人)系统设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!