51单片机矩阵键盘扫描程序分析

51单片机矩阵键盘扫描程序分析,第1张

我给你一个我自己写的吧 有注释

假设按下的是S1键进行如下检测(44键盘

先在P3口输出

p3 00001111

低四位 行会有变化

cord_h =00001111&00001110 =00001110

if !=00001111

延时01us

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 <reg52h>//包含头文件

#define uchar unsigned char

#define uint unsigned int

unsigned char const table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,

0x77,0x7c,0x39,0x5e,0x79,0x71};//0-F

uchar 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--);

}

在P3口做的键盘

你的去抖检测没有做好

代码很好写,但是关键是你的数码管属于硬件

也就是说,至少要知道 *** 作你数码管的API才行啊。

或者说要怎样传送数据给你的数码管,你的数码管需要接受怎样的数据。

键盘扫描很简单,给你个代码。

要求引用头文件

#include <iostream>

using namespace std;

#include <conioh>//kbhit API头文件

#include <timeh>

#include <windowsh>

#define ESC 0x1b

void loop()

{

int i;

if( kbhit() ) //判断是否有键盘按键按下。

{

char ch;

ch = getch(); //获取按下的键值

if( ESC == ch )//判断是否是你要的键,我以ESC为例

{

cout<<"ESC"<<endl;

system("pause");

}

}

while( !kbhit() )//没有按键是的 *** 作

{

balabalabala

}

}

int main()

{

loop();

}

KeyPort=0x0f; //行线输出全为0

cord_h=KeyPort&0x0f; //读入列线值

这两句代码最后造成的结果就是使得cord_h=0x0f。

这样的话,完全没有任何的意义呀,

----

不一定是 0f。

有按键时,也可能是 07,也可能是 0d,也可能是 0e,也可能是 0b。

松手检测是很有必要的,如果没有松手检测,当你按下时会相当于你多次按下,这里松手检测用的是if;也可以用while()和for()循环做,这里的意思是当检测到手还没有松开时,就会返回到if前,再次进行判断,直到检测到松手时,才会继续向下执行!

你明白了吗

按照行顺序,一行一行的开启,如下图:44共16键,假设P00-P03为H0-H3,P04-P07为L0-L3

(列)

L0

L1

L2

L3

(行)

H0

0

1

2

3

H1

4

5

6

7

H2

8

9

A

B

H3

C

D

E

F

首先让

H0

=

0,然后依次检测L0-L3,看那个键按下了

,则对应的L0-L3为0,这样第一行检测结束。比如扫描H0

行时

第一个键按下了,则L0=0,获得的P0=0xee,你也可以返回一个值,比如就是0,来代表第一个键(0)被按下,这样依次检测就扫描满16个键就行了。

以上就是关于51单片机矩阵键盘扫描程序分析全部的内容,包括:51单片机矩阵键盘扫描程序分析、求编写一个键盘数码块扫描实验的程序、用行列反转法进行单片机矩阵键盘扫描,解释一下下面的程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10108255.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存