基于单片机的班级投票器课程设计Word格式文档下载.docx
《基于单片机的班级投票器课程设计Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《基于单片机的班级投票器课程设计Word格式文档下载.docx(25页珍藏版)》请在冰豆网上搜索。
2.3总原理图和元器件淸单11
2.3.1总原理图11
2.3.2元件淸单11
3系统软件设计12
3.1主程序设计12
13
3.2中断程序设计
3.3定时程序设计14
4调试16
16
5总结
6致谢语17
参考文献17
附录一PCB图19
附录二源程序19
引言
在大学生活中,时常发生选举投票事件。
目前班级职位选举采用纸条的方式进行投票。
具体过程如下:
首先,在黑板上列出要选举的职位及职位候选人的名字;
接着班级成员在纸条上写上候选人的名字,折叠好放在指左的位苣(如讲台桌上);
再来全部投票完毕后,进行唱票,判断票的有效性(写上多于一个候选人的划字,或不写都视为废票),同时并统计票数。
最后,票数统汁完成后先判断本次选举是否有效(若发生选票多于选民数,视为无效)。
确泄本次选举有效后,宣布最髙得票者为该职位的的当选者。
这样的选举的缺点是比较费时,效率不高,同时也由于可能发生的选举无效问题,造成时间的延长,同时降低班级成员的积极性等。
其优点就是选举十分的直观,可以在唱票时期直接观察到每个候选人的得票情况,并较直接判断岀当选人。
针对纸条选举费时,效率不高的问题,采用设计投票器来改善这一情况。
本设il•是基于单片机设计的适用于班级选举的投票器,由键盘专用芯片74C922完成投票,再经由单片机采集信息,统计票数。
最后由四联数码管显示投票结果。
并且利用发光二极管和一个按键来控制投票的有效性。
选举投票期间可暂停投票,査看当前投票结果,后可继续投票,直至达到预设的最大班级人数就会自动关闭投票系统。
本次设计的班级投票群可以有效地控制投票及选举的有效性,就石省了去判断选票及选举的有效性及选举无效延长的时间。
同时投票器本身有统计票数的功能,就又节省了统讣票数的时间。
整体上提高了班级选举的效率,同时也使得选举更加地民主,公平。
1、系统总体设计
1.1设计要求
假立班级成员45人,职位候选人10人(不超过10人)。
选民(班级成员)分别编号为01,02,……44,45:
候选人分别编号为01,02,……,09,10(由10个按键构成)。
(1)一上电不允许投票,按下允许投票键,利用10个按键进行投票,有效投票后显示选民编号和所选候选人的编号。
将投票结果储存起来并且再按其他按键无效。
(2)按下允许投票键进行下一个选民的投票。
(3)投票期间,可暂停投票来查看票数统讣结果,后按下允许投票键又可继续投票。
(4)全部成员投票完成后,最后显示候选人的编号及其得票数。
(5)按下复位键,进行新一轮的职位选举。
1.2系统组成方框图
图1-2系统模块组成方框图
1.3方案设计
设计时班级成员不超过99,职位候选人10人。
由键盘接口专用芯片74C922及12个按键(10个按键用于投票工作,2个按键用于査看投票结果)构成的电路来完成键盘扫描,编码,再通过AT89C51芯片来采集信息,进行票数的统讣。
由四联数码管完成显示工作,投票期间显示选民编号和所选候选人的编号,查看结果时显示候选人的编号及其得票数。
设置一按键来控制有效投票,并让发光二极管配合指示。
选举投票期间可暂停投票,查看投票结果,后可继续投票,直至达到预设的最大班级人数关闭投票系统。
2、系统硬件设计
2.1相关芯片介绍
2.1.1AT89C51芯片简介
AT89C51是一种低电压,高性能CM0S8位单片机,采用ATMEL公司的髙密度、非易失性存储技术生产,
兼容标准MCS-51指令系统,片内置通用8位中央处理器(CPU)和FLASH存储单元,功能强大AT89C51单片
机可为您提供许多髙性能比的应用场合,可灵活应用在各种控制领域。
川
它具有以下特点:
4K字节FLASH闪速存储器,128字节内部RAM,32个I/O口线,两个16位左时/计数器,一个5向量级中断接口,一个全双工串行通信口,片内振荡器及时钟电路。
同时.AT89C51可降至0Hz的静态逻辑操作,并支持两种软件可选的节电工作模式。
空闲方式停止CPU的工作,但允许RAH,左时/计数器,串行通信口及中断系统继续工作。
掉电方式保存RAH中的内容,但振荡器停止工作并禁止其它所有部件工作直到岀现下一个硬件复位。
U1
AT89C51
图2-1-1AT89C51引脚图
2.1.274C922芯片简介
74C922芯片有16键IC和20键IC,本设计采用的是16键的IC.图2-1-2
(1)所示为4X4(16键)扫描式编码键盘原理图。
这种键盘的按键排成矩阵形式,以减少按键联线。
如图中有16个键,排列成4行4列,仅需8根引线。
时钟发生器的输出送给4位计数器进行计数,计数器的低2位经译码后作为行扫描,髙2位经译码后作为列扫描。
若没有检出有键闭合,则计数器周而复始反复计数,即反复进行扫描,一旦检出有键闭合,就发出一个脉冲使时钟振荡器停振,汁数器随即停止计数。
单片机通过读取计数器的讣数值来获取闭合键所在的行列位置,然后从真值表得到按键读数。
如果有两个键同时按下,则扫描到第一个闭合键时就停止扫描,把该键当作有效按键进行处理。
E
74C922芯片(16键IC)的引脚排列如02-1-2
(2)所示:
5
VCC
18
6
11
Y1
ABC
D
1?
10
A1
X2
8
15
7
;
14
1
Y2
2
3
DA
12
4
I-J
Y4
GND
9
oe
U3
图2-1-2
(2)74C922引脚图
XI〜X4:
列线。
Y1〜Y4:
行线。
OSC:
接振荡电容0.luF,以便扫描矩阵键盘
KM:
键盘消除抖动电路,并发出两种信号。
⑴内部计数器停止计数。
(2)若有键按下,使DA脚由未按键时的低电平变为高电平,若按键未放开则一直保持髙电平,当按键放开时,才转为低电平。
此引脚外接一个电容是0SC所接电容的10倍。
DA:
数据有效信号。
若无键按下,保持低电平。
若有键按下,变为高电平,直到键放开,才转为低电平。
/0E:
输出使能。
D〜A:
按键值输岀,按BCD码输出,具体输岀情况如表2-1-2所示。
表2-1-2真值表
数据输岀
Yl,
XI
X3
X4
Y2,
Y3,
Y4,
A
B
C
2.1.374LS04芯片简介
741S04是一六反向器,苴功能表如表2-1-3,英引脚分布如图2-1-3。
表2」・3功能表
Y=a
输入
输出
Y
L
H
H为髙电平
L为低电平
图2-1-374LS04引脚图
2.2各单元电路设计与分析
2.2.1由74C922够成的键盘电路
1■2
——oc<
S4
oc«
S3
J
冬2
o0«
S1
Zl
Z
Y1/
S8
—■—
o
S7
『心<
-(
S6
—>
■—
oc<
S5
/
Y2/
0c
S12
dOSil
OO
S10
do
S9
^1/
图2-2-174C922构成的键盘电路
在键盘部分采用74C922来完成工作。
键盘电路图如图2-2-1所示。
74922芯片是专用编码键盘接口芯片,当按下某一按键时,该芯片能自动给出相应的编码信息,并可自动消除抖动,从而可免除关于削抖的软件编程,提高了CPU的利用率。
⑵因为按键扫描要对按键进行削抖处理,而削抖分为软件削抖和硬件削抖,一般情况下多采用软件削抖。
74C922为CMOS工艺技术制造,工作电压为3—15V,“二键锁定“功能,编码输出为三态输出,可直接与微处理器数据线相连,内部振荡器完成4x4矩形键盘扫描,当有按键按下时,DA变高,通过非门接到AT89C51的外部中断0,并且设外部中断0为边沿触发方式,当DA变髙时,经过非门变为低电平跳变产生外部中断,通知AT89C51从数据总线读键值,判断键值从而完成相应的散转程序功能。
⑶根据图221及74C922芯片真值表2-1-2,按键SI—S10对应DCBA输出(0000—1001),上下翻查键S1LS12对应输出是(1010)和(1011)。
同时ABCD输出连接到AT89C51的P2口的P2.0-P2.3o
2.2.2复位电路
图2-2-2复位电路
单片机的复位都是靠外部电路来实现的。
在时钟电路工作后,只要在单片机的复位(RST)脚上出现24个时钟振荡脉冲(也就是2个机器周期)以上的髙电平,单片机便实现初始化状态复位。
⑷
传统的复位方法有阻容上电复位和按键电平复位如图2-2-2o本设计采用按键手动复位电路。
它们实际上利用RC充放电原理实现的复位电路,从外部给RST脚2个机器周期以上的高电平。
在实际应用系统中,为了保证复位电路可靠地工作,常常将RC电路接斯密特电路后再接入单片机的复位端和外用电路复位端。
这样就特别适用于应用现场F扰大、电压波动大的工作环境,并且当系统有多个复位端时,也能够保证可靠的同步复位。
当AT89C51的RST引脚到高电平时,单片机就会复位。
按下按纽S13,将髙电平接到RST端,从而复位。
复位后,单片机就从0000H地址开始执行程序。
P0〜P3四个并行接口全为高电平,其他寄存器全部淸零,只有SBUF寄存器状态不确定。
2.2.3时钟电路
CZJY1
12M
图2-2-3时钟电路
时钟电路是计算机的心脏,它控制着计算机的工作节奏。