(1)矩阵按键原理:话不多说,对于16个矩阵按键来说,要想知道哪个按键被按下,可以设置16个IO口,但是这样硬件电路过于繁琐,所以可以采用行列扫描法,由行推列,再由列推行。首先给四个行为低电平,四个列为高电平;如何某个按键被按下,那么该按键所在的列就变为低电平;再给四个行为高电平,四个列为低电平,那么刚才那个按键的所在的行就变为低电平,由此经过行列扫描就是锁定了具体是哪个按键被按下。
(2)矩阵按键原理图:(3)源代码:
#include<reg51.h>
typedef unsigned char u8;
typedef unsigned int u16;
#define KEY P1
#define SMG P0
sbit LSA=P2^2;
sbit LSB=P2^3;
sbit LSC=P2^4;
u8 value;
u8 code smgduan[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
void delay(u16 i)
{
while(i--);
}
void keypros()
{
u8 a=0;
u8 i;
KEY=0x0f;
if(KEY!=0x0f)
{
delay(100);
if(KEY!=0x0f)
{
KEY=0x0f;
switch(KEY)
{
case 0x07:value=0;break;
case 0x0b:value=1;break;
case 0x0d:value=2;break;
case 0x0e:value=3;break;
}
KEY=0xf0;
switch(KEY)
{
case 0x70:value=value;break;
case 0xb0:value=value+4;break;
case 0xd0:value=value+8;break;
case 0xe0:value=value+12;break;
}
while((a<50)&&(value!=0xf0))
{
delay(1000);
a++;
}
SMG=smgduan[value];
for(i=0;i<8;i++)
{
switch(i)
{
case 0:LSA=0;LSB=0;LSC=0;break;
case 1:LSA=1;LSB=0;LSC=0;break;
case 2:LSA=0;LSB=1;LSC=0;break;
case 3:LSA=1;LSB=1;LSC=0;break;
case 4:LSA=0;LSB=0;LSC=1;break;
case 5:LSA=1;LSB=0;LSC=1;break;
case 6:LSA=0;LSB=1;LSC=1;break;
case 7:LSA=1;LSB=1;LSC=1;break;
}
delay(50000);
}
}
}
}
void main()
{
while(1)
{
keypros();
}
}