矩阵按键扫描原理

2018-08-31 17:15:33 蓝水园整理 矩阵按键原理 矩阵按键原理

矩阵按键扫描原理程序

Q1:4X4矩阵键盘扫描原理


能否尽量详细地说一下:
P1=0x0F;//低四位输入
delay(1);//稍稍延时
temp=P1;//读P1口
temp=temp&0x0F;//取低四位
temp=~(temp|0xF0);
if(temp==1)//检测按下的键所在的列号,在第一列
key=0;
else if(temp==2) //在第二列
key=1;
else if(temp==4) //在第三列
key=2;
else if(temp==8) //在第四列
key=3;
else
key=16;//否则显示-
这一段的意义
你只要我解释这段的意义吧。这一段是确定按下的键所在的列号。我看几乎每行都有注释啊,而且注释的很好。
temp=temp&0x0F;//取低四位
temp=~(temp|0xF0);这行没注释,我就说一下,就是对temp低四位取反,
因为 P0是段选,低电平有效,这样能分离出按键信息。举个例子,如果是第一列有键按下,temp在执行此句前,低四位应该是1110(低电平有 效 )执行后低四位才变成0001,恰好能为下面的 if,else if 提供正确的逻辑。如果没键按下,temp=0x00,所以有else key=16。显示“-”。
我想应该解释清楚了,如有疑问,给我留言。


Q2:矩阵键盘扫描的原理是什么?

先扫描一排,判断有没有按键按下,如果有 在扫描另一排 根据坐标就找到按键了

Ww。w.jizhubA.coM

Q3:矩阵键盘扫描程序分析

假设按下的是S1键进行如下检测(4*4键盘)
先在P3口输出
p300001111、低四位行会有变化
cord_h =00001111&00001110 =00001110
if!=00001111、延时0.1us
cord_h=00001110&00001111=00001110、if!=00001111、P3再输出11111110、P3=00001110|11110000=11111110、输出高四位
cord_l=P3&0xf0 //此时P3口就是输入值01111110 而不是上面的11111110、cord_l=01111110&11110000=01110000
cord_h+cord_l=00001110+01110000=01111110=0x7e//此编码即为S1的编码
#include //包含头文件
#define uchar unsigned char
#define uintunsigned int
unsigned char const table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};//0-Fuchar keyscan(void);
void delay(uint i);
void main()
{
uchar key;
P2=0x00;//1数码管亮 按相应的按键,会显示按键上的字符
while(1)
{
key=keyscan();//调用键盘扫描,
switch(key)
{
case 0x7e:P0=table[0];break;//0 按下相应的键显示相对应的码值
case 0x7d:P0=table[1];break;//1、case 0x7b:P0=table[2];break;//2、case 0x77:P0=table[3];break;//3、case 0xbe:P0=table[4];break;//4、case 0xbd:P0=table[5];break;//5、case 0xbb:P0=table[6];break;//6、case 0xb7:P0=table[7];break;//7、case 0xde:P0=table[8];break;//8、case 0xdd:P0=table[9];break;//9、case 0xdb:P0=table[10];break;//a
case 0xd7:P0=table[11];break;//b
case 0xee:P0=table[12];break;//c
case 0xed:P0=table[13];break;//d
case 0xeb:P0=table[14];break;//e
case 0xe7:P0=table[15];break;//f
}
}
}
uchar keyscan(void)//键盘扫描函数,使用行列反转扫描法
{
uchar cord_h,cord_l;//行列值
P3=0x0f;//行线输出全为0
cord_h=P3&0x0f;//读入列线值
if(cord_h!=0x0f)//先检测有无按键按下
{
delay(100);//去抖
cord_h=P3&0x0f;//读入列线值
if(cord_h!=0x0f)
{
P3=cord_h|0xf0;//输出当前列线值
cord_l=P3&0xf0;//读入行线值
return(cord_h+cord_l);//键盘最后组合码值
}
}return(0xff);//返回该值
}
void delay(uint i)//延时函数
{
while(i--);
}

Q4:矩阵键盘扫描程序


假设按下的是S1键进行如下检测(4*4键盘)
先在P3口输出
p300001111、低四位行会有变化
cord_h =00001111&00001110 =00001110
if!=00001111、延时0.1us
cord_h=00001110&00001111=00001110、if!=00001111、P3再输出11111110、P3=00001110|11110000=11111110、输出高四位
cord_l=P3&0xf0 //此时P3口就是输入值01111110 而不是上面的11111110、cord_l=01111110&11110000=01110000
cord_h+cord_l=00001110+01110000=01111110=0x7e//此编码即为S1的编码
#include //包含头文件
#define uchar unsigned char
#define uintunsigned int
unsigned char const table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,
0x77,0x7c,0x39,0x5e,0x79,0x71};//0-Fuchar keyscan(void);
void delay(uint i);
void main()
{
uchar key;
P2=0x00;//1数码管亮 按相应的按键,会显示按键上的字符
while(1)
{
key=keyscan();//调用键盘扫描,
switch(key)
{
case 0x7e:P0=table[0];break;//0 按下相应的键显示相对应的码值
case 0x7d:P0=table[1];break;//1、case 0x7b:P0=table[2];break;//2、case 0x77:P0=table[3];break;//3、case 0xbe:P0=table[4];break;//4、case 0xbd:P0=table[5];break;//5、case 0xbb:P0=table[6];break;//6、case 0xb7:P0=table[7];break;//7、case 0xde:P0=table[8];break;//8、case 0xdd:P0=table[9];break;//9、case 0xdb:P0=table[10];break;//a
case 0xd7:P0=table[11];break;//b
case 0xee:P0=table[12];break;//c
case 0xed:P0=table[13];break;//d
case 0xeb:P0=table[14];break;//e
case 0xe7:P0=table[15];break;//f
}
}
}
uchar keyscan(void)//键盘扫描函数,使用行列反转扫描法
{
uchar cord_h,cord_l;//行列值
P3=0x0f;//行线输出全为0
cord_h=P3&0x0f;//读入列线值
if(cord_h!=0x0f)//先检测有无按键按下
{
delay(100);//去抖
cord_h=P3&0x0f;//读入列线值
if(cord_h!=0x0f)
{
P3=cord_h|0xf0;//输出当前列线值
cord_l=P3&0xf0;//读入行线值
return(cord_h+cord_l);//键盘最后组合码值
}
}return(0xff);//返回该值
}
void delay(uint i)//延时函数
{
while(i--);
}


小提示:内容仅供参考,如果您需解决具体问题(尤其法律、医学等领域),建议您详细咨询相关领域专业人士。

矩阵按键原理 推荐文章:
推荐不满意?点这里  ››  

矩阵按键原理