1.
每按下一次开关SP1,计数值加1,经过AT89S51单片机的P1端口的P1.0到P1.3显现出其的二进制计数值。
2.
(1.把“单片机体系”区域中的P3.7/RD端口连接到“独立式键盘”区域中的SP1端口上;
(2.把“单片机体系”区域中的P1.0-P1.4端口用8芯排线连接到“八路发光二极管指示模块”区域中的“L1-L8”端口上;要求,P1.0连接到L1,P1.1连接到L2,P1.2连接到L3,P1.3连接到L4上。
4.
(1.其实,作为一个按键从没有按下到按下以及开释是一个完好的进程,也便是说,当咱们按下一个按键时,总期望某个指令只履行一次,而在按键按下的
要把咱们手上的搅扰信号以及按键的机械触摸等搅扰信号给滤除去,一般情况下,咱们能够选用%&&&&&%来滤除去这些搅扰信号,但实际上,会添加硬件本钱及硬件电路的体积,这是咱们不期望,总得有个办法处理这个问题,因而咱们能够选用软件滤波的办法去除这些搅扰信号,一般情况下,一个按键按下的时分,总是在按下的时间存在着必定的搅扰信号,按下之后就根本进步入了安稳的状况。详细的一个按键从按下到开释的全进程的信号图如上图所示:
从图中能够看出,咱们在程序设计时,从按键被辨认按下之后,延时5ms以上,然后避开了搅扰信号区域,咱们再来检测一次,看按键是否真得现已按下,若真得现已按下,这时必定输出为低电平,若这时检测到的是高电平,证明刚才是因为搅扰信号引起的误触发,CPU就认为是误触发信号而放弃这次的按键辨认进程。然后提高了体系的可靠性。
因为要求每按下一次,指令被履行一次,直到下一次再按下的时分,再履行一次指令,因而从按键被辨认出来之后,咱们就能够履行这次的指令,所以要有一个等候按键开释的进程,明显开释的进程,便是使其康复成高电平状况。
(1.关于按键辨认的指令,咱们仍然挑选如下指令JBBIT,REL指令是用来检测BIT是否为高电平,若BIT=1,则程序转向REL处履行程序,不然就持续向下履行程序。或者是JNBBIT,REL指令是用来检测BIT是否为低电平,若BIT=0,则程序转向REL处履行程序,不然就持续向下履行程序。
(2.但对程序设计进程中按键辨认进程的框图如右图所示:图4.8.3
5.
ORG0
START:MOVR1,#00H;初始化R7为0,表明从0开端计数
MOVA,R1;
CPLA;取反指令
MOVP1,A;送出P1端口由发光二极管显现
REL:JNBP3.7,REL;判别SP1是否按下
LCALLDELAY10MS;若按下,则延时10ms左右
JNBP3.7,REL;再判别SP1是否真得按下
INCR7;若真得按下,则进行按键处理,使
MOVA,R7;计数内容加1,并送出P1端口由
CPLA;发光二极管显现
MOVP1,A;
JNBP3.7,$;等候SP1开释
SJMPREL;持续对K1按键扫描
DELAY10MS:MOVR6,#20;延时10ms子程序
L1:MOVR7,#248
DJNZR7,$
DJNZR6,L1
RET
END
7.
#include
unsignedcharcount;
voiddelay10ms(void)
{
unsignedchari,j;
for(i=20;i>0;i–)
for(j=248;j>0;j–);
}
voidmain(void)
{
while(1)
{
if(P3_7==0)
{
delay10ms();
if(P3_7==0)
{
count++;
if(count==16)
{
count=0;
}
P1=~count;
while(P3_7==0);
}
}
}
}