为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

液晶显示电子密码锁设计

2011-01-14 50页 doc 683KB 27阅读

用户头像

is_111350

暂无简介

举报
液晶显示电子密码锁设计学号:02206069 学号:02206069 2010 届本科生毕业论文(设计) 题 目: 液晶显示电子密码锁设计 学院(系): 信 息 工 程 学 院 专业年级: 计算机科学与技术2006级 学生姓名: 指导教师: 完成日期: 2010-6-10 液晶显示电子密码锁设计 摘 要 单片机技术是智能化检测与控制领域应用非常普及并且具有很大潜力的技术。论文阐述一个基于单片机的液晶显示电子密码锁的设计与实现。系统采用美国Atmel公司的AT89S52单片机作为系统核心,液晶显示器LCD1602作为输出设备显示系统提示信息,4*4矩...
液晶显示电子密码锁设计
学号:02206069 学号:02206069 2010 届本科生毕业论文(设计) 题 目: 液晶显示电子密码锁设计 学院(系): 信 息 工 程 学 院 专业: 计算机科学与技术2006级 学生姓名: 指导教师: 完成日期: 2010-6-10 液晶显示电子密码锁设计 摘 要 单片机技术是智能化检测与控制领域应用非常普及并且具有很大潜力的技术。论文阐述一个基于单片机的液晶显示电子密码锁的设计与实现。系统采用美国Atmel公司的AT89S52单片机作为系统核心,液晶显示器LCD1602作为输出设备显示系统提示信息,4*4矩阵薄膜键盘作为输入设备,CMOS串行E2PROM存储器AT24C02作为数据存储器,配合蜂鸣器、继电器等电路构成整个系统硬件;系统软件采用汇编语言编写。设计的系统液晶显示,密码修改方便,具有报警、锁定等功能,使用便捷简单,符合住宅、办公用锁需求,具有一定的实用价值。 关键词:密码锁;单片机;AT89S52;LCD1602;AT24C02 The Design of LCD Electronic Password-Lock Abstract SCM technology is very popular and has great potential in application of intelligent detection and control field. This thesis describes the design and implementation of LCD electronic password-lock system based on SCM. The system uses the product of America Atmel corporation AT89S52 as the core of system, liquid crystal monitor 1602 as the output device displaying the prompt information of system, 4*4 matrix membrane keyboard as the input device, serial E2PROM memory AT24C02 as the data storage, with buzzer, relay, and other circuits together constitute the system hardware. The software of the system is written in assembly language. The designed system display in LCD, change password easily, has the function of alarming, locking, and so on. This system is simple and easy to use, meets the demand of residential, office lock needs, has some practical value. Key words: Password-Lock; SCM; AT89S52; LCD1602; AT24C02 目 录 TOC \o "1-3" \h \u 1 引言 - 1 - 2 系统设计 - 1 - HYPERLINK \l _Toc19289 2.1 功能设计 - 1 - HYPERLINK \l _Toc18314 2.2 结构设计 - 2 - 3 硬件设计 - 3 - HYPERLINK \l _Toc19372 3.1 AT89S52简介 - 3 - HYPERLINK \l _Toc7049 3.2 液晶显示电路 - 5 - HYPERLINK \l _Toc7477 3.2.1 LCD1602简介 - 5 - HYPERLINK \l _Toc15577 3.2.2 LCD1602电路 - 9 - HYPERLINK \l _Toc18090 3.3 发声电路 - 9 - HYPERLINK \l _Toc1336 3.4 开锁控制电路 - 10 - HYPERLINK \l _Toc31888 3.5 密码存储电路 - 11 - HYPERLINK \l _Toc29050 3.5.1 AT24C02简介 - 11 - HYPERLINK \l _Toc30937 3.5.2 AT24C02电路 - 14 - HYPERLINK \l _Toc2964 3.6 键盘输入电路 - 14 - HYPERLINK \l _Toc1865 3.7 手动复位电路 - 14 - HYPERLINK \l _Toc11563 3.8 晶振电路 - 15 - 4 软件设计 - 16 - HYPERLINK \l _Toc14327 4.1 系统主程序 - 16 - HYPERLINK \l _Toc30919 4.1.1 初始化及按键识别 - 16 - HYPERLINK \l _Toc19968 4.1.2 按键重定位 - 17 - HYPERLINK \l _Toc17478 4.1.3 保存密码 - 19 - HYPERLINK \l _Toc2258 4.1.4 确认键处理 - 19 - HYPERLINK \l _Toc27011 4.1.5 开锁键处理 - 20 - HYPERLINK \l _Toc3872 4.1.6 改密键处理 - 21 - HYPERLINK \l _Toc3878 4.1.7 校验新密码 - 21 - HYPERLINK \l _Toc9393 4.2 系统相关子程序 - 22 - HYPERLINK \l _Toc10924 4.2.1 按键识别子程序 - 22 - HYPERLINK \l _Toc28303 4.2.2 液晶显示子程序 - 23 - HYPERLINK \l _Toc25691 4.2.3 AT24C02子程序 - 23 - 5 系统调试与测试 - 25 - 6 结论 - 26 - 附 录 - 29 - 1 引言 锁具是源流千古的社会性用品,主要用于日常生活和工作中,住宅与部门的安全防范。当前门锁的主流是弹子锁,其保密性不强,钥匙容易被仿制和意外丢失;且持有者需随时携带钥匙,使用不方便。保存贵重物件的保险箱主要用机械密码锁,其结构较为复杂,制造精度要求高,成本高昂,且易出现故障。随着科技、经济和社会的发展,当今社会公共安全防范系统对锁具的保密性、牢固性、可靠性、耐用性以及安装使用等提出了新的更高的要求。针对原有锁具的特点和缺陷,为满足人们对锁的使用需求,增加其安全性,用密码代替钥匙的电子密码锁应运而生。 早期开发的电子密码锁由于电子器件所限,种类不多,保密性差,最基本的就是只依靠最简单的模拟电子开关来实现的,制作简单但不安全。后来多是基于EDA实现,其电路结构复杂,电子元件繁多,也有使用早先2051系列单片机来实现的,但密码简单,容易破解。随着电子元件的进一步发展,电子密码锁也出现了很多的种类,功能日益强大,使用更加方便,保密安全性更强;由以前的单密码输入发展到现在密码加感应元件,实现了真正的电子加密。 电子密码锁是一种通过密码输入来控制电路或是芯片工作,从而控制机械开关的闭合,完成开锁、闭锁任务的电子产品。它的种类很多,有简易的电路产品,也有基于芯片的性价比较高的产品。电子密码锁的出现给人们带来了极大的方便,有很广阔的市场前景。现在应用较广的电子密码锁是以芯片为核心,通过编程来实现的。其性能和安全性已大大超过了机械锁,特点有: 保密性好,编码量多。 随机开锁成功率几乎为零。 密码可变。用户可以经常更改密码,防止密码被盗,同时也可以避免因人员的更替而使锁的密级下降。 误码输入保护。当输入密码多次错误时,报警系统自动启动。 操作简单易行,一学即会。 论文阐述基于美国Atmel公司的AT89S52单片机,采用液晶显示器1602作为输出显示系统提示信息的电子密码锁的设计与实现。 2 系统设计 2.1 功能设计 本系统拟采用单片机为主控芯片,由于单片机种类繁多,各种型号都有其各自特点,应用于不同的环境,因此在选用时要多加比较。一般来说,在选取单片机时从下面几个方面考虑:性能、存储器、运行速度、I/O口、定时/计数器、串行/并行接口、模拟电路功能、工作电压、功耗、封装形式、抗干扰性、保密性等等。基于以上因素本设计选用单片机AT89S52作为本设计的核心元件,利用该单片机灵活的编程设计和丰富的I/O端口,及其控制的准确性,实现基本的密码锁功能。 在单片机I/O接口上外接输入键盘用于输入和一些功能的控制。考虑到密码的存在形式一般为数字或字母形式,而字母数量众多,并且排列不规则,不能使用矩阵式键盘排列字母;并且按键过多会大大增加系统的体积,对适用性极为不利,故只使用数字作为密码。阿拉伯数字不仅便于用户记忆,而且通用性极强,是作为密码的首选。10个数字需要1个不同的按键,故选用为4*4矩阵键盘;除去10个数字键,还剩6个按键可设置不同的功能。 用户使用电子密码锁开锁的步骤为:用户输入数字密码,输入完毕后按确认键。如果密码正确,再按开锁键,即可开锁。如果密码错误则报警,如果密码错误多次,还会锁定键盘。这里需要蜂鸣器提示用户按键已按下,开锁需要继电器开关。液晶显示器则直观显示系统当前状态和提示用户需要做的操作。 用户修改密码步骤为:首先输入旧密码,输入完毕后按确认键。如果密码正确再按改密键。输入两次新密码并确认。如果两次密码输入长度一致,则密码修改成功。如果两次输入不一致,则密码修改失败。失败后只能重新输入旧密码才能继续改密。 为防止系统发生异常,还应提供复位开关,在系统无法正常运转时手动复位。 2.2 结构设计 如图2-1所示,整个系统以单片机为核心,辅以若干外围电路。其中密码存储部分是输入输出双向结构,保证密码可以掉电保存,上电后读出。其余都是单向输入或输出。电源部分为整个系统供电,采用5V直流电源。键盘输入部分采用4*4矩阵行列键盘,需不断扫描检查有无按键按下。复位部分提供手动复位功能,当系统发生异常或未知错误时可以由用户手动复位单片机。晶振部分是提供外部石英晶体谐振器。 系统输出有:液晶显示部分,为用户显示字符提示当前操作状态。蜂鸣器发声,提示用户按键已按下,以及密码正确的提示音,错误的警告音等。开锁电路部分是控制继电器,只有密码正确并选择开锁后,继电器内部的电磁铁才会吸合,发光二极管电路连通后发光,表示锁已打开。 3 硬件设计 根据上面的结构设计思路,具体设计中选用一块20cm*10cm的通用PCB板做为系统焊接板。单片机为Atmel公司的AT89S52,电源部分为直流4.5V,3节5号电池供电,实验时也可以用直流5V电源供电。键盘输入部分为4*4矩阵薄膜键盘,不需上拉电阻,但扫描时需先给行线或列线供电。液晶显示器选用1602,可以显示两行,每行16个字符。蜂鸣器为有源5V。继电器为5脚5V。密码存储选用串行AT24C02芯片,256B空间,足够存储密码,采用串行传输可以极大减少连线数目。系统原理电路图如图3-1所示。下面按系统的结构具体介绍一些电路及其所用的芯片。 3.1 AT89S52简介 AT89S52是一款低功耗、高性能CMOS8位微控制器,具有8K可编程 Flash存储器。使用 Atmel 公司高密度非易失性存储器技术制造,与工业 80C51 产品指令和引脚完全兼容。 AT89S52具有以下功能:8K字节Flash, 256字节RAM,32 位 I/O 口线,看门狗定时器,2 个数据指针,三个 16 位定时器/计数器,一个6向量 2级中断结构,全双工串行口,片内晶振及时钟电路。其引脚如图3-2所示,下面简要介绍其引脚功能: VCC:电源。本设计中接电源正极。 GND:地。本设计中接电源负极。 P0口:P0口是一个8位漏极开路的双向I/O口。作为输出口,每位能驱动8个TTL逻辑电平。对P0端口写"1"时,引脚用作高阻抗输入。 P1口:P1口是一个具有内部上拉电阻的8 位双向I/O口,P1输出缓冲器能驱动4个TTL逻辑电平。对 P1 端口写"1"时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流。 P2口:P2口是一个具有内部上拉电阻的8位双向I/O口,P2输出缓冲器能驱动4个TTL逻辑电平。对P2端口写"1"时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流。 P3口:P3口是一个具有内部上拉电阻的8位双向I/O口,P3输出缓冲器能驱动4个TTL逻辑电平。对P3端口写"1"时,内部上拉电阻把端口拉高,此时可以作为输入口使用。作为输入使用时,被外部拉低的引脚由于内部电阻的原因,将输出电流。 RST:复位输入。晶振工作时,RST脚持续2个机器周期高电平将使单片机复位。看门狗计时完成后,RST脚输出96个晶振周期的高电平。特殊寄存器AUXR(地址8EH)上的DISRTO位可以使此功能无效。DISRTO默认状态下,复位高电平有效。 EA/VPP:访问外部程序存储器控制信号。为使能从0000H到FFFFH的外部程序存储器读取指令,EA必须接GND。为了执行内部程序指令,EA应该接VCC。本设计中不需要外部程序存储器,因此需接高电平。 ALE/PROG:地址锁存控制信号(ALE)是访问外部程序存储器时,锁存低8位地址的输出脉冲。 PSEN:外部程序存储器选通信号(PSEN)是外部程序存储器选通信号。当AT89S52从外部程序存储器执行外部代码时,PSEN在每个机器周期被激活两次,而在访问外部数据存储器时,PSEN将不被激活。 XTAL1:振荡器反相放大器和内部时钟发生电路的输入端。 XTAL2:振荡器反相放大器的输出端。 以上是AT89S52的引脚功能介绍,下面简要介绍AT89S52的存储器结构。AT89S52有单独的程序存储器和数据存储器,外部程序存储器和数据存储器都可以64K寻址。 程序存储器:如果EA引脚接地,程序读取只从外部存储器开始。对于AT89S52,如果EA接VCC,程序读写先从内部存储器(地址为0000H~1FFFH)开始,接着从外部寻址,寻址地址为:2000H~FFFFH。 数据存储器:AT89S52有256字节片内数据存储器。高128字节与特殊功能寄存器重叠。也就是说高128字节与特殊功能寄存器有相同的地址,而物理上是分开的。当一条指令访问高于7FH的地址时,寻址方式决定CPU访问高128字节RAM还是特殊功能寄存器空间。 3.2 液晶显示电路 3.2.1 LCD1602简介 字符型液晶显示模块是一种专门用于显示字母、数字、符号等点阵式LCD,市面上字符液晶绝大多数是基于HD44780液晶芯片,HD44780是带西文字库的液晶显示控制器,用户只需要向HD44780送ASCII的字符码,HD44780就按照内置的ROM点阵发生器自动在LCD液晶显示器上显示出来。所以,HD44780主要适用于显示西文ASCII字符内容的液晶显示。 1602字符型LCD能够同时显示16*2即32个字符(16列2行)。其内置192种字符(160个5*7点阵字符和32个5*10点阵字符),具有64个字节的自定义字符RAM,可自定义8个5*8点阵字符或4个5*11点阵字符。 1602通常有14条引脚线或16条引脚线两种,多出来的2条线是背光电源线和地线,带背光的比不带背光的略厚,控制原理与14脚的LCD完全一样,是否带背光在应用中并无差别。本设计中采用带背光16引脚线的。其主要技术参数为: 显示容量:16×2个字符。 芯片工作电压:4.5-5.5V。 工作电流:2.0mA(5.0V)。 模块最佳工作电压:5.0V。 字符尺寸:2.95×4.35(W×H)mm。 LCD1602的16个引脚可参照图3-3,其引脚功能分别为: VSS:电源地(GND)。 VCC:电源电压(5V)。 V0:LCD驱动电压,液晶显示器对比度调整端。使用时可以通过一个10K的电位器调整对比度,接正电源时对比度最弱,接地电源时对比度最高。 RS:寄存器选择输入端,选择模块内部寄存器类型信号。RS=0,进行写模块操作时指向指令寄存器,进行读模块操作时指向地址计数器。RS=1,无论进行读操作还是写操作均指向数据寄存器。 R/W:读写控制输入端,选择读/写模块操作信号。R/W=0,读操作;R/W=1,写操作。本设计中只需往LCD里写数据即可,写时序见图3-4。 E:使能信号输入端。读操作时,高电平有效;写操作时,下降沿有效 DB0~DB7:数据输入/输出口,单片机与模块之间的数据传送通道。选择4位方式通讯时,不使用DB0~DB3。 BLA:背光的正端+5V。 BLK:背光的负端0V。 1602模块内部主要由LCD显示屏、控制器、列驱动器和偏压产生电路构成。控制器接受来自MPU的指令和数据,控制着整个模块的工作。主要由显示数据缓冲区DDRAM,字符发生器CGROM,字符发生器CGRAM,指令寄存器IR,地址寄存器DR,忙标志BF,地址计数器AC以及时序发生电路组成。 模块通过数据总线DB0~DB7和E、R/W、RS三个输入控制端与MPU接口。这三根控制线按照规定的时序相互协调作用,使控制器通过数据总线接受MPU发来的数据和指令,从CGROM中找到欲显示字符的字符码,送入DDRAM,在LCD显示屏上与DDRAM存储单元对应的规定位置显示出该字符。控制器还可以根据MPU的指令,实现字符的显示,闪烁和移位等显示效果。 CGROM内提供的是内置字符码,CGRAM则是供用户存储自定义的点阵图形字符。模块字符在LCD显示屏上的显示位置与该字符的字符代码在显示缓冲区DDRAM内的存储地址一一对应。 LCD1602模块内部具有两个8位寄存器:指令寄存器IR和地址寄存器DR,用户可以通过RS和R/W输入信号的组合选择指定的寄存器,进行相应的操作。表3-1中列出了组合选择方式: 表3-1 寄存器选择组合 1602提供了较为丰富的指令设置,通过选择相应的指令设置,用户可以实现多种字符显示样式。下面仅简要介绍本次设计中需要用到的一些指令设置。 清屏指令 Clear display 清显示指令将空位字符码20H送入全部DDRAM地址中,时DDRAM中的内容全部清除,显示消失,地址计数器AC=0,自动增一模式。显示归位,光标闪烁回到原点(显示屏左上角),但不改变移位设置模式。清屏指令码见表3-2。 表3-2 清屏指令码 RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 0 0 0 0 0 1 进入模式设置指令 Entry mode set 见表3-3,进入模式设置指令用于设定光标移动方向和整体显示是否移动。 表3-3 模式设置指令码 RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 0 0 0 1 I/D S I/D:字符码写入或者读出DDRAM后DDRAM地址指针AC变化方向标志。 I/D=1,完成一个字符码传送后,AC自动加1。 I/D=0,完成一个字符码传送后,AC自动减1。 S:显示移位标志。 S=1,完成一个字符码传送后显示屏整体向右(I/D=0)或向左(I/D=1)移位。 S=0,完成一个字符码传送后显示屏不移动。 显示开关控制指令 Display on/off control 指令码见表3-4,该指令功能为控制整体显示开关,光标显示开关和光标闪烁开关。 表3-4 显示开关控制指令码 RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 0 0 1 D C B D:显示开/关标志。D=1,开显示;D=0,关显示。 关显示后,显示数据仍保持在DDRAM中,开显示即可再现。 C:光标显示控制标志。C=1,光标显示;C=0,光标不显示。 不显示光标并不影响模块其他显示功能。显示5*8点阵字体时,光标在第八行显示;显示5*10点阵字符时,光标在第11行显示。 B:闪烁显示控制标志。B=1,光标所在位置会交替显示全黑点阵和显示字符,产生闪烁效果;B=0,光标不闪烁。 功能设置指令 Function set 功能设置指令用于设置接口数据位数,显示行数以及字形。指令码见表3-5。 表3-5 功能设置指令码 RS R/W DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 0 0 0 0 1 DL N F * * DL:数据接口宽度标志。DL=1,8位数据总线DB7~DB0;DL=0,4位数据总线DB7~DB4,DB3~DB0不使用,此方式传送数据需分两次进行。 N:显示行数标志。N=0,显示一行;N=1,显示两行。 F:显示字符点阵字体标志。F=0,显示5*7点阵字符;F=1,显示5*10点阵字符。 1602模块内部设有上电自动复位电路,当外加电源电压超过+4.5V时,自动对模块进行初始化操作,将模块设置为默认的显示工作状态。初始化大约持续10ms左右。初始化进行的指令操作为: 清显示 功能显示 DL=1:8位数据接口。 N=0:显示一行。 F=0:显示5*8点阵字符字体。 显示开/关控制 D=0:关显示。 C=0:不显示光标。 B=0:光标不闪烁。 输入模式设置 I/D=1:AC自动增一。 S=0:显示不移位。 但是需要特别注意的是,倘若供电电源达不到要求,模块内部复位电路无法正常工作,上电复位初始化就会失败。因此,最好在系统初始化时通过指令设置对模块进行手动初始化。 3.2.2 LCD1602电路 如图3-5,AT89S52的P0口接1602的8位数据线,通过输出数据控制1602显示不同的提示字符。1602本身内置各种字符,还可以自定义显示字符。本设计中根据不同场合1602会显示各种提示字符,显示内容对应含义见表3-6。 P3.0~P3.2接1602控制端,其中P3.0接使能端E,写操作时,使能端下降沿有效。P3.1接读写控制端R/W,R/W=0,读操作;R/W=1,写操作。P3.2接寄存器选择端RS,RS=0,写操作时指向指令寄存器,读操作时指向地址寄存器;RS=1,无论读操作还是写操作都指向数据寄存器。 LCD1602的VSS为电源地,需接地;VDD为电源电压;V0为LCD驱动电压,接电位器,通过调节电位器控制显示的亮度,使LCD显示清晰而无黑影。背光电源线LCD正负两端分别接电源和地即可。 3.3 发声电路 发声部分的电路如图3-6,就是用P2.1口控制一个有源蜂鸣器发声,作为提示音或报警音。程序设定为每当识别到有一位按键被按下时,蜂鸣器发声0.1S;开锁时停顿2S发声2S,发声3次;密码错误时每次停顿0.5S发声1S,错误5次以内时错N次发N声,错误5次及以上发声10次。 蜂鸣器有两个引脚,其中长脚为正极,短脚为负极。其发声原理是电流通过电磁线圈,使电磁线圈产生磁场来驱动振动膜发声的,因此需要一定的电流才能驱动它。由于单片机I/O引脚输出的电流较小,基本上驱动不了蜂鸣器,因此需要增加一个电流放大的电路,一般使用三极管来放大电流就可以了。本设计中使用三极管9012,P2.1口高电平时三极管截至,蜂鸣器不发声;P2.1口低电平时,三极管导通,这样蜂鸣器的电流形成回路,发出声音。因此,我们可以通过程序控制P2.1脚的电平来使蜂鸣器发出声音和关闭。 3.4 开锁控制电路 开锁控制电路如图3-7,电路的功能就是在输入正确的密码后开锁。系统使用单片机P2.0引脚发出信号,经三极管放大之后,由继电器驱动电磁阀将锁打开。设计中用一个发光二极管模拟表现锁的开关,只有锁打开之后,继电器吸合至常开触电,发光二极管才会亮起;实际应用中用继电器控制开锁电路的开关。 在现代自动控制设备中,都存在电子电路(弱电)与电气电路(强电)的相互连接问题,一方面要使电子电路的控制信号能够控制电气电路的执行元件(如电动机、电磁铁、电灯等),另一方面又要为电子线路的电气电路提供良好的电隔离,以保护电子电路和工作人员的人身的安全。继电器便能完成这一桥梁作用。继电器实际上是用较小的电流去控制较大电流的一种“自动开关”,在电路中起着自动调节、安全保护、转换电路等作用。在大多数情况下,继电器就是一个电磁铁,这个电磁铁的衔铁可以闭合或断开一个、数个触点。当电磁铁的绕组中有电流通过时,衔铁被电磁铁吸引,因而就改变了触点的状态。 继电器也是感性器件,所以不能用单片机的I/O口直接控制,而且必须在三极管等控制器件上加反相保护电路。本设计中单片机通过P2.0引脚连接一只作为电子开关的PNP型三极管9012来驱动继电器,继电器的开、关完全由三极管的基极电平进行控制。当P2.0为高电平时,PNP型三极管截止,继电器不工作;反之P2.0为低电平时,三极管导通,继电器得电吸合。 设计中使用的继电器型号是松川833H,线圈工作电压直流5V,有5个引脚,如图3-8。其中1、3引脚是线圈两端,一端接三极管,另一端接地,不分正负。4是常闭触点,不工作时导通。5是常开触点,继电器吸合后才导通,接发光二极管正极。2是继电器两个触点的公共极点,接个小电阻后连高电平。 3.5 密码存储电路 3.5.1 AT24C02简介 AT24C02是美国Atmel公司的低功耗CMOS型E2PROM,内含256*8位存储空间,具有工作电压宽(2.5V~5.5V),擦写次数多(大于10000次),写入速度快(小于10ms),抗干扰能力强,数据不易丢失,体积小等特点。并且它是采用I2C总线式进行数据读写的串行操作,只占用很少的资源和I/O线。AT24C02有一个16字节页写缓冲器,该器件通过I2C总线接口进行操作,还有一个专门的写保护功能。 AT24C02的引脚如图3-9,各引脚功能如下: SCL:串行时钟输入管脚,用于产生器件所有数据发送或接收的时钟。 SDA:双向串行数据/地址管脚,用于器件所有数据的发送或接收。 A0、A1、A2:器件地址输入端。这些输入脚用于多个器件级联时设置器件地址,当这些脚悬空时默认值为0。使用AT24C02最大可级联8个器件,如果只有一个24C02被总线寻址,这三个地址输入脚A0、A1、A2可悬空或连接到VSS。 WP:写保护。如果WP管脚连接到Vcc,所有的内容都被写保护,只能读。当WP管脚连接到Vss或悬空,允许器件进行正常的读/写操作。 VSS:电源地(GND)。 VCC:电源电压(5V)。 AT24C02支持I2C总线数据传送,I2C总线协议规定:任何将数据传送到总线的器件作为发送器,任何从总线接收数据的器件为接收器。数据传送是由产生串行时钟和所有起始停止信号的主器件控制的,主器件和从器件都可以作为发送器或接收器,但由主器件控制传送数据发送或接收的模式。I2C总线协议定义如下: 只有在总线空闲时才允许启动数据传送。 在数据传送过程中,当时钟线为高电平时,数据线必须保持稳定状态,不允许有跳变,时钟线为高电平时,数据线的任何电平变化将被看作总线的起始或停止信号。 如图3-10所示,时钟线保持高电平期间,数据线电平从高到低的跳变作为I2C总线的起始信号。时钟线保持高电平期间,数据线电平从低到高的跳变作为I2C总线的停止信号。 主器件通过发送一个起始信号启动发送过程,然后发送它所要寻址的从器件的地址。8位从器件地址的高4位固定为1010(见表3-7),接下来的3位A2、A1、A0为器件的地址位,用来定义哪个器件以及器件的哪个部分被主器件访问。从器件8位地址的最低位作为读写控制位。1表示对从器件进行读操作,0表示对从器件进行写操作。 在主器件发送起始信号和从器件地址字节后,AT24C02监视总线并当其地址与发送的从地址相符时响应一个应答信号。通过SDA线AT24C02再根据读写控制位R/W的状态进行读或写操作。 表3-7 AT24C02控制字 1 0 1 0 A2 A1 A0 R/W I2C总线数据传送时,每成功地传送一个字节数据后,接收器都必须产生一个应答信号(见图3-11)。应答的器件在第9个时钟周期时将SDA线拉低,表示其已收到一个8位数据。AT24C02在接收到起始信号和从器件地址之后响应一个应答信号,如果器件已选择了写操作,则在每接收一个8位字节之后响应一个应答信号。 当AT24C02工作于读模式时,在发送一个8位数据后释放SDA线并监视一个应答信号。一旦接收到应答信号,AT24C02继续发送数据,如主器件没有发送应答信号,器件停止传送数据且等待一个停止信号。 AT24C02的写模式有字节写和页写两种。本设计中选择字节写模式,其时序见图3-12。该模式下,主器件发送起始命令和从器件地址信息(R/W位置零)给从器件。在从器件产生应答信号后,主器件发送AT24C02的字节地址,主器件在收到从器件的另一个应答信号后,再发送数据到被寻址的存储单元。AT24C02再次应答,并在主器件产生停止信号后开始内部数据的擦写。在内部擦写过程中AT24C02不再应答主器件的任何请求。 对AT24C02读操作的初始化方式和写操作时一样,仅把R/W位置为1。有三种不同的读操作方式:立即地址读、选择读和连续读。设计中需要一次性读出16字节的密码,故用连续读方式。 连续读操作可通过立即读或选择性读操作启动,在AT24C02发送完一个8位字节数据后,主器件产生一个应答信号来响应,告知AT24C02主器件要求更多的数据。对应每个主机产生的应答信号,AT24C02将发送一个8位数据字节;当主器件不发送应答信号而发送停止位时结束此操作。连续读操作的时序可见图3-13。 3.5.2 AT24C02电路 如图3-14所示,该部分电路的作用就是使用AT24C02保存密码,使密码在单片机掉电之后仍能保存。AT24C02只需要串行时钟SCL引脚接P3.5,串行数据/地址SDA引脚接P3.6,即可完成数据和指令的传送,比起并行传输节省I/O口资源。SCL和SDA各需接一个5.1K的上拉电阻。写保护WP接地,使AT24C02可进行正常读写。 系统初始化时,从AT24C02中读出密码信息存储到单片机中,用户修改密码后再将新密码写入AT24C02。这样即便单片机掉电,重启后仍能读取用户密码,从而达到掉电存储的目的。 3.6 键盘输入电路 本设计中采用的4*4矩阵键盘共有16个键位,4根行线连P1口低四位,4根列线连P1口高四位(见图3-15所示)。在按键未被按下时,每一条行线与线列线的交叉处互不相通,当某个按键被按下后,该按键所在的行线和列线连通。这样在P1口的高4位和低4位中各有一位互相连通。通过行列扫描检测出这两位,即可识别出被按下的键。具体识别方式和按键功能完全由软件自定义。 系统具体使用的键盘是一体式薄膜键盘,更轻薄更便捷,有印刷字符,无需连接上拉电阻。但键盘内部无电流通过,行扫描之前需给4根行线赋高电平,如果某行和某列相通,则高电平变低,可知该行有按键被按下。然后进行列扫描,同理可识别出按键所在列。确认行和列按键即被识别出来。 3.7 手动复位电路 为确保系统中电路稳定可靠工作,复位电路是必不可少的一部分。无论是哪种类型的单片机,用户在使用时都必须设计复位电路,以提高单片机在强磁场、电源尖峰等强干扰环境下的工作稳定性或实现从误操作中正确恢复初试状态。如果复位电路可靠性较差,将直接影响到整个单片机系统工作的稳定性,造成系统调试成功后出现死机或“程序跑飞”等现象。 单片机复位是使CPU和系统的其他功能部件都处在一个确定的初试状态,并从这个状态开始工作,无论是在单片机刚开始接上电源时,还是断电后或者发生故障后都要复位。完成复位操作共需24个状态周期,复位结束后,单片机从地址0000H开始执行程序。0000H~0002H是系统的启动单元,而0003H~002AH是程序存储器中的特殊保留单元,所以一般在启动单元中存放一条无条件转移指令,以便直接转去执行指定的应用程序。 复位电路的基本功能是:系统上电时提供复位信号,直至系统电源稳定后,撤销复位信号。为可靠起见,电源稳定后还要经一定的延时才撤销复位信号,以防止复位开关闭合过程中引起的抖动而影响复位。图3-16所示的复位电路可以基本实现上述功能,该电路在最基本的复位电路基础上增加了一个手动复位开关,当人为按下按钮时,则Vcc的高电平就会直接加到RST端。由于人的动作再快也会使按钮保持接通达数十毫秒,所以完全能够满足复位的时间要求。 3.8 晶振电路 单片机本身是一个复杂的同步时序电路,为保证同步工作方式的实现,必须提供时钟信号,以使其系统在时钟信号的控制下按时序协调工作。单片机的时钟电路由振荡电路和分频电路组成,其中振荡电路由反向器以及其并联外接的石英晶体和电容构成,用于产生振荡脉冲。而分频电路则用于把振荡脉冲分频,以得到所需要的时钟信号。 晶振是晶体振荡器的简称,它用一种能把电能和机械能相互转化的晶体在共振的状态下工作,以提供稳定,精确的单频振荡。在通常工作条件下,普通的晶振频率绝对精度可达百万分之五十,高级的精度更高。电路中的晶振即石英晶体振荡器,它与电容构成振荡回路,为片内放大器提供正反馈和振荡所需的相移条件,从而构成一个稳定的自激振荡器。 如图3-17所示,AT89S52芯片中的高增益反向放大器输入端为引脚XTAL1,输出端引脚为XTAL2。通过这两个引脚在芯片外并接石英晶体振荡器和两只电容(一般取30pF)。这两个电容叫晶振的负载电容,它是根据晶振厂家提供的晶振要求负载电容选值的;换句话说,晶振的频率就是在它提供的负载电容下测得的,能最大限度的保证频率值的误差,也能保证温漂等误差。 4 软件设计 系统的软件设计采用汇编语言编码。设计方法是先用文本编辑器编写源码,然后用软件Keil C51编译,如果没有错误,可连接生成.HEX格式的文件(需事先在Keil C51中设置)。如果有错误则无法连接,但可在生成的.OBJ文件中找到代码错误的地方,便于修改。当然也可以直接在Keil中编码。 生成的HEX文件是文本行的ASCII文本文件,在HEX文件中,每一行是一个HEX记录,由十六进制数组成的机器码或者数据常量。HEX文件经常被用于将程序或数据传输存储到ROM、EPROM,大多数编程器和模拟器使用HEX文件。 在Keil中生成的HEX文件需要烧写到单片机ROM中,系统上电运行后才能看出程序运行的实际效果。烧写需要的设备是烧写器和配套软件Superpro280,将单片机引脚放入烧写器并卡紧,打开烧写器,打开软件,选定单片机的型号,AT89S52。烧写之前需擦除ROM内原有的内容,然后载入上面生成的.HEX文件,选择文件格式为Intel,然后写入。完成后校验,无误后即可关掉烧写器,取下单片机。 4.1 系统主程序 系统的主程序如图4-1所示。由于用户在使用系统的过程中,可能在任何时刻按下任何按键,而程序都必须对此作出正确响应。所以主程序的主要思路是是根据按键的不同进行不同的程序处理,下面具体介绍主程序的流程。 4.1.1 初始化及按键识别 如图4-2,系统的初始化包括堆栈起始地址的设定,两个定时/计数器的设定,液晶显示模式的设定,密码缓冲区的初始化,一些自定义数据空间的初始化,蜂鸣器初始化发声等操作。 如果AT24C02里没有存储密码,或者读取AT24C02失败,则载入系统初始化密码;如果AT24C02里有掉电存储的密码,则会读出该密码。 系统初始化并读取密码完成后,液晶显示"Password:",提示用户可以输入密码。此时程序即不断测试按键,检查是否有按键被按下。如果有,则进行按键识别;行列扫描法识别出的键位与对应BUFF的值如表4-1所示。 如果没有按键按下,或者按下的按键没有被识别,BUFF赋值0FFH,并跳转至按键测试。实际程序运行时,绝大部分时间都在测试按键,等待用户输入。 4.1.2 按键重定位 之所以要进行按键重定位,是因为按键识别子程序的功能只限于确认某个按键被按下,不包括确认按键的意义。根据表4-1可知,识别出的按键排列不符合用户使用习惯,也不利于程序的后续处理,需要重新定位。对BUFF重新赋值,新的键位值见表4-2,按键左3列仿照手机的9宫格按键,便于用户输入密码。剩下的6个按键为功能按键,各键位对应的功能设定如表4-3。 根据不同的按键,程序跳转至不同的程序段,进行对应按键处理,具体流程可见图4-3。 程序开始时,先驱动蜂鸣器发声0.1秒,提示用户程序已经检测到刚才的按键。然后根据BUFF的初始值进行一系列的对比。 如果BUFF的值是0,1,2,4,5,6,8,9,D中的一个,则按键是属于数字键。分别将BUFF重赋值为1,2,3,4,5,6,7,8,9,0。然后程序跳转至保存密码部分,将数字密码保存至密码缓冲区。 除了两个未定义功能键(BUFF=0BH或0FH)程序不作任何处理,删除键(BUFF=0EH)程序直接清空密码缓冲区,然后返回至按键测试之外,其他3个功能按键也有各自的处理程序段。确认键处理当确认键按下后的程序流程,开锁键处理当开锁键按下后的准备开锁流程,改密处理当确认键按下后的预备修改密码流程,稍后将分别详细介绍。 4.1.3 保存密码 如图4-4,该程序段的功能是将密码信息保存至对应的缓冲区。程序设置了一个16字节的密码缓冲区(PS1~PS16)和一个16字节缓冲区存储正确的密码(AT1~AT16)。为便于比较,第一次输入的密码保存至PS1,第二次输入的密码保存至PS2,依此类推。后面没有输入的位填充默认值0FFH。 为保密起见,输入的密码不能在液晶显示器上显示出来,而以“*”号代替。每输入一位密码,增加一位星号,便于用户直观察觉已经输入的密码位数。 另外,密码超长也在此程序段处理。因为密码超长并不涉及其他功能键,在保存密码之前可判断当前密码的长度。如果超过缓冲区16位长度,即认为密码超长,无法继续保存密码。此时清空密码缓冲区所有密码,等待重新输入。 4.1.4 确认键处理 该程序段就是在识别到按键为确认键之后程序的执行流程,如图4-5所示。输入密码完成后会按确认键,但是输入的密码有三种情况:旧密码,新密码第一次,新密码第二次,三种情况所做的操作也不一样。 程序设置有新密码第一次标志位PS_NEW1和新密码第二次标志位PS_NEW2,默认都是0。如果PS_NEW1被置1,则表明输入的密码是新密码第一次,需将缓冲区PS1~PS16的信息转存至NEW1~NEW16,然后PS_NEW1清0,PS_NEW2置1,提示重新输入新密码第二次。如果PS_NEW2被置1,则输入的密码是新密码第二次,会进行新密码校验,调用密码校验子程序判断两次输入的新密码是否一致,然后将PS_NEW2清0。 如果两个标志位均没有被置1,则没有进行改密操作,程序进行密码校验,调用密码校验子程序判断输入密码是否正确。密码正确会有声光提示,并且密码正确标志位PSW_F置1,然后提示用户选择开锁(A)还是改密(B)。如果密码错误,系统也有声光警示,此时无法进行开锁或改密操作。 程序开始后会首先判别BUFF值是否匹配(BUFF=0F5H),如果BUFF值不匹配,说明程序异常,不是从按键重定位处跳转过来的,应重启程序。以下几个按键的处理程序段开头也有类似的BUFF值检测,不再做赘述。 如果密码长度小于等于2,则密码太短,不进行任何比较,直接清空缓冲区重新检测,可节省程序运行时间。 4.1.5 开锁键处理 该程序段是程序识别到开锁键被按下后的流程,如图4-6所示。此段并不需校验密码,这里只需检查密码正确标志位PSW_F的状态。如果PSW_F=1,则前面输入的密码正确,可以开锁。如果PSW_F=0,说明密码错误,甚至根本没有校验密码(输入密码后没有按确认键,或者直接按下开锁键),此时提示用户密码错误,无法开锁。 开锁过程就是将P2.0口置0,继电器得到低电平就会自动吸合,点亮发光二极管;可以配合液晶显示器和蜂鸣器发声,提示用户锁已被打开。整个过程可持续若干时间,然后P2.0口置1,清空密码缓冲区,标志位PSW_F清0,重新检测新的按键。 4.1.6 改密键处理 如图4-7,可以看出,改密键的处理流程跟开锁键类似,都需检查密码正确的标志位,只有PSW_F被置1才可以进行改密。不同之处在于,如果密码正确,程序会将新密码第一次的标志位PS_NEW1置位,这样在下一次按确认键时,程序可以判别出此次输入的密码是新密码第一次。 4.1.7 校验新密码 新密码的校验用于当新密码第二次的标志位PS_NEW2=1时,按下确认键后程序判定当前新密码已经输入两次,继而执行新密码校验,即判断两次输入的新密码是否一致。 如图4-8所示,校验两次输入的新密码是否一致的方法仍然是调用密码校验子程序段。然后查询密码正确标志位PSW_F,如果PSW_F=1,则表明两次输入的新密码一致,可以修改密码,即可调用AT24C02写子程序保存新密码。若PSW_F=0,则两次输入不一致,无法修改密码;程序提示密码修改失败,清空密码缓冲区,重新测试按键。 因为新密码写入存储器的过程可能发生异常,故写入后马上调用AT24C02读子程序读出密码,然后调用密码校验子程序进行对比,即可判断密码是否被正确写入。如果PSW_F=1,则密码写入无误,才提示用户修改密码成功。如果PSW_F=0,则表明读出的密码跟要用户准备修改的密码不一致,密码修改异常。此时程序可尝试调用AT24C02写子程序重新写一遍,再次读出并对比。若仍然不一致,则只能调用系统初试密码,这个密码是系统最初写入单片机ROM内部的密码,仅在AT24C02无法正常读写的时候启用。 4.2 系统相关子程序 4.2.1 按键识别子程序 按键识别子程序的功能是行列扫描矩阵键盘并识别按键送入BUFF值,如图4-9所示。尽管进入子程序的前提条件是按键检测子程序检测到有按键被按下,但扫描前仍再次调用按键检测子程序;因为人为按键的速度再快也会持续几十毫秒,远远低于程序的处理速度,所以若是用户正常按下按键,此处的按键检测子程序仍可检测到。此处调用按键检测子程序可以防止因按键抖动产生的不必要识别。 前面提到,薄膜按键没有上拉电阻,扫描行列之前需先给行列写1。程序的处理方法是在读行线之前先给P1口低4位送高电平,然后再读P1口低4位;被按下的按键所在行高电平会因为行列导通,高电平被拉低;故P1口低4位中低电平所在行就是被按下的行。同理,在读列线之前先给P1口高4位送高电平,然后再读出,低电平所在的列就是被按下的列。 确定BUFF初值的方法是行扫描时送该行第一个按键的值入BUFF,4行的首个按键键值分别为00H,04H,08H,0CH。然后在列扫描时给BUFF加上按键所在列的值,分别加00H,01H,02H,03H。即可得到BUFF初值。至于BUFF的重赋值,则在按键重定位中根据初值对应修改。 4.2.2 液晶显示子程序 液晶显示子程序在每次更新显示内容时都会被调用,其流程如图4-10所示。 每次更新显示内容前,需清显示清空LCD原先的显示内容,清屏指令的指令码为01H,即将P0口赋值01H,然后写入指令寄存器IR。 LCD1602要显示的内容是根据其控制器内置的字符码表,事先列出要显示的ASCII字符串。每次送一个字符的ASCII码入P0口,然后写入数据寄存器DR,最后将字符地址加一,LCD1602会将写入的ASCII码对应的字符依次显示出来。由于显示字符串的长度不尽相同,约定每串字符以00H结尾;程序检测到字符码为00H时,即停止写入,返回。LCD显示的内容在下次更新前会一直保持。 4.2.3 AT24C02子程序 AT24C02的子程序包括从AT24C02中读取信息和将信息写入AT24C02,首先介绍AT24C02的读程序。 如图4-11所示,单片机作为主器件,发送起始信号和要寻址的从器件的地址;因为此时即随后的发送读取地址操作都是单片机往AT24C02写入控制信息,所以R/W要置0。本设计中只用一个AT24C02,从器件地址为0,对应代码为0A0H。AT24C02接收到信号后,发送应答信号。单片机接收到应答信号后,再发送要读取信息在从器件上的地址;本设计中从0地址开始读,则送00H。再次接收到从器件的应答信号后,单片机重新发送起始信号和读模式信号,将R/W位置1,对应代码为0A1H,正式开始读取信息。本设计中需要连续读取16字节的信息,所以选择连续读方式;即是单片机每接收到一字节的信息后,存入正确密码缓冲区(AT1~AT16),然后产生一个应答信号,告知AT24C02要求更多的数据。当单片机不发送应答信号而发送停止信号时表示读取结束。 写入AT24C02的子程序流程如图4-12所示。单片机发送起始信号,接着发送从器件AT24C02所在地址(0A0H)。这里与读AT24C02子程序不同的是,从开始到结束都是单片机控制AT24C02写入信息,所以R/W置1无需更改。对应地址上的从器件AT24C02接收到地址信号后发送应答信号。主器件在接收到应答信号后,发送要写入信息欲保存在从器件上的地址,本设计中从0地址开始保存,故地址为00H。单片机再次接收到从器件的应答信号后即可开始写入信息。本设计中采用字节写模式,即AT24C02在每接收一个8位字节之后响应一个应答信号,单片机在接收到应答信号后认为该字节成功写入,便准备下一字节的数据。直到所有数据发送完毕,单片机发送停止信号,结束写操作。 5 系统调试与测试 系统的软硬件设计都完成后,还不能直接上电运行;需要对系统进行详细的调试,以消除在设计过程中出现的各种错误。单片机系统的硬件调试和软件调试是不能分开的,很多硬件错误是在软件调试中被发现和纠正的。但通常是先排除明显的硬件故障以后,再和软件结合起来调试以进一步排除故障。所以硬件的调试是基础,如果硬件调试不通过,软件设计则是无从做起。 当硬件设计从布线到焊接安装完成之后,就开始进入硬件调试阶段。首先应该确认电源电压是否正常,用电压表测量接地引脚跟电源引脚之间的电压,看是否是电源电压。接下来就是检查复位引脚电压是否正常。分别测量按下复位按钮和放开复位按钮的电压值,看是否正确。然后再检查晶振是否起振了,一般用示波器来看晶振引脚的波形,注意应该使用示波器探头的“X10”档。另一个办法是测量复位状态下的IO口电平,按住复位键不放,然后测量IO口(没接外部上拉的P0口除外)的电压,看是否是高电平,如果不是高电平,则多半是因为晶振没有起振。另外还要注意的地方是,如果使用片内ROM的话,一定要将EA引脚拉高,否则会出现程序乱跑的情况。如果系统运行不稳定的话,有时是因为电源滤波不好导致的。在单片机的电源引脚跟地引脚之间接上一个0.1uF的电容会有所改善。如果电源没有滤波电容的话,则需要再接一个更大滤波电容,例如220uF的。遇到系统不稳定时,就可以并上电容,越靠近芯片越好。 系统的键盘输入电路,蜂鸣器发声电路,AT24C02密码存储电路,继电器开锁电路,液晶显示电路,这几个部分在检查硬件无误后,需要结合软件调试。可编写单独控制某一部分的程序,运行看是否可以正确控制。如蜂鸣器发声电路,可编写程序控制单片机 P2.1口电平,上电运行看是否正常发声。一些无法直接观测出运行效果的电路,如键盘输入电路和密码存储电路,则需结合液晶显示器调试。如键盘输入电路,需加上按键显示程序显示被按下按键的BUFF值。 6 结论 本设计利用单片机AT89S52作为主控芯片,配合液晶显示器LCD1602,串行传输存储器AT24C02,4*4矩阵薄膜键盘,蜂鸣器,继电器以及其他外围电路,用单片机汇编语言编写的控制程序,成功设计出一款利用密码开锁,可以随时改密,丰富声光提示信息,具有适用价值的电子密码锁。本系统发挥出单片机应有的价值,完成了电子密码锁的基础功能。利用单片机控制矩阵键盘输入密码,液晶显示器显示英文字符,继电器开锁,蜂鸣器发声等部件都运转良好,密码锁运行的效果也可以正确呈现。 致 谢 作为大学生涯里的最后一项重要课程,本次毕业设计历时数月,收获颇丰。从前期的
/
本文档为【液晶显示电子密码锁设计】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
热门搜索

历史搜索

    清空历史搜索