stm32 4*4矩阵键盘

原理在http://www.51hei.com/mcu/3815.html上讲得很清楚,也附了代码,本文主要是改进了代码中的一些问题,并且作了详细的注释,欢迎读者评论交流。(还没测试,测试结果要等键盘发过来)

#include"anjian4_4.h"
/*
PF7:A B C D
PF6:3 6 9 #
PF5:2 5 8 0
PF4:1 4 7 *  第一列
///
PF3:* 0 # D
PF2:7 8 9 C
PF1:4 5 6 B
PF0:1 2 3 A  第一行
*/
/*按键使能函数
PB0-PB7
*/
void Key_Config(void)
{
    GPIO_InitTypeDef GPIO_InitStructure;
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOF, ENABLE);

    /********4列输出*********/
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 | GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOF, &GPIO_InitStructure);

    /********4行输入*********/
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOF, &GPIO_InitStructure);
}
//按键扫描函数
void matrixkeyscan()
{
uchar temp,key;

/*=========================以下代码是按键扫描程序=========================*/
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3, GPIO_PIN_RESET); // 先清空引脚状态
    
/*----------------------------Scan the 1st ROW----------------------------*/
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_1|GPIO_PIN_2|GPIO_PIN_3, GPIO_PIN_SET);   // 设置PD1 2 3为1
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0, GPIO_PIN_RESET);                       // 设置PD0 为0    二进制编码为1111 1110 
//1111 1110 高位是列,低位是行
//把引脚的值赋给temp,作运算的时候不改变P3的值
//后面计算全部用temp,方便大规模改动引脚
	  temp=(GPIOF->IDR&0xFF);//读取
    if((temp&0xf0)!=0xf0)//如果有按键按下
    {
      delayms(10);//延时消抖
			temp=(GPIOF->IDR&0xFF);//第二次读取
      if(temp!=0xf0)//如果有按键按下
      {
        switch(temp)//通过P3的值,判断是哪个按键按下
        {
          case 0xee:
               key=1;
               break;
          case 0xde:
               key=2;
               break;
          case 0xbe:
               key=3;
               break;
          case 0x7e:
               key='A';
               break;
         }
         while(temp!=0xf0)//等待按键释放
         {
           temp=(GPIOF->IDR&0xFF);//读取
         }
      }
    }

		/*----------------------------Scan the 2st ROW----------------------------*/
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0|GPIO_PIN_2|GPIO_PIN_3, GPIO_PIN_SET);   // 设置PD0 2 3为1
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_1, GPIO_PIN_RESET);                       // 设置PD1 为0    二进制编码为1111 1101 
    temp=(GPIOF->IDR&0xFF);//读取
    if((temp&0xf0)!=0xf0)
    {
      delayms(10);
      temp=(GPIOF->IDR&0xFF);//二次读取
			if((temp&0xf0)!=0xf0)
      {
        temp=P3;
        switch(temp)
        {
          case 0xed:
               key=4;
               break;
          case 0xdd:
               key=5;
               break;
          case 0xbd:
               key=6;
               break;
          case 0x7d:
               key='B';
               break;
         }
         while(temp!=0xf0)//等待按键释放
         {
           temp=(GPIOF->IDR&0xFF);//读取
         }
      }
      }
/*----------------------------Scan the 3st ROW----------------------------*/
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_3, GPIO_PIN_SET);   // 设置PD0 1 3为1
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_2, GPIO_PIN_RESET);                       // 设置PD2 为0    二进制编码为1111 1011 
    temp=(GPIOF->IDR&0xFF);//读取
    temp=temp&0xf0;
    if((temp&0xf0)!=0xf0)
    {
      delayms(10);
      temp=(GPIOF->IDR&0xFF);//二次读取
      if((temp&0xf0)!=0xf0)
      {
        temp=P3;
        switch(temp)
        {
          case 0xeb:
               key=7;
               break;
          case 0xdb:
               key=8;
               break;
          case 0xbb:
               key=9;
               break;
          case 0x7b:
               key='C';
               break;
         }
         while(temp!=0xf0)//等待按键释放
         {
           temp=(GPIOF->IDR&0xFF);//读取
         }
      }
      }
/*----------------------------Scan the 4st ROW----------------------------*/
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_2, GPIO_PIN_SET);   // 设置PF0 1 2为1
    HAL_GPIO_WritePin(GPIOD, GPIO_PIN_3, GPIO_PIN_RESET);                       // 设置PF3 为0    二进制编码为1111 0111 
    temp=(GPIOF->IDR&0xFF);//读取
    temp=temp&0xf0;
    if((temp&0xf0)!=0xf0)
    {
      delayms(10);
      temp=(GPIOF->IDR&0xFF);//二次读取
      if((temp&0xf0)!=0xf0)
      {
        switch(temp)
        {
          case 0xe7:
               key='*';
               break;
          case 0xd7:
               key=0;
               break;
          case 0xb7:
               key=9;
               break;
          case 0x77:
               key='D';
               break;
         }
         while(temp!=0xf0)//等待按键释放
         {
           temp=(GPIOF->IDR&0xFF);//读取
         }
      }
    }
}
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
STM32 4*4矩阵键盘原理是指使用STM32微控制器和4行4列的矩阵键盘组合起来实现按键输入的一种方法。 矩阵键盘是一种常见的输入设备,由多个按键按照矩阵排列组成,每个按键连接到矩阵的一个交叉点上。4*4矩阵键盘共有4行和4列,总共16个按键。 在STM32微控制器中,通过使用GPIO(通用输入输出)引脚作为键盘的控制线和数据线,实现对矩阵键盘的扫描。具体工作步骤如下: 1. 初始化GPIO引脚:选择4个GPIO引脚作为行线,设置为输出模式,并把它们输出高电平。选择4个GPIO引脚作为列线,设置为输入模式,开启上拉电阻。 2. 扫描行:将其中一个行线设置为低电平,其余行线保持高电平。然后读取列线的电平状态,判断是否有按键按下。如果有按键按下,说明该列线和行线交叉点有连接。 3. 判断按键:通过检测哪个列线有电平变化,可以确定按下的按键所在的列。再结合之前设置的低电平行线,就可以确定按键所在的行。通过这样的扫描方式,可以检测到按键的位置。 4. 键值获取:根据按键所在的行和列,可以确定按键的唯一编号或者键值。可以通过查找键值对应的字符、数字或其他功能来实现具体的按键响应。 5. 不断循环扫描:通过不断循环这些步骤,可以不断检测键盘状态,实现对按键的准确响应。 通过上述原理,STM32 4*4矩阵键盘可以实现对16个按键的检测和响应,广泛应用于各种嵌入式系统和电子产品中,以实现人机交互。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值