|
先说明,此方法是之前我一个老师给我的,但是当时是单个按键的程序,我把它改成了矩阵按键的程序。
这个程序特别不好理解,但是特别巧妙。
实现的功能是,按键松开有效,换句话说,你按下不会触发,当你松开后才回触发,完美去抖。
此程序基于mage128单片机
/ *******************************************************/
/ ****** 16*16矩阵按键扫描程序头文件——2010.8.16 追雪***/
/ *******************************************************/
/ *******************************************************/
/ ****** key_scan_0(void) 按键判断 松开有效 ******/
/ ****** uchar key_scan(void) 返回按键号1~16 ******/
/ *******************************************************/
#define key_board PINC //按键I/0口
#define key_num 0xf0 //提取有用位系数
static unsigned char key_release=0;
unsigned char key=0xf0;//没有任何按键按下的时候P1.3/1.4/1.5都是1,是初始值。我们只关心P1.3/1.4/1.5,不关心别的引脚。
/ *******************************************************/
/ ****** 函数名称: key_scan_0(void) ******/
/ ****** 功 能: 按键判断松开有效 ******/
/ ****** 参 数: 无 ******/
/ ****** 返 回 值: 无 ******/
/ *******************************************************/
void key_scan_0(void)//按键松开才认为是有效按键
{
unsigned char key1,key2;
key1=key_board;
key1&=key_num;
delay_nus(200);
key2=key_board;
key2&=key_num;
if(key1!=key2) return;
if((key1==key)) //按键扫描结果和上次相同,可能是没有按键,也有可能是同一个按键
{
return;
}
else //按键扫描结果与上次不同
if(key1==key_num) {key_release=1;}//按键松开
else //有按键按下
{
key_release=0;
key=key1;
}
}
/ *******************************************************/
/ ****** 函数名称: unsigned char key_scan(void) ******/
/ ****** 功 能: 返回按键号1~16 ******/
/ ****** 参 数: 无 ******/
/ ****** 返 回 值: unsigned char ******/
/ *******************************************************/
unsigned char key_scan(void)
{
unsigned char key1=0,i;
PORTC=0xff;
for(i=0;i<=3;i++)
{
PORTC&=~(1<<i);
key_scan_0();
if(key_release)
{
switch(key)
{
case 0xe0:{key1=1+4*i;key=0xf0;key_release=0;return key1;}
case 0xd0:{key1=2+4*i;key=0xf0;key_release=0;return key1;}
case 0xb0:{key1=3+4*i;key=0xf0;key_release=0;return key1;}
case 0x70:{key1=4+4*i;key=0xf0;key_release=0;return key1;}
default :{key1=0;key=0xf0;key_release=0;break;}
}
}
}
return key1;
} |
阿莫论坛20周年了!感谢大家的支持与爱护!!
曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……
|