史上最容易理解的矩阵键盘C语言

采用4位一体共阳数码管,P0口输出段码,P2口输出位码,P1口接4*4矩阵键盘,最左边2个数码管可以显示按键值0~15,按键0可让最右边数码管显示值加1,按键0可减1,显示值在0-9之间循环。可有效避免按一次按键,按键处理却多次的情况。

#include <reg52.h>
#define uchar unsigned char

uchar segcode[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
uchar bitcode[]={0x01,0x02,0x04,0x08};
uchar key_value,key_re;
uchar temp,row,col;
uchar num=5;

void delay(uchar n)
{
	uchar i,j;
	for(i=0;i<n;i++)
		for(j=0;j<120;j++);
}

void main()
{
	
	while(1)
	{
		if((P1 == 0x0f)||(P1 == 0xf0))			
		   key_re = 1;//按键已释放
		P1 = 0x0f;
		if((P1&0x0f) != 0x0f)
		{
			delay(10);
			if((P1&0x0f) != 0x0f)
			{
				temp = P1&0x0f;
				switch(temp)
				{
					case 0x0e: row = 0; break;
					case 0x0d: row = 1; break;
					case 0x0b: row = 2; break;
					case 0x07: row = 3; break;
					default: key_value = 0xff;	break;				
				}
				P1 = 0xf0;
				temp = P1&0xf0;
				switch(temp)
				{
					case 0xe0: col = 0; break;
					case 0xd0: col = 1; break;
					case 0xb0: col = 2; break;
					case 0x70: col = 3; break;
					default: key_value = 0xff; break;					
				}
				key_value = row*4 + col;
				if(key_re == 1)
				{					
					if(key_value == 0)
						num++;
					if(num==10)
						num=0;
					if(key_value == 1)
						num--;
					if(num==-1)
						num=9;						
					key_re = 0;
				}
			}			
		}

		P0 = segcode[key_value/10];
		P2 = bitcode[0];
		delay(2);
		P2 = 0x00;
		
		P0 = segcode[key_value%10];
		P2 = bitcode[1];
		delay(2);
		P2 = 0x00;

		P0 = segcode[num];
		P2 = bitcode[3];
		delay(2);
		P2 = 0x00;		
	}	
}

对应的仿真电路图如下。
矩阵按键电路
按键检测流程:先置全行高全列低,然后读取0-3行,如有键按下,则有一行读入后为低,记下行号。然后置全行低全列高,然后读取0-3列,如有键按下,则有一列读入后为低,记下列号。行号*4+列号等于键值。为防止一次按键处理多次,采用了变量key_re,re是release的缩写,当P1读入为0x0f或0xf0时,key_re=1,标识按键已释放,在key_re为1,检测到按键按下时,才处理按键值。按键值处理完后key_re=0,如果按键此时按键没有释放,那么再次检测到按键时,key_re=0,不会执行按键处理。这种方法优于采用延时来处理。

  • 2
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是一个简单的4×4矩阵键盘C语言代码,可以检测并输出按下的键: ```c #include <stdio.h> #include <stdlib.h> #include <wiringPi.h> // 定义每个按键所连接的GPIO引脚编号 int rows[4] = {0, 1, 2, 3}; // 行 int cols[4] = {4, 5, 6, 7}; // 列 char keys[4][4] = { // 按键的映射矩阵 {'1', '2', '3', 'A'}, {'4', '5', '6', 'B'}, {'7', '8', '9', 'C'}, {'*', '0', '#', 'D'} }; void init() { wiringPiSetup(); // 初始化wiringPi库 // 设置GPIO引脚的模式为输出或输入 for (int i = 0; i < 4; i++) { pinMode(rows[i], OUTPUT); digitalWrite(rows[i], HIGH); // 行默认高电平 pinMode(cols[i], INPUT); pullUpDnControl(cols[i], PUD_UP); // 列默认上拉电阻 } } char scan() { // 扫描矩阵键盘 int row, col; for (row = 0; row < 4; row++) { digitalWrite(rows[row], LOW); // 输出低电平 for (col = 0; col < 4; col++) { if (!digitalRead(cols[col])) { // 检测到按键按下 digitalWrite(rows[row], HIGH); // 释放行,防止干扰 return keys[row][col]; } } digitalWrite(rows[row], HIGH); // 释放行 } return NULL; // 如果没有任何按键按下则返回NULL } int main() { init(); // 初始化GPIO printf("Press any key on the 4x4 keypad.\n"); while (1) { char key = scan(); if (key) { printf("Key pressed: %c\n", key); } } return 0; } ``` 说明: - `wiringPi`是一个能够方便地控制树莓派GPIO的C语言库; - 4×4的矩阵键盘每个行列都被连接到一个GPIO引脚上; - 扫描矩阵键盘需要分别输出每行低电平,并检测每列是否有信号输入; - 如果检测到有按键按下,则返回对应的字符映射; - 程序会不断扫描键盘,直到有按键按下为止。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值