首页 > 其他分享 >第4章 键盘的检测原理及应用实现

第4章 键盘的检测原理及应用实现

时间:2023-05-11 21:02:47浏览次数:42  
标签:case P3 temp 检测 0xf0 键盘 key 按键 原理

第4章 键盘的检测原理及应用实现

 

非编码键盘:独立键盘和行列式键盘。

  1. 独立键盘检测

 

常见的按键:弹性小按键,贴片式按键,自锁式按键。

单片机检测按键的原理:单片机的I/O即可作输出也可作输入,当检测按键时,用它的输入功能,把按键的一端接地,另一端接IO,开始时,给IO赋高电平,然后不断的检测该IO是否变为低电平,当按键闭合时,变为低电平。程序一旦检测到IO变成低电平,说明该按键被按下,执行相应的操作。

按键的抖动,一般为5-10ms。通常用软件延时的方法消抖。

例1 用数码管的前两位显示一个十进制数,变化范围为00-59.开始显示00,每按下S2键一次,数值加1;每按下S3键一次,数值减1;每按下S4键一次,数值归零;每按下S5键一次,利用定时器功能,使数值自动每秒加1,再次按下S5键,数值停止加1,保持原值显示。

#include<reg52.h>

#define uchar unsigned char

#define uint unsigned int

sbit key1=P3^4;

sbit key2=P3^5;

sbit key3=P3^6;

sbit key4=P3^7;

sbit dula=P2^6;

sbit wela=P2^7;

uchar code table[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71};

void delayms(uint);

uchar numt0,num;

void display(uchar numdis)

{

uchar shi,ge;

shi=numdis/10;

ge=numdis%10;

 

dula=1;

P0=table[shi];

dula=0;

P0=0xff;

wela=1;

P0=0xfe;

wela=0;

delayms(5);

 

dula=1;

P0=table[ge];

dula=0;

P0=0xff;

wela=1;

P0=0xfd;

wela=0;

delayms(5);

}

 

void delayms(uint xms)

{

uint i,j;

for(i=xms;i>0;i--)

  for(j=110;j>0;j--);

}

 

void init()    //初始化函数

{

TMOD=0x01;  //定时器0

TH0=(65536-45872)/256;

TL0=(65536-45872)%256;

EA=1;

ET0=1;

}

 

void keyscan()

{

if(key1==0)

{

delayms(10);

if(key1==0)

{

num++;

if(num==60)

num=0;

while(!key1);

}

}

if(key2==0)

{

delayms(10);

if(key2==0)

{

if(num==0)

num=60;

  num--;

while(!key2);

}

}

if(key3==0)

{

delayms(10);

if(key3==0)

{

num=0;

while(!key3);

}

}

if(key4==0)

{

delayms(10);

if(key4==0)

{

while(!key4);

TR0=~TR0;    //启动或停止定时器0

}

}

}

 

void main()

{

init();

while(1)

{

keyscan();

display(num);

}

}

 

void T0_time() interrupt 1

{

TH0=(65536-45872)/256;

TL0=(65536-45872)%256;

numt0++;

if(numt0==20)      //1s

{

numt0=0;

num++;

if(num==60)

num=0;

}

}

在键盘扫描程序中,while(!Key1),表示按键释放,检测按键释放很重要,若无这条语句,程序会循环多次检测到按键按下,就会无序操作(一直加减等等)。

 

  1. 矩阵键盘检测

 

矩阵键盘检测的原理,每一个按键的2段都连接到单片机的I/O,先设定某行为0,轮流检测各列,若有按键按下,确定行,通过行,列确定按键。循环检测。

例2 上电后,数码管无显示,依次按下各键,数码管显示0-f。6个数码管静态显示。

#include<reg52.h>

#define uchar unsigned char

#define uint unsigned int

sbit dula=P2^6;

sbit wela=P2^7;

uchar code table[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71};

void delayms(uint xms)

{

uint i,j;

for(i=xms;i>0;i--)

for(j=110;j>0;j--);

}

void display(uchar num)

{

P0=table[num];        //段选数据

dula=1;

dula=0;

}

void matrixkeyscan()

{

uchar temp,key;

P3=0xfe;

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

delayms(10);

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

temp=P3;

switch(temp)

{

case 0xee:key=0;break;

case 0xde:key=1;break;

case 0xbe:key=2;break;

case 0x7e:key=3;break;

}

while(temp!=0xf0)  //等待按键释放

{

temp=P3;

temp=temp&0xf0;

}

display(key);

}

}

P3=0xfd;

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

delayms(10);

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

temp=P3;

switch(temp)

{

case 0xed:key=4;break;

case 0xdd:key=5;break;

case 0xbd:key=6;break;

case 0x7d:key=7;break;

}

while(temp!=0xf0)  //等待按键释放

{

temp=P3;

temp=temp&0xf0;

}

display(key);

}

}

P3=0xfb;

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

delayms(10);

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

temp=P3;

switch(temp)

{

case 0xeb:key=8;break;

case 0xdb:key=9;break;

case 0xbb:key=10;break;

case 0x7b:key=11;break;

}

while(temp!=0xf0)  //等待按键释放

{

temp=P3;

temp=temp&0xf0;

}

display(key);

}

}

P3=0xf7;

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

delayms(10);

temp=P3;

temp=temp&0xf0;

if(temp!=0xf0)

{

temp=P3;

switch(temp)

{

case 0xe7:key=12;break;

case 0xd7:key=13;break;

case 0xb7:key=14;break;

case 0x77:key=15;break;

}

while(temp!=0xf0)  //等待按键释放

{

temp=P3;

temp=temp&0xf0;

}

display(key);

}

}

}

void main()

{

P0=0;    //关闭所有的段选

dula=1;

dula=0;

P0=0xc0;  //位选所有的数码管

wela=1;

wela=0;

while(1)

{

matrixkeyscan();  //不停扫描键盘

}

}

程序分析:进入主函数后,首先关闭段选,不显示。然后打开所有的位选。接着调用按键扫描程序。键盘扫描用到了读P3口的值,比较,延时消抖,再读值,比较,判断键值,释放按键。

 

标签:case,P3,temp,检测,0xf0,键盘,key,按键,原理
From: https://www.cnblogs.com/halflife/p/17392219.html

相关文章

  • 程序员的降龙十八掌,一部电脑、一个键盘,笑傲江湖
    程序员写代码需要精益求精,具备工匠精神(反复思考,打磨)。汲取百家之长,各种精华,融会贯通,才能独创黯然销魂掌。写代码可不是伸手就来的,每个开发人员都有自己的理解。就像武学界的武功一样,讲究招招式式,每门功夫都需要一个名字,想要编写出优质的代码,首先要学会以下十八招式:第一招:养成一......
  • Java内存模型原理,你真的理解吗?(转载)
    内存模型产生背景在介绍Java内存模型之前,我们先了解一下物理计算机中的并发问题,理解这些问题可以搞清楚内存模型产生的背景。物理机遇到的并发问题与虚拟机中的情况有不少相似之处,物理机的解决方案对虚拟机的实现有相当的参考意义。物理机的并发问题硬件的效率问题计算机处......
  • 拉普拉斯图像融合,基于sobel算子的边缘检测,PCA人脸识别,SIFT图像配准,分形维数计算,数字图
    拉普拉斯图像融合,基于sobel算子的边缘检测,PCA人脸识别,SIFT图像配准,分形维数计算,数字图像水印,霍夫变换做直线检测,人脸纹理识别,伪彩色增强,图像增强,图像分割,特征提取,字符分割,各种GUI,等等各种跟图像处理有关的程序。ID:1360615396171857......
  • Delphi 检测密码强度 规则(仿 google)
    一、密码长度:5分:小于等于4个字符10分:5到7字符25分:大于等于8个字符二、字母:0分:没有字母10分:全都是小(大)写字母20分:大小写混合字母三、数字:0分:没有数字10分:1个数字20分:大于等于3个数字四、符号:0分:没有符号10分:1......
  • 第二章、操作系统基本原理
    第一节.操作系统概述操作系统与计算机体系结构之间的关系: 操作系统具备的管理职能:1.进程管理:(1)进程的状态;(2)前趋图;(3)PV操作;(4)死锁问题。2.存储管理:(1)段页式存储;(2)页面置换算法。3.文件管理:(1)索引文件;(2)位示图4.作业管理5.设备管理:数据传输控制方式6.微......
  • EPON的原理
    EPON的原理  为了分离同一根光纤上多个用户的来去方向的信号,采用以下两种复用技术。  a、下行数据流采用广播技术.  b、上行数据流采用TDMA技术。EPON、GPON有何区别?哪个好?(baidu.com)......
  • 高频方波电压注入的的PMSM转子初始位置检测 1.方波电压和
    高频方波电压注入的的PMSM转子初始位置检测1.方波电压和正负脉冲电压相结合实现永磁同步电机转子初始位置检测;2.提供算法对应的参考文献和仿真模型,支持技术解答。仿真模型纯手工搭建,不是从网络上复制得到。仿真模型仅供学习参考ID:9968676117451227......
  • 聊一聊redis十种数据类型及底层原理
    概述Redis是一个开源的高性能键值数据库,它支持多种数据类型,可以满足不同的业务需求。本文将介绍Redis的10种数据类型,分别是string(字符串)hash(哈希)list(列表)set(集合)zset(有序集合)stream(流)geospatial(地理)bitmap(位图)bitfield(位域)hyperloglog(基数统计)String概述string......
  • 关于真正量化和假冒量化的原理分析
    关于真正量化和假冒量化的原理分析背景: 目前大量的GPT-base模型的量化仅仅对权重(weights)进行量化,而没有对特征图(featuremaps)进行量化。这样的量化模型实际上并不是真正的量化模型。在深度学习中,模型参数(weights)和输入数据(featuremaps)都可以进行量化,从而在计算和存......
  • mybatis运行原理-- 总述
    1.根据mybatis配置文件和mapper映射文件,初始化出Configuration对象。得到sqlSessionFactory,包含数据库的信息,和所有的mapper路径,mapper接口路径可用包扫描的方式代替;2.sqlSessionFactory.openSession得到sqlSession,里面已经包含了Configuration以及Executor(defaultExecutorType......