學了霖鋒的矩陣鍵盤,(與源程序有差別)程序基本如下:
#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]; //共陽的數碼管,要取反。
}
}
這個松手檢測必須有,不然有時顯示不正常。
這兩個程序一個沒用松手檢測,一個用了。但都是正常。
不知道為什么?
|