基于标志位的独立按键扫描方法分析

出处:电子发烧友网 发布于:2018-06-29 14:11:21

独立按键的扫描方法(延时,消抖的方法),可见这种方法很大程度上可以实现按键的准确扫描。但是仔细一看,可以发现,它有一个缺点——存在while语句的松手检测!

试想,倘若我们一直按着按键不松手,那我们的程序毫无疑问的一直卡在了while语句的松手检测上。这在很多场合是并不适用的。

对于独立按键的博文中所提到的配合数码管显示的实例中,由于我们数码管显示函数display() 位于主函数中,假如我们按键长时间按下,一定会存在数码管不能显示的情况。所以接下来给出一种不需要while松手检测的按键扫描——带有标志位的按键识别(在矩阵键盘同样适用,这里以独立键盘为例)。

首先附上原理图:

基于标志位的独立按键扫描方法分析

用跳帽连接排针 J5 的2脚与3脚,将键盘设置为独立按键(只有S4~S7有效)。此时,S4~S7一端分别与P3^3~P3^0相连,另一端连向GND。

其代码如下,以按下 S4 为例:

sbit s4 = P3^3;

uchar key_flag = 0; //首先定义按键的标志位,并初始化为0

void key_scan() //按键扫描函数

{

if((s4 == 0) && (!key_flag)) //如果有键按下,则条件成立(有键按下,则s4为0;而 !key_flag为1)

{

delay10ms(); //延时消抖

key_flag = 1; //把标志位置为1

if(s4 == 0) //如果确定有键按下

{

dspbuf[0]++; //进行事件处理(数码管显示值加1)

}

}

else if(s4 != 0) //未按下按键

{

key_flag = 0;

}

}123456789101112131415161718

其中:

代码“key_flag = 1”的作用是:下次即便按键没有松手,程序跑完一圈之后,也不会再满足if((s4 == 0) && (!key_flag))的条件;同样,亦不会满足else if(s4 != 0)的条件,那么key_flag 不会被赋为0。综合以上情况,按键只会进行处理。当按键被释放后,以后的扫描则会满足else if(s4 != 0)的条件,那么key_flag 会被赋为0,则可以进行接下来的按键扫描了,如此反复……

综上所述,这样的按键处理,让程序减少了while的松手检测,这对于程序是十分有利的。试想,单片机有那么多的程序要处理,但是却因为按键而卡在一个地方,这确实有点得不偿失了。

而在单片机程序执行的过程中,我们也要尽可能的少用delay()等延时函数,因为在延时的过程中,单片机基本上没有什么工作。但是这段时间对于单片机而言,也是比较宝贵的。

版权与免责声明

凡本网注明“出处:维库电子市场网”的所有作品,版权均属于维库电子市场网,转载请必须注明维库电子市场网,https://www.dzsc.com,违反者本网将追究相关法律责任。

本网转载并注明自其它出处的作品,目的在于传递更多信息,并不代表本网赞同其观点或证实其内容的真实性,不承担此类作品侵权行为的直接责任及连带责任。其他媒体、网站或个人从本网转载时,必须保留本网注明的作品出处,并自负版权等法律责任。

如涉及作品内容、版权等问题,请在作品发表之日起一周内与本网联系,否则视为放弃相关权利。

上传BOM文件: BOM文件
*公司名:
*联系人:
*手机号码:
QQ:
应用领域:

有效期:
OEM清单文件: OEM清单文件
*公司名:
*联系人:
*手机号码:
QQ:
有效期:

扫码下载APP,
一键连接广大的电子世界。

在线人工客服

买家服务:
卖家服务:

0571-85317607

客服在线时间周一至周五
9:00-17:30

关注官方微信号,
第一时间获取资讯。

建议反馈

联系人:

联系方式:

按住滑块,拖拽到最右边
>>
感谢您向阿库提出的宝贵意见,您的参与是维库提升服务的动力!意见一经采纳,将有感恩红包奉上哦!