单片机学习笔记---矩阵键盘密码锁

2024-01-27 15:36

本文主要是介绍单片机学习笔记---矩阵键盘密码锁,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一,设置密码按键

1.设置密码区域

2.设置输入的数字左移

3.设置记录按键的次数

二,设置确认键

1.密码正确时显示OK

2.密码错误时显示ERR

3.密码错误恢复初始状态重输

三,设置取消键


学了这么久,迫不及待想要做一个密码锁玩一玩,那直接进入正题!

这节我们可以直接创建一个跟上一节一模一样的工程文件。

可以直接复制粘贴上一节的工程文件,把名字改成矩阵键盘密码锁就可以了。

然后点击打开这个文件,就得到一个一模一样的工程了。

然后把上一节课的这一句代码改成Password

然后编译测试一下

没有错,可以继续了!

一,设置密码按键

我们想要把S1-S9定义为数字1-9,然后S10定义为0,为什么没有S0呢?

是因为0这个数字被占用了,作为一种没有按键按下的返回。

所以我们就把S10定义为0,S11作为确认键,S12作为取消键,S13-S16键不用。

开始写代码:

1.设置密码区域

需要再加一个if判断限制密码区

然后定义一个密码变量,类型是unsigned  int,为什么是unsigned  int?是因为它的取值范围是0-65535,为什么我们这个程序不用6位密码?因为六位的话已经超出unsigned int的取值范围了。

如果定义一个5位数的密码是99999的话就存不了,当然也可以改成unsigned long long类型,但是这样还受限于我们的LCD1602.c中的定义的LCD_ShowNum只支持0-65535,所以6位密码不好显示。

当然,如果你想的话也可以显示,比如可以定义一个数组,然后一位一位分开存,然后一位一位地显示。

但是为了简单,本节只显示4位密码,这样Unsigned int完全可以存的下了。

代码这样写

这里还需要改成Password

编译测试一下

按下9,松开就显示09

按下10松开就显示0

证明这段代码没有问题,继续!

2.设置输入的数字左移

我们需要把输入的上一个数字挪到左边去,代码这样写:

为什么这样写呢?

比如密码刚开始等于0000,然后输入一位密码1,按下1后就变成0001

如果再按下2,0001*10就变成 0010,再加上2,就是0012

如果再输入3,就是0012*10变成0120,再加上3,就是0123

搞明白了后,把先显示密码长度改成4

编译测试一下:

一次按下1 2 3 4后,屏幕上显示1234,效果正确!

如果再继续按5的话,最高位的1就不见了

如果按6的话,就显示错误,是因为超出了取值范围,就显示别的了。

3.设置记录按键的次数

所以我们接下来要写一段程序判断按下的次数

当输入超过4位,就不让用户继续输入了。

再定义一个变量Count用来计数:

测试一下:

当按第五次的时候,就不再有反应了,是我们想要实现的效果!

我们可以把这段代码挪上来

二,设置确认键

1.密码正确时显示OK

然后再加一个if判断,如果按下的密码正确则显示OK

测试一下:

正确!

2.密码错误时显示ERR

如果输入的密码不正确,就显示err错误

测试一下:

不等于正确密码,显示err

3.密码错误恢复初始状态重输

提示错误后,还得让人家继续输入,所以要恢复初始状态

正确与否都应该清零,才能让人重新输入。

测试一下:

按下1234后,显示错误

但是显示没有清零,但其实变量已经清零

所以我们还需要更新一下显示:

再测试一下:

输入1234错误后,提示ERR,并清零

重新输入2345,按下确认

显示OKR,并清零

为什么是显示OKR不是OK?

因为我们前面输错密码显示了ERR,现在显示OK才占两个字符,可以在OK后面加个空格占一个字符,覆盖R

再测试一下:

这样就没有多出来一个R了

三,设置取消键

接下来还需要设置一个取消键,如果人家输到一半密码发现输错了,按取消,重新输。

测试一下:

输入2345,点取消

什么都没有显示,直接清零

输1234,点击确认显示ERR

输2345,点击确认,显示OK

OK和ERR都会清零

以上就是本节想要实现的效果。

这节的代码比较多,如果出错,可以最好是边写边测试。

本节所有的程序源码评论区自取。

如果有问题可以私信我评论区留言,谢谢!

这篇关于单片机学习笔记---矩阵键盘密码锁的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

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 +

线性代数|机器学习-P36在图中找聚类

文章目录 1. 常见图结构2. 谱聚类 感觉后面几节课的内容跨越太大,需要补充太多的知识点,教授讲得内容跨越较大,一般一节课的内容是书本上的一章节内容,所以看视频比较吃力,需要先预习课本内容后才能够很好的理解教授讲解的知识点。 1. 常见图结构 假设我们有如下图结构: Adjacency Matrix:行和列表示的是节点的位置,A[i,j]表示的第 i 个节点和第 j 个