
temp=P3//读回P3口的状态
temp=temp&0xf0//temp&1111 0000,0与任何数结果为0,把temp变量的低四位屏蔽了,高四位因为任何数与1等于它本身,所以把高四位对应的端口状态读进来。
while(temp!=0xf0) //上步处理后,高四为不全为1,说明有按键按下(结合矩阵键盘的电路结构才能理解,这里不方便上图)
{
delay(5)
temp=P3
temp=temp&0xf0//这三句跟上面重复,功能是软件消抖
while(temp!=0xf0) //延时一段时间后判断还有按键按下,说明是真有按键按下,进入按键扫描与键值的判断,否则可能是意外抖动引起的,就不进行按键扫描。
{
temp=P3
switch(temp).....
我想注释完应该能读懂,关键是要理解矩阵键盘的扫描原理。
此程序实现独立按键的检测功能,每次按下按键 key5 时,数码管最后一位显示的数 值加 1,按键同时响蜂鸣器 #include<reg52.h>sbit key5 = P1^4//独立按键 sbit P3_6 = P3^6//蜂鸣器控制端口 unsigned char code BitSet[8] = { 0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f }//用于设置(低电平位选)数码管的位选信号,从低到高对应 8 个数码管 unsigned char code NumberCode[16] = { 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71, }//用于设置(共阴极)数码管的段选信号,从 0~f 共 16 个数值 void delay_ms(unsigned int n) { //软件延时函数,延时 n 毫秒 unsigned int i, jfor(i=ni>0i--) for(j=110j>0j--)} void beep(int n) { int i = nwhile(i>0) { P3_6 = 1delay_ms(1)P3_6 = 0delay_ms(1)i--} } void main() //喇叭连续响 n 毫秒 //向喇叭输入 1000HZ 的方波震荡源 //0.5 毫秒高电平 //0.5 毫秒低电平 { int num=0while(1) { P2=BitSet[7]//选择最低位的数码管 if(key5==0) //判断按键 key5 是否按下 { delay_ms(10)//延时重新判断按键是否按下,延时消除抖动 if(key5==0) { num++//每按下一次显示的数值加 1 beep(200)//喇叭响 200 毫秒 if(num==16) num=0while(!key5)//直到按键释放,按下时 key5==0,持续循环 } } P0=~NumberCode[num]} } // 2、 此程序实现独立按键的检测功能,key5 和 key6 每次按下按键时,数码管次低位和最 低位显示的数值加 1,按键同时响蜂鸣器 #include<reg52.h>sbit key5 = P1^4sbit key6 = P1^5sbit P3_6 = P3^6unsigned char code BitSet[8] = { 0xfe, 0xfd, 0xfb, 0xf7, 0xef, 0xdf, 0xbf, 0x7f }//用于设置(低电平位选)数码管的位选信号,从低到高对应 8 个数码管 unsigned char code NumberCode[16] = { 0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7f, 0x6f, 0x77, 0x7c, 0x39, 0x5e, 0x79, 0x71, }//用于设置(共阴极)数码管的段选信号,从 0~f 共 16 个数值 void delay_ms(unsigned int n) { //软件延时函数,延时 n 毫秒 unsigned int i, jfor(i=ni>0i--) for(j=110j>0j--)} void beep(int n) { int i = nwhile(i>0) { P3_6 = 1delay_ms(1)P3_6 = 0delay_ms(1)i--} } void main() { int num=0, num2=0while(1) { P2=BitSet[6]//喇叭连续响 n 毫秒 //向喇叭输入 1000HZ 的方波震荡源 //0.5 毫秒高电平 //0.5 毫秒低电平 //选择最低位的数码管 if(key5==0) //判断按键 key5 是否按下 { delay_ms(10)//延时重新判断按键是否按下,延时消除抖动 if(key5==0) { num++//每按下一次显示的数值加 1 beep(100)//喇叭响 100 毫秒 if(num==16) num=0while(!key5) { P2=BitSet[6]//选择次低位的数码管 P0=~NumberCode[num]delay_ms(3)P2=0xff}} } P2=BitSet[7]//选择最低位的数码管 P0=~NumberCode[num2]delay_ms(3)P2=0xff//直到按键释放,按下时 key5==0,持续循环 P0=~NumberCode[num]delay有独立键盘和距阵键盘的 独立键盘的很简单我就不写了 距阵的我给你写一个//键盘扫描
uchar Keys_Scan()
{
uchar sCode,kCode,i,k
//低4 位置0,放入4 行
P1=0xf0
//若高4 位出现0,则有键按下
if((P1&0xf0)!=0xf0)
{
DelayMS(2)
if((P1&0xf0)!=0xf0)
{
sCode=0xfe//行扫描码初值
for(k=0k<4k++) //对4 行分别进行扫描
{
P1=sCode
if((P1&0xf0)!=0xf0)
{
kCode=~P1
for(i=0i<16i++) //查表得到按键序号并返回
if(kCode==KeyCodeTable[i])
return(i)
}
else
sCode=_crol_(sCode,1)
}
}
}
return(-1)
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)