基于51单片机的带矩阵键盘指纹密码电子锁原理图PCB

这篇具有很好参考价值的文章主要介绍了基于51单片机的带矩阵键盘指纹密码电子锁原理图PCB。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

功能:
0.本系统采用STC89C52作为单片机
1.LCD1602液晶显示功能界面
2.支持添加/删除/搜索指纹,更改密码
3.支持指纹和密码开锁
4.采用DC002作为电源接口可直接输入5V给整个系统供电

原理图:

51单片机密码锁原理图,51单片机,单片机,c语言
51单片机密码锁原理图,51单片机,单片机,c语言

PCB :
51单片机密码锁原理图,51单片机,单片机,c语言

主程序:

#include "main.h"

enum ModeFlag_Df ModeFlag; //模式,正常开锁模式,设置密码模式,设置指纹模式
unsigned char stepCnt = 0;
char setIndex = 0;
xdata unsigned char dis0[16];
bit refreshFlag = 1;
unsigned char inpPasswd[4]; //输入密码
unsigned char Passwd[4] = {'0','0','0','0'}; //初始密码
unsigned char isNewFlag = 1;

void main()
{
    LOCK = OPEN; //锁打开
    DelayMs(200);
    LOCK = CLOSE; //锁关闭

    EEPROM_Init();
    DelayMs(200);

    // EEPROM_WriteByte(IS_NEW_ADDR, 1);
    
    ReadPassword(); //初次使用时屏蔽此句
    if (isNewFlag != 0)
    {
        unsigned char i = 0;
        
        EEPROM_WriteByte(IS_NEW_ADDR, 0);
        for (i = 0; i < 4; i++)
        {
            Passwd[i] = '0';
        }
        WritePassword();
    }

    LCD_Init(); //初始化液晶
    LCD_DispStr(0, 0, "Fingerprint Lock"); //液晶开机显示界面
    Timer0_Init(); //初始化定时器
    Uart_Init();  //初始化串口
    DelayMs(200);
    DelayMs(200);
    DelayMs(200); //延时500MS,等待指纹模块复位
    Device_Check(); //校对指纹模块是否接入正确,液晶做出相应的提示
    DelayMs(200);
    DelayMs(200);
    DelayMs(200); //对接成功界面停留一定时间

    LCD_Clear();
    LCD_DispStr(0, 0, "Enter pw or fp: "); //显示

    while (1)
    {
        if (refreshFlag == 1)
        {
            TR0 = 0;
            refreshFlag = 0;
            if (ModeFlag == NORMAL)
            {
                if (stepCnt == 0)
                {
                    LCD_DispStr(0, 0, "Enter pw or fp: "); //显示
                    LCD_DispStr(0, 1, "                ");
                }
                CTRL_BY_FPM10A_Find_Fingerprint(); //搜索指纹
            }
            else if (ModeFlag == OLD_PW)
            {
                if (stepCnt == 0)
                {
                    LCD_DispStr(0, 0, "Old Password:   "); //显示
                    LCD_DispStr(0, 1, "                ");
                }
            }
            else if (ModeFlag == SELECT_PW_FP)
            {
                LCD_DispStr(0, 0, "A.Set Password  "); //显示
                LCD_DispStr(0, 1, "B.SetFingerprint");
            }
            else if (ModeFlag == SET_PW)
            {
                if (stepCnt == 0)
                {
                    LCD_DispStr(0, 0, "New Password:   "); //显示
                    LCD_DispStr(0, 1, "                ");
                }
            }
            else if (ModeFlag == SET_FP_SELECT)
            {
                Into_FP();
            }
            else if (ModeFlag == FIND_FP)
            {
                FPM10A_Find_Fingerprint();
            }
            else if (ModeFlag == ADD_FP)
            {
                FPM10A_Add_Fingerprint();
            }
            else if (ModeFlag == DELETE_FP)
            {
                LCD_DispStr(0, 0, "   Empty All    ");
                LCD_DispStr(0, 1, "  A.Yes  B.No   ");
            }
            TR0 = 1;
        }

        Key_Process(Calkey_scan());

    }
}

void Timer0_Init(void)
{
    TMOD |= 0x01;                //使用模式1,16位定时器,使用"|"符号可以在使用多个定时器时不受影响
    TH0 = (65536 - 18432) / 256; //重新赋值 20ms
    TL0 = (65536 - 18432) % 256;
    EA = 1;  //总中断打开
    ET0 = 1; //定时器中断打开
    TR0 = 1; //定时器开关打开
}

void Timer0_Interrupt(void) interrupt 1
{
    static unsigned char time_20ms = 0;

    TH0 = (65536 - 18432) / 256; //重新赋值 20ms
    TL0 = (65536 - 18432) % 256;
    time_20ms++;
    if (time_20ms > 10) //定时显示
    {
        refreshFlag = 1;
        time_20ms = 0;
    }
}

void Open_Lock(void) //打开电磁锁
{
    LOCK = OPEN;
    DelayMs(250);
    DelayMs(250);
    LOCK = CLOSE;
}

void Into_FP(void)
{
    /**************进入主功能界面****************/
    if (setIndex == 0)
    {
        LCD_DispStr(0, 0, " *Search finger "); //第一排显示搜索指纹
        LCD_DispStr(0, 1, "  Add     Delete"); //添加和删除指纹
    }
    else if (setIndex == 1)
    {
        LCD_DispStr(0, 0, "  Search finger "); //第一排显示搜索指纹
        LCD_DispStr(0, 1, " *Add     Delete"); //添加和删除指纹
    }
    else if (setIndex == 2)
    {
        LCD_DispStr(0, 0, "  Search finger "); //第一排显示搜索指纹
        LCD_DispStr(0, 1, "  Add    *Delete"); //添加和删除指纹
    }
}

void ReadPassword(void)
{
    unsigned char i = 0;

    isNewFlag = EEPROM_ReadByte(IS_NEW_ADDR);

    for (i = 0; i < 4; i++)
    {
        Passwd[i] = EEPROM_ReadByte(PASSWORD_ADDR + i);
    }
}

void WritePassword(void)
{
    unsigned char i = 0;
    
    for (i = 0; i < 4; i++)
    {
        EEPROM_WriteByte(PASSWORD_ADDR + i, Passwd[i]);
    }
}

void Key_Process(unsigned char keyCode)
{
    static unsigned char count_num = 0;
    static unsigned char i = 0;
    
    if (ModeFlag == NORMAL)
    {
        if (keyCode == 'A') //设置键
        {
            ModeFlag = OLD_PW;
        }
        else if ((keyCode >= '0') && (keyCode <= '9'))
        {
            stepCnt = 1;
            if (count_num <= 3)
            {
                inpPasswd[count_num] = keyCode;
                // LCD_DispOneChar((count_num+6), 1, inpPasswd[count_num]);
                LCD_DispOneChar((count_num+6), 1, '*');
                count_num++;
            }
            if (count_num == 4)
            {
                DelayMs(250);
                DelayMs(250);
                for (i = 0; i < 4; i++) //判断密码是否正确
				{
					if (inpPasswd[i] != Passwd[i])
						break;
				}
				if (i == 4) //密码输入正确
				{
                    LCD_DispStr(0, 1, "      Open      "); //显示状态
                    Open_Lock();
				}
                else
                {
                    LCD_DispStr(0, 1, "     Error      "); //显示状态
                    Buzz_Times(2);
                }
                DelayMs(250);
                DelayMs(250);
                stepCnt = 0;
                count_num = 0;
            }
        }
    }
    else if (ModeFlag == OLD_PW)
    {
        if ((keyCode >= '0') && (keyCode <= '9')) //输入旧密码
        {
            stepCnt = 1;
            if (count_num <= 3)
            {
                inpPasswd[count_num] = keyCode;
                // LCD_DispOneChar((count_num+6), 1, inpPasswd[count_num]);
                LCD_DispOneChar((count_num+6), 1, '*');
                count_num++;
            }
            if (count_num == 4)
            {
                DelayMs(250);
                DelayMs(250);
                for (i = 0; i < 4; i++) //判断密码是否正确
                {
                    if (inpPasswd[i] != Passwd[i])
                        break;
                }
                if (i == 4) //密码输入正确
                {
                    LCD_DispStr(0, 1, "     Right      "); //显示状态
                    DelayMs(250);
                    DelayMs(250);
                    ModeFlag = SELECT_PW_FP;
                }
                else
                {
                    LCD_DispStr(0, 1, "     Error      "); //显示状态
                    Buzz_Times(2);
                    DelayMs(250);
                    DelayMs(250);
                    ModeFlag = NORMAL; //返回最初界面
                }
                stepCnt = 0;
                count_num = 0;
            }
        }
    }
    else if (ModeFlag == SELECT_PW_FP)
    {
        if (keyCode == 'A')
        {
            ModeFlag = SET_PW;
        }
        else if (keyCode == 'B')
        {
            ModeFlag = SET_FP_SELECT;
            setIndex = 0;
        }
    }
    else if (ModeFlag == SET_PW)
    {
        if ((keyCode >= '0') && (keyCode <= '9')) //设置新密码
        {
            stepCnt = 1;
            if (count_num <= 3)
            {
                Passwd[count_num] = keyCode;
                LCD_DispOneChar((count_num+6), 1, Passwd[count_num]);
                count_num++;
            }
            if (count_num == 4)
            {
                DelayMs(250);
                DelayMs(250);
                LCD_DispStr(0, 1, "      OK        "); //显示状态
                WritePassword();
                DelayMs(250);
                DelayMs(250);
                ModeFlag = NORMAL;
                stepCnt = 0;
                count_num = 0;
            }
        }
        else if (keyCode == 'B')
        {
            ModeFlag = SELECT_PW_FP;
        }
    } 
    else if (ModeFlag == SET_FP_SELECT)
    {
        if (keyCode == 'A') //确认
        {
            switch (setIndex)
            {
            case 0: //搜索指纹
                ModeFlag = FIND_FP;
                // FPM10A_Find_Fingerprint();
                break;

            case 1: //添加指纹
                ModeFlag = ADD_FP;
                // FPM10A_Add_Fingerprint();
                break;

            case 2: //清空指纹
                ModeFlag = DELETE_FP;
                // FPM10A_Delete_All_Fingerprint();
                break;
            }
        }
        else if (keyCode == 'B')
        {
            ModeFlag = SELECT_PW_FP;
        }
        else if (keyCode == '*') //设置位置移动
        {
            setIndex--;
            if (setIndex < 0)
            {
                setIndex = 2;
            }
        }
        else if (keyCode == '#') //设置位置移动
        {
            setIndex++;
            if (setIndex > 2)
            {
                setIndex = 0;
            }
        }
    }
    else if (ModeFlag == FIND_FP)
    {
        if (keyCode == 'B')
        {
            ModeFlag = SET_FP_SELECT;
        }
    }
    else if (ModeFlag == DELETE_FP)
    {
        if (keyCode == 'A')
        {
            LCD_DispStr(0, 0, "   Emptying     ");
            LCD_DispStr(0, 1, "                ");
            DelayMs(250);
            FINGERPRINT_Cmd_Delete_All_Model();
            FPM10A_Receive_Data(12);
            LCD_DispStr(0, 0, "   All empty    ");
            LCD_DispStr(0, 1, "                ");
            Buzz_Times(3);
            DelayMs(250);
            ModeFlag = NORMAL;
        }
        else if (keyCode == 'B')
        {
            ModeFlag = SET_FP_SELECT;
        }
    }

    if (keyCode == 'D')
    {
        ModeFlag = NORMAL;
        stepCnt = 0;
        count_num = 0;
        setIndex = 0;
    }
}

实物演示视频:
https://www.bilibili.com/video/BV1b3411j7DF/文章来源地址https://www.toymoban.com/news/detail-540712.html

到了这里,关于基于51单片机的带矩阵键盘指纹密码电子锁原理图PCB的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 51单片机入门——矩阵键盘(附51代码)

    硬件如图非常简单,将一个4*4的矩阵键盘的8个管脚引到端子上,在连接到8个I/O口上,ARRAY_H代表着行,ARRAY_L代表着列,当行与列的电平都置低的时候,就选中的相应的矩阵按键,比如当s1按下时,ARRAY_H1会置低,其他ARRAY_H给高电平,那么选中的就是第一行,然后到列,ARRAY_

    2024年02月11日
    浏览(43)
  • 51单片机(六)矩阵键盘和矩阵键盘密码锁

    ❤️ 专栏简介:本专栏记录了从零学习单片机的过程,其中包括51单片机和STM32单片机两部分;建议先学习51单片机,其是STM32等高级单片机的基础;这样再学习STM32时才能融会贯通。 ☀️ 专栏适用人群 :适用于想要从零基础开始学习入门单片机,且有一定C语言基础的的童鞋

    2024年02月04日
    浏览(53)
  • 6.51单片机之矩阵键盘

    👻 1.矩阵键盘的介绍 在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式。 采用逐行或逐列的“扫描”,就可以读出任何位置按键的状态。 结构:在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式。在矩阵式键盘中,每条

    2024年02月07日
    浏览(44)
  • 51单片机学习笔记-4矩阵键盘

    [toc] 注:笔记主要参考B站江科大自化协教学视频“51单片机入门教程-2020版 程序全程纯手打 从零开始入门”。 注:工程及代码文件放在了本人的Github仓库。 在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式。采用逐行或逐列的“扫描”,就可以读

    2024年02月06日
    浏览(56)
  • 51单片机矩阵键盘——数码管显示

    当我们熟悉了数码管的位选与段选,并了解的矩阵键盘的扫描之后就可以编写程序了。 按下矩阵键盘S1并松开,数码管第一位(LED8)显示0;按下矩阵键盘S2并松开,数码管第一位显示1;...按下矩阵键盘S16并松开,数码管第一位显示F; 矩阵键盘扫描(输入扫描)     原理:

    2024年02月11日
    浏览(55)
  • 51单片机实现矩阵键盘密码锁

    使用51单片机的矩阵键盘模块以及led1602显示屏,实现模拟密码锁。 当程序烧录到单片机中后,led1602屏幕会显示文字。 第一行会显示单词“PASSWORD”,第二行显示4个0,表示我们要写入的四位密码,每位默认为0。 矩阵键盘前两行与第三行的前两个分别代表输入1-9与0,第三行第

    2024年02月03日
    浏览(58)
  • 51单片机矩阵键盘——LCD1602显示

    本次的实验需要用到LCD1602液晶屏,需要用到LCD1602.c 与LCD1602.h文件链接: https://download.csdn.net/download/YLG_lin/86404949 使用矩阵键盘随意按下按键,LCD1602第二行前两位就会显示对应按键按下的数字。 在键盘中按键数量较多时,为了减少I/O口的占用,通常将按键排列成矩阵形式 采用

    2023年04月09日
    浏览(44)
  • 如何在51单片机上实现矩阵键盘功能

    本文详细介绍了在51单片机上实现矩阵键盘功能的方法,包括按键检测、消抖处理和键值映射等关键步骤。通过本文的学习,你将能够掌握在嵌入式系统中处理矩阵键盘输入的技术。

    2024年04月10日
    浏览(99)
  • 51单片机矩阵键盘扫描及使用方法

             矩阵键盘 ,也称矩阵按键,是为了节约单片机IO口占用所引入的一种外设。 (图片截取至普中A2开发板原理图) (图片截取至普中A2开发板实物图)         我们知道,一个独立按键需要1个IO口。但是如果我们需要大量的按键,则需要大量的IO口,但是单片机

    2024年02月02日
    浏览(38)
  • 51单片机学习--矩阵键盘、电子密码锁

    矩阵键盘的模块原理图: 功能:按下矩阵按键,在LCD上显示对应的数值。 采用模块化编程,在此只给出MatrixKey.c 和 main.c 两部分代码 这里要注意必须先判断KeyNum是否为0,否则while不断循环会不断显示0,导致看不到按下按钮显示的数字 要利用写好的矩阵键盘来制作一个密码锁

    2024年02月16日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包