蓝桥杯物联网竞赛_STM32L071_9_按键矩阵扩展模块

2023-12-05 03:44

本文主要是介绍蓝桥杯物联网竞赛_STM32L071_9_按键矩阵扩展模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原理图:

矩阵按键原理图:

在这里插入图片描述
实验板接口原理图:

在这里插入图片描述
得到对应图:

在这里插入图片描述

扫描按键原理:

按键的COLUMN1、2、3分别制0,每次只允许其中一个为0其他都是1(POW1和POW2正常状况为上拉),当有一个按键按下POW1和POW2必有一个被制0,这样就是能找到按键的标号
所以很明确COLUMN1、2、3应该制为输出电平,而POW1和POW2应该制输入电平用来读取按键被按下而传入的低电平

CubMX配置:

在这里插入图片描述

由于OLED引脚被占用所以用串口输出调试

Keil配置:

Function:

#include "Function.h"
#include "usart.h"
#include "gpio.h"void Function_SendInformation(const char * data, uint16_t len){HAL_UART_Transmit(&huart2, data, len, 0xff);
}void Function_ReciveInformation(char * data, uint16_t len){HAL_UART_Receive(&huart2, data, len, 0xff);
}void Function_OnlyRsetPortPin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin){ // 将其中一个COLUMN制0HAL_GPIO_WritePin(COLUMN1_GPIO_Port, COLUMN1_Pin, GPIO_PIN_SET);HAL_GPIO_WritePin(COLUMN2_GPIO_Port, COLUMN2_Pin, GPIO_PIN_SET);HAL_GPIO_WritePin(COLUMN3_GPIO_Port, COLUMN3_Pin, GPIO_PIN_SET);HAL_GPIO_WritePin(GPIOx, GPIO_Pin, GPIO_PIN_RESET);
}unsigned char Function_ResetPowNumberFind(void){ // 找到哪一根POW线制零了if(HAL_GPIO_ReadPin(POW1_GPIO_Port, POW1_Pin) == GPIO_PIN_RESET){ HAL_Delay(2); // 去抖动if(HAL_GPIO_ReadPin(POW1_GPIO_Port, POW1_Pin) == GPIO_PIN_RESET){ // 有效按下while(HAL_GPIO_ReadPin(POW1_GPIO_Port, POW1_Pin) == GPIO_PIN_RESET); // 按下一直有效return 1; // 松开放回POW1被制0}}if(HAL_GPIO_ReadPin(POW2_GPIO_Port, POW2_Pin) == GPIO_PIN_RESET){ HAL_Delay(2); // 去抖动if(HAL_GPIO_ReadPin(POW2_GPIO_Port, POW2_Pin) == GPIO_PIN_RESET){ // 有效按下while(HAL_GPIO_ReadPin(POW2_GPIO_Port, POW2_Pin) == GPIO_PIN_RESET); // 按下一直有效return 2; // 松开放回POW1被按下}}return 0; // 即POW1和POW2都未读取0
}unsigned char Function_KeyMatrixCheck(void){unsigned char PowFind = 0;Function_OnlyRsetPortPin(COLUMN1_GPIO_Port, COLUMN1_Pin);PowFind = Function_ResetPowNumberFind();	if(PowFind == 1) return 1;else if(PowFind == 2) return 4;PowFind = 0;Function_OnlyRsetPortPin(COLUMN2_GPIO_Port, COLUMN2_Pin);PowFind = Function_ResetPowNumberFind();	if(PowFind == 1) return 2;else if(PowFind == 2) return 5;PowFind = 0;Function_OnlyRsetPortPin(COLUMN3_GPIO_Port, COLUMN3_Pin);PowFind = Function_ResetPowNumberFind();	if(PowFind == 1) return 3;else if(PowFind == 2) return 6;	
}
#ifndef __FUNCTION__
#define __FUNCTION__
#include <stdint.h>void Function_SendInformation(const char * data, uint16_t len);
void Function_ReciveInformation(char * data, uint16_t len);
unsigned char Function_KeyMatrixCheck(void);
#endif

main:

 
#include "main.h"
#include "usart.h"
#include "gpio.h"
#include "Function.h"void SystemClock_Config(void);int main(void)
{unsigned char Rx[1];HAL_Init();SystemClock_Config();MX_GPIO_Init();MX_USART2_UART_Init();while (1){Rx[0] = Function_KeyMatrixCheck();if(Rx[0]){ // 返回不是0才输出Function_SendInformation(Rx, 1);}HAL_Delay(1000);}}void SystemClock_Config(void)
{RCC_OscInitTypeDef RCC_OscInitStruct = {0};RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;RCC_OscInitStruct.HSIState = RCC_HSI_ON;RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;RCC_OscInitStruct.PLL.PLLMUL = RCC_PLLMUL_4;RCC_OscInitStruct.PLL.PLLDIV = RCC_PLLDIV_2;if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK){Error_Handler();}RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_1) != HAL_OK){Error_Handler();}PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART2;PeriphClkInit.Usart2ClockSelection = RCC_USART2CLKSOURCE_PCLK1;if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK){Error_Handler();}
}void Error_Handler(void)
{__disable_irq();while (1){}}

运行效果:

在这里插入图片描述
在这里插入图片描述

这篇关于蓝桥杯物联网竞赛_STM32L071_9_按键矩阵扩展模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/456015

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

hdu 4565 推倒公式+矩阵快速幂

题意 求下式的值: Sn=⌈ (a+b√)n⌉%m S_n = \lceil\ (a + \sqrt{b}) ^ n \rceil\% m 其中: 0<a,m<215 0< a, m < 2^{15} 0<b,n<231 0 < b, n < 2^{31} (a−1)2<b<a2 (a-1)^2< b < a^2 解析 令: An=(a+b√)n A_n = (a +

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类