学了霖锋的矩阵键盘,(与源程序有差别)程序基本如下:
#include<reg52.h>
#include<intrins.h>
typedef unsigned char u8;
typedef unsigned int u16;
u8 code smgduan[16]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,
0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71,};
void delay(u16 z)
{
u16 x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void main()
{
u8 key_l,key_h;
while(1)
{
P1=0xf0;
key_l=P1;
if(key_l!=0xf0)
{
delay(10);
if(key_l!=0xf0)
{
key_l=key_l|0x0f;
P1=key_l;
key_h=P1;
}
}
switch(key_h)
{
case 0xee:P0=~smgduan[15];break;
case 0xde:P0=~smgduan[14];break;
case 0xbe:P0=~smgduan[13];break;
case 0x7e:P0=~smgduan[12];break;
case 0xed:P0=~smgduan[11];break;
case 0xdd:P0=~smgduan[10];break;
case 0xbd:P0=~smgduan[9];break;
case 0x7d:P0=~smgduan[8];break;
case 0xeb:P0=~smgduan[7];break;
case 0xdb:P0=~smgduan[6];break;
case 0xbb:P0=~smgduan[5];break;
case 0x7b:P0=~smgduan[4];break;
case 0xe7:P0=~smgduan[3];break;
case 0xd7:P0=~smgduan[2];break;
case 0xb7:P0=~smgduan[1];break;
case 0x77:P0=~smgduan[0];break;
}
}
}
这个程序没用松手检测,但在开发板上试验,很稳定,没有一次按下是错的。请教各位师傅,为什么呢?
普中的程序如下:
#include<reg52.h>
#include<intrins.h>
typedef unsigned char u8;
typedef unsigned int u16;
u8 code smgduan[16]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,
0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71,};
#define smg P0
#define key P1
u8 keyvalue,keyvalue1;
void delay(u16 z)
{
u16 x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
void keyscan()
{
u8 a;
a=0;
key=0x0f;
if(key!=0x0f)
{
delay(5);
if(key!=0x0f)
{
switch(key)
{
case(0x07):keyvalue=0;break;
case(0x0b):keyvalue=1;break;
case(0x0d):keyvalue=2;break;
case(0x0e):keyvalue=3;break;
}
}
}
key=0xf0;
if(key!=0xf0)
{
delay(5);
if(key!=0xf0)
{
switch(key)
{
case(0x70):keyvalue1=keyvalue; break;
case(0xb0):keyvalue1=keyvalue+4; break;
case(0xd0):keyvalue1=keyvalue+8; break;
case(0xe0):keyvalue1=keyvalue+12; break;
}
}
}
while((a<50)&&(key!=0xf0)) //松手检测且限定时间退出程序
{
delay(5);
a++;
} //假如按键持续一直按下,会占用CPU的资源,因此设定一定的时间
//让CPU退出键盘扫描程序
}
void main()
{
while(1)
{
keyscan();
smg=~smgduan[keyvalue1]; //共阳的数码管,要取反。
}
}
这个松手检测必须有,不然有时显示不正常。
这两个程序一个没用松手检测,一个用了。但都是正常。
不知道为什么?
|