当前位置:首页 > 单片机 > 单片机
[导读]// P1口扩展4*4矩阵键盘,P1.7-P1.4作为行线,P1.3-P1.0作为列线。// 数码管显示按键值,P0提供段码,P2.7-2.5通过74ls138,作为位码,片选数码管。#include void leddisplay(); // 数码管显示 unsigned char key

// P1口扩展4*4矩阵键盘,P1.7-P1.4作为行线,P1.3-P1.0作为列线。

// 数码管显示按键值,P0提供段码,P2.7-2.5通过74ls138,作为位码,片选数码管。

#include
void leddisplay(); // 数码管显示
unsigned char keyscan(); //键盘扫描
unsigned char keyin(); //按键值读取
void delayms(unsigned int k);
unsigned char data ledxs[8]={16,16,16,16,16,16,0,0}; // 数码管显示缓冲区
unsigned char code tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0,0xff};
//共阴极代码 0-F, 全灭,全亮
void main()
{
unsigned char i,keyword;
delayms(200);
while(1)
{

for(i=0;i<38;i++) // 按下一个按键300ms后再响应下一个,不检测按键弹起
{
ledxs[6]=keyword/10;
ledxs[7]=keyword%10;
leddisplay();
}
i=keyin();
switch(i)
{
//case 0x0f: keyword=0;break;
case 0x77: keyword=6;break;
case 0x7b: keyword=7;break;
case 0x7d: keyword=8;break;
case 0x7e: keyword=9;break;
case 0xb7: keyword=10;break;
case 0xbb: keyword=11;break;
case 0xbd: keyword=12;break;
case 0xbe: keyword=13;break;
case 0xd7: keyword=14;break;
case 0xdb: keyword=15;break;
case 0xdd: keyword=16;break;
case 0xde: keyword=17;break;
case 0xe7: keyword=18;break;
case 0xeb: keyword=19;break;
case 0xed: keyword=20;break;
case 0xee: keyword=21;break;
default:break;
}
}
}
unsigned char keyin() //读取按键值
{
unsigned char i;
do
{
i=keyscan(); // 读取键值
leddisplay(); // 8ms 去抖
}
while(i!=keyscan()); // 无键按下继续扫描
return i; // 有键按下返回键值
}
unsigned char keyscan() //按键检测
{
unsigned char i=0x0f,d;
P1=0xff;

P1=0x7f; // 扫描第1行
i=P1&0x0f; // 读取列值
d=i|0x70; // 高4位为行号,低4位为列号
if(i!=0x0f)
return d; // 返回键值

P1=0xbf; // 扫描第2行
i=P1&0x0f;
d=i|0xb0;
if(i!=0x0f)
return d;

P1=0xdf; // 扫描第3行
i=P1&0x0f;
d=i|0xd0;
if(i!=0x0f)
return d;

P1=0xef; // 扫描第4行
i=P1&0x0f;
d=i|0xe0;
if(i!=0x0f)
return d;

return i; //无键按下,返回0x0f

}
void leddisplay()
{
P2=0xdf;
P0=tab[ledxs[0]];
delayms(1);
P0=0x00;

P2=0x5f;
P0=tab[ledxs[1]];
delayms(1);
P0=0x00;

P2=0x9f;
P0=tab[ledxs[2]];
delayms(1);
P0=0x00;

P2=0x1f;
P0=tab[ledxs[3]];
delayms(1);
P0=0x00;

P2=0xff;
P0=tab[ledxs[4]];
delayms(1);
P0=0x00;

P2=0x7f;
P0=tab[ledxs[5]];
delayms(1);
P0=0x00;

P2=0xbf;
P0=tab[ledxs[6]];
delayms(1);
P0=0x00;

P2=0x3f;
P0=tab[ledxs[7]];
delayms(1);
P0=0x00;
}
void delayms(unsigned int k) //延时 n ms
{
while(k)
{
int i;
i=110;
while(i--);
k=k-1;
}
}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式系统开发中,经常通过键盘来实现人机交互。本文介绍了一种直接利用ARM的I/O口扩展矩阵键盘的方法。同时以TQ2440开发板为例,对硬件电路连接和相应的linux驱动设计方法都作了详细说明。

关键字: ARM 矩阵键盘 linux驱动

超声波模块测距51程序_单片机超声波测距c语言,超声波检测原理

关键字: 超声波模块 测距 51程序

有的单片机应用需要使用的按键数量比较多,比如:密码锁,这时如果按照之前的设计,一个GPIO控制一个按键的话,有点浪费单片机资源,这时候我们常常需要使用矩阵键盘。

关键字: 矩阵键盘

矩阵键盘的使用在单品机的学习当中十分广泛,可是对于许多新手,包括本人有时也是搞不明白,昨天晚上和今天早上的思考和同行们的讨论,终于有了点头绪,所以想记录下读取键盘的思路。

关键字: 矩阵键盘 编程方法 读取键值

基于TX-1C开发板,电路连接图如下

关键字: 检测及使用 矩阵键盘

矩阵键盘是单片机外部设备中所使用的排布类似于矩阵的键盘组。矩阵式结构的键盘显然比直接法要复杂一些,识别也要复杂一些,列线通过电阻接正电源,并将行线所接的单片机的I/O口作为输出端,而列线所接的I/O口则作为输入。矩阵键盘...

关键字: 单片机 矩阵键盘

在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式,如图1所示。在矩阵式键盘中,每条水平线和垂直线在交叉处不直接连通,而是通过一个按键加以连接。

关键字: 单片机 矩阵键盘 扫描识别

/**************************文件所用资源1.端口:P22.调用delay_ms函数**************************/#include #include #define key...

关键字: 4*4 c51程序 矩阵键盘

1.代码:#include typedef unsigned char u8;typedef unsigned int u16;sbit seg_sel = P1^4;sbit bit_sel = P1^5;#defin...

关键字: 矩阵键盘 解码程序

采用反转法判断按键坐标,即行号与列号获得按键码。 写完后发现Proteus一个问题:直接使用这样的if(P10xf0!=0xf0)语句时,调不出来,当用了一个中间变量过渡时,就调出来了,害我花了一个上午的时间,现在...

关键字: 4x4 单片机 扫描程序 矩阵键盘
关闭
关闭