智能密码锁系统总体设计和主要芯片介绍_第1页
智能密码锁系统总体设计和主要芯片介绍_第2页
智能密码锁系统总体设计和主要芯片介绍_第3页
智能密码锁系统总体设计和主要芯片介绍_第4页
智能密码锁系统总体设计和主要芯片介绍_第5页
已阅读5页,还剩41页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上第三章 系统总体设计和主要芯片介绍3.1 系统总体设计本设计主要由单片机、矩阵键盘、液晶显示器和密码存储等部分组成。其中矩阵键盘用于输入数字密码和进行各种功能的实现。由用户通过连接单片机的矩阵键盘输入密码,后经过单片机对用户输入的密码与自己保存的密码进行对比,从而判断密码是否正确,然后控制引脚的高低电平传到开锁电路或者报警电路控制开锁还是报警,实际使用时只要将单片机的负载由继电器换成电子密码锁的电磁铁吸合线圈即可。系统整体框图如图3-1所示。显示模块键盘输入模块 AT89S52报警电路复位电路开锁电路密码存储模块 图3-1 系统结构框图各模块功能如下:1键盘输入模块:

2、分为密码输入按键与几个功能按键,用于完成密码锁输入功能。2显示模块:用于完成对系统状态显示及操作提示功能。3复位电路:完成系统的复位。4报警电路:用于完成输错密码时候的警报功能。5密码存储模块:用于完成掉电存储功能,使修改的密码断电后仍能保存。6开锁电路:应用继电器及发光二极管模拟开锁,完成开锁及开锁提示。3.2 主要芯片介绍3.2.1 AT89S52 AT89S52单片机是一个低功耗,高性能CMOS 8位单片机,片内含8K Bytes ISP(In-system programmable)的可反复擦写1000次的Flash只读程序存储器,器件采用ATMEL公司的高密度、非易失性存储技术制造,

3、兼容标准MCS-51指令系统及80C51引脚结构,芯片内集成了通用8位中央处理器和ISP Flash存储单元,功能强大的微型计算机的AT89S52可为许多嵌入式控制应用系统提供高性价比的解决方案10。AT89S52具有以下标准功能: 8k字节Flash,256字节RAM,32 位I/O 口线,看门狗定时器,2个数据指针,三个16位定时器/计数器,一个6向量2级中断结构,全双工串行口,片内晶振及时钟电路。另外,AT89S52可降至0Hz静态逻辑操作,支持2种软件可选择节电模式。空闲模式下,CPU停止工作,允许RAM、定时器/计数器、串口、中断继续工作。掉电保护方式下,RAM内容被保存,振荡器被冻

4、结,单片机一切工作停止,直到下一个中断或硬件复位为止。AT89S52的管脚分布如图3-2所示。 图3-2 AT89S52芯片管脚P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写

5、“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P3口作为AT89S52的一些特殊功能管脚备选功能,P3.0 RXD(串行输入口)P3.1 TXD(串行输出口)P3.2 /INT0(外部中断0)P3.3 /INT1(外部中断1)P3.4 T0(记时器0外部输入)P3.5 T1(记时器1外部输入)P3.6 /WR(外部数据

6、存储器写选通)P3.7 /RD(外部数据存储器读选通)AT89S52主要特性如表3-1所示。表3-1 AT89S52主要特性兼容MCS-51指令系统8k可反复擦写(>1000次)ISP Flash ROM32个双向I/O口4.5-5.5V工作电压3个16位可编程定时/计数器时钟频率0-33MHz全双工UART串行中断口线256x8bit内部RAM2个外部中断源低功耗空闲和省电模式中断唤醒省电模式3级加密位看门狗(WDT)电路软件设置空闲和省电功能灵活的ISP字节和分页编程双数据寄存器指针3.2.2 存储芯片AT24C02 是美国Atmel公司的低功耗CMOS型E²PROM,内含

7、256×8位存储空间,具有工作电压宽(2.55.5 V)、擦写次数多(大于10000次)、写入速度快(小于10 ms)、抗干扰能力强、数据不易丢失、体积小等特点。而且他是采用了I²C总线式进行数据读写的串行器件,占用很少的资源和I/O线,并且支持在线编程,进行数据实时的存取十分方便。中带有的片内地址寄存器。每写入或读出一个数据字节后,该地址寄存器自动加1,以实现对下一个存储单元的读写。所有字节均以单一操作方式读取。为降低总的写入时间,一次操作可写入多达8个字节的数据。I2C总线是一种用于IC器件之间连接的二线制总线。他通过SDA(串行数据线)及SCL(串行时钟线)两根线在连

8、到总线上的器件之间传送信息,并根据地址识别每个器件。 正是运用了I²C规程,使用主/从机双向通信,主机(通常为单片机)和从机()均可工作于接收器和发送器状态。主机产生串行时钟信号(通过SCL引脚)并发出控制字,控制总线的传送方向,并产生开始和停止的条件。无论是主机还是从机,接收到一个字节后必须发出一个确认信号ACK。的控制字由8位二进制数构成,在开始信号发出以后,主机便会发出控制字,以选择从机并控制总线传送的方向。管脚描述:SCL 为串行时钟:串行时钟输入管脚用于产生器件所有数据发送或接收的时钟这是一个输入管脚。SDL 为串行数据/地址:双向串行数据/地址管脚用于器件所有数据的发送或

9、接收SDL,是一个开漏输出管脚可与其它开漏输出或集电极开路输出进行线或。A0、A1、A2 为器件地址输入端:当使用24C02 时最大可级联8个器件,如果只有一个24C02被总线寻址,这三个地址输入脚A0、A1、A2可悬空或连接到Vss。WP为写保护:如果WP 管脚连接到Vcc 所有的内容都被写保护只能读当WP, 管脚连接到Vss 或悬空,允许器件进行正常的读/写操作12。管脚图如图3-3所示。 图3-3 AT24C02引脚图3.2.2 LCD1602显示器 现在的字符型液晶模块已经是单片机应用设计中最常用的信息显示器件了。1602型LCD显示模块具有体积小,功耗低,显示内容丰富等特点。1602

10、型LCD可以显示2行16个字符,有8位数据总线D0D7和RS,R/W,EN三个控制端口,工作电压为5V,并且具有字符对比度调节和背光功能。接口信号说明:1602型LCD的接口信号说明如表3-2所示。表3-2 1602型LCD的接口信号说明第1脚VSS 电源地第9脚D2双向数据线第2脚VDD +5V电源第10脚D3双向数据线第3脚VEE 液晶显示偏压信号第11脚D4双向数据线第4脚RS 数据/命令选择端第12脚D5双向数据线第5脚R/ W 读/写 选择端第13脚D6双向数据线第6脚E 使能端第14脚D7双向数据线第7脚D0双向数据线第15脚BLA 背光源正极第8脚D1 双向数据线第16脚BLK

11、背光源负极主要技术参数:1602型LCD的主要技术参数如表3-3所示。 表3-3 1602型LCD的主要技术参数显示容量16×2个字符芯片工作电压4.55.5V工作电流2.0mA(5.0V)模块最佳工作电压5.0V字符尺寸2.95×4.35(WXH)mm基本操作程序:读状态:令RS=L,RW=L, E=H 输出:D0D7=状态字读数据:令RS=H,RW=H, E=H 输出:无写指令:令RS=L,RW=L,D0D7=指令码,E=高脉冲 输出:D0D7=数据写数据:令RS=H,RW=L, D0D7=数据, E=高脉冲 输出:无 第四章 硬件设计本系统外围电路包括键盘输入部分、密

12、码存储部分、复位部分、显示部分、报警部分、开锁部分组成,根据实际情况键盘输入部分选择4×4矩阵键盘,显示部分选择字符型液晶显示LCD1602,密码存储部分选用AT24C02芯片来完成。其原理图如图4-1所示。图4-1 电路原理图4.1 键盘输入模块由于本设计所用到的按键数量较多而不适合用独立按键式键盘。采用的是矩阵式按键键盘,它由行和列组成,也称行列式键盘,按键位于行列的交叉点上,密码锁的密码由键盘输入完成,与独立式按键键盘相比,要节省很多I/O口。本设计中使用的这个4×4键盘不但能完成密码的输入还能作特别功能键使用。键盘的每个按键功能在程序设计中设置。它与单片机的连接如图

13、4-2所示。图4-2 键盘输入模块4.2 密码存储模块图4-3所示AT24C02的1、2、3脚是三条地址线,用于确定芯片的硬件地址。在AT89S51试验开发板上它们都接地,第5脚和第8脚分别为正、负电源。第8脚SDL为串行数据输入/输出,数据通过这条双向I²C总线串行传送,在AT89S52试验开发板上和单片机的P3.6连接。第6脚SCL为串行时钟输入线,在AT89S52试验开发板上和单片机的P3.7连接。SDL和SCL都需要和正电源间各接一个5.1K的电阻上拉。第6脚接P3.5。AT24C02中带有片内地址寄存器。每写入或读出一个数据字节后,该地址寄存器自动加1,以实现对下一个存储单

14、元的读写。所有字节均以单一操作方式读取。为降低总的写入时间,一次操作可写入多达8个字节的数据。图4-3 密码存储电路4.3 复位部分单片机复位是使CPU和系统中的其他功能部件都处在一个确定的初始状态,并从这个状态开始工作。该电路在最简单的复位电路下增加了手动复位按键,在接通电源瞬间,电容C1上的电压很小,复位下拉电阻上的电压接近电源电压,即RST为高电平,在电容充电的过程中RST端电压逐渐下降,当RST端的电压小于某一数值后,CPU脱离复位状态,由于电容C1足够大,可以保证RST高电平有效时间大于24个振荡周期,CPU能够可靠复位。增加手动复位按键是为了避免死机时无法可靠复位。当复位按键按下后

15、电容C1通过R5放电。当电容C1放电结束后,RST端的电位由R5与R6分压比决定。由于R5<<R6 因此RST为高电平,CPU处于复位状态,松手后,电容C1充电,RST端电位下降,CPU脱离复位状态。R5的作用在于限制按键按下瞬间电容C1的放电电流,避免产生火花,以保护按键触电。其电路如图4-4所示。图4-4 复位电路4.4 晶振部分AT89S52引脚XTAL1和XTAL2与晶体振荡器及电容C2、C3按图4-5所示方式连接。晶振、电容C2C3及片内与非门(作为反馈、放大元件)构成了电容三点式振荡器,振荡信号频率与晶振频率及电容C2、C3的容量有关,但主要由晶振频率决定,范围在033

16、MHz之间,电容C2、C3取值范围在530pF之间。根据实际情况,本设计中采用12MHZ作为系统的外部晶振。电容取值为10pF。其电路图如图4-5所示。 图4-5 晶振电路4.5 显示模块显示部分由液晶显示器LCD1602取代普通的数码管完成。开锁时,按下键盘上的开锁按键后,利用键盘上的数字键09输入密码,每按下一个数字键后在显示器上显示一个*,输入多少位就显示多少个*。当密码输入完成时,按下确认键,如果输入的密码正确的话, LCD显示“DOOR OPEN”,单片机其中P2.0引脚会输出低电平,使三极管T2导通,电磁铁吸合,继电器开关跳转,电子密码锁被打开,如果密码不正确,LCD显示屏会显示“

17、CODE WRONG”,P2.0输出的是高电平,电子密码锁不能打开。通过LCD显示屏,可以清楚地判断出密码锁所处的状态。电路图如图4-6所示。 图4-6 显示电路4.6 报警部分 报警部分由陶瓷压电发声装置及外围电路组成,加电后不发声,当有键按下时,“叮”声,每按一下,发声一次,密码正确时,不发声直接开锁,当密码输入错误时,单片机的P2.1引脚为低电平,三极管T3导通蜂鸣器发出噪声报警。如图4-7所示。图4-7 报警电路4.7 开锁部分开锁控制电路的功能是当输入正确的密码后将锁打开。系统使用单片机其中一引脚线发出信号,经三极管放大后,由继电器驱动电磁阀动作将锁打开。用户通过键盘任意设置密码,并

18、储存在E2PROM中作为锁码指令。只有用户操作键盘时,单片机的电源端才能得到3V电源,否则,单片机处于节电工作方式。开锁步骤如下:首先按下键盘上的开锁按键,然后利用键盘上的数字键09输入密码,最后按下确认键。当用户输入密码后,单片机自动识别密码,如果密码不符,则报警。只有当密码正确,单片机才能使继电器处于开锁状态。具体电路如图4-8所示。图4-8 开锁电路第五章 系统软件设计5.1 系统程序流程图5.1.1 主程序流程图主程序设计流程图如图5-1所示。 开始初始化密码正确 输入旧密码出错报警开锁原密码相同设新密码 返回开锁修改 NYV NY 图5-1主程序流程图5.1.2 键功能程序流程图键功

19、能程序流程图如图5-2所示。 键功能程序键值=09?键值=开锁?键值=确认?键值=设置? 返回密码输入程序确认程序设置程序开锁程序YNYNYN YN 图5-2 键功能流程图5.1.3 开锁程序流程图开锁程序流程图如图5-3所示。LCD初始化按开锁键输入密码确认程序开锁N输入密码正确?报警程序开锁成功返回Y 图5-3 开锁流程图5.2 子程序举例5.2.1 开锁子程序 if(sk15=1) />>>>>>>>>>>>>>>>>>>>>>>>>>

20、;>>> 提示输入密码GotoXY(0,0);count=0;Print("Code: ");count1=1;count2=1;count6=1;sk15=0; sk14=0;m=0;cp0=1;if(count!=0)&&(count1=1) />>>>>>>>>>>>>>>>>>>LCD上显示"*" if(count=1)GotoXY(0,0); Print("Code:* ");i

21、f(count=2)GotoXY(0,0); Print("Code:* "); if(count=3)GotoXY(0,0); Print("Code:* "); if(count=4)GotoXY(0,0); Print("Code:* ");if(count=5)GotoXY(0,0); Print("Code:* "); if(count=6)GotoXY(0,0); Print("Code:* "); if(count>6)GotoXY(0,0); Print("Cod

22、e:* ");count1=0;if(sk14=1)&(count6=1) />>>>>>>>>>>>>>>>>>"按下确认,刚进入较验/>>>>>>>>>>>>>>>>>>密码正确if(password0=cq0)&(password1=cq1)&(password2=cq2)&(password3=cq3)&(pass

23、word4=cq4)&(password5=cq5)&(count=6 )GotoXY(0,0); Print("Door Open! ");sk14=0; count=0;count2=0; m=0; count4=1;DelayMs(1000); count6=1; P2_0=0;DelayMs(500);P2_0=1;/>>>>>>>>>>>>>>>>>>>>>>>>>>>>>&g

24、t;>>>>>密码错误 LCD_Initial(); cp0=0;else GotoXY(0,0); Print("Code wrong! " );DelayMs(1000);sk14=0; count=0; count2=0; count6=0; m=0; p3_6=0;DelayMs(100);DelayMs(3000);p3_6=1; LCD_Initial(); cp0=0; /密码错误5.2.2 按键扫描子程序 void Check_Key(void)unsigned int row,col,tmp1,tmp2;tmp1 = 0x10

25、; /tmp1用来设置P1口的输出,取反后使P1.4P1.7中有一个为0for(row=0;row<4;row+) / 行检测P1 = 0x0f; / 先将p1.0P1.3置高P1 =tmp1; / 使P1.4p1.7中有一个为0tmp1*=2; / tmp1左移一位if (P1 & 0x0f) < 0x0f) / 检测P1.0P1.3中是否有一位为0,只要有,则说明此行有键按下,进入列检测DelayMs(30);if (P1 & 0x0f) < 0x0f) / 检测P1.0P1.3中是否有一位为0,只要有,则说明此行有键按下,进入列检测 tmp2 = 0x0

26、1; / tmp2用于检测出哪一列为0for(col =0;col<4;col+) / 列检测 if(P1&tmp2)=0x00) / 该列如果为低电平则可以判定为该列 key_val = row*4 +col; / 获取键值,识别按键while(P1&tmp2)=0x00);return; / 退出循环tmp2*=2; / tmp2左移一位while(P1&tmp2)=0x00); 5.2.3 密修改码子程序if(sk11=1)&(cp0=0) /提示输入旧密码GotoXY(0,0); Print("Old Code: ");pass

27、=1;count1=0;count=0;count7=1;count2=1;count6=0;sk11=0;f(count!=0)&(pass=1)&(cp0=0) /输出显示"*"pass0=0; if(count=1)GotoXY(0,0); Print("Old Code:* ");if(count=2)GotoXY(0,0); Print("Old Code:* "); if(count=3)GotoXY(0,0); Print("Old Code:* "); if(count=4)Goto

28、XY(0,0); Print("Old Code:* ");if(count=5)GotoXY(0,0); Print("Old Code:* "); if(count=6)GotoXY(0,0); Print("Old Code:* "); m=0;if(count!=0)&(pass0=1)&(cp0=0)pass=0; if(count=1)GotoXY(0,0); Print("New Code:* ");if(count=2)GotoXY(0,0); Print("New Cod

29、e:* "); if(count=3)GotoXY(0,0); Print("New Code:* "); if(count=4)GotoXY(0,0); Print("New Code:* ");if(count=5)GotoXY(0,0); Print("New Code:* "); if(count=6)GotoXY(0,0); Print("New Code:* "); m=0;if(sk14=1)&(count7=1) />>>>>>>>&

30、gt;>>按键盘认键,较验旧密码/旧密码输入正确if(password0=cq0)&(password1=cq1)&(password2=cq2)&(password3=cq3)&(password4=cq4)&(password5=cq5)&(pass=1)&(count>=6)GotoXY(0,0); Print("New Code: ");pass0=1;pass=0;sk14=0;count=0;count7=0;n=0;m=0;elseGotoXY(0,0); Print("Old

31、 Code Wrong! "); />>>>>>>>>>>>旧密码输入错误sk14=0;count2=0;count7=0;pass=0;m=0;if(pa!=10)&(pass0=1)if(n<7)con=pa;n+;pa=10;if(sk14=1)if(n>=7)&(count=6)GotoXY(0,0); Print("Set Over! "); />>>>>>>>>>>>>>

32、旧密码输入正确,存新密码cq0=co1;cq1=co2;cq2=co3;cq3=co4;cq4=co5;cq5=co6;n=0;pass0=0;pass1=1;sk14=0;count=0;count2=0;m=0;count7=0;elseGotoXY(0,0); Print("Set Wrong! "); />>>>>>>>>>>密码过多或过少,报错sk14=0;count2=0;count=0;count7=0;m=0; 附录一 总电路原理图附录二 实物图附录三 元器件清单序号元件名称型号与规格单位数量

33、1电阻1K个6470个15.1K个210K个12三极管8550个23发光二极管个14晶振12M个15电容10uf个120pf个26按钮开关个177芯片AT24C02块1AT89S52块18蜂鸣器5V个19继电器5V个110液晶显示器1602块111实验板块1附录四 系统总体程序#include <REG51.H>#include <ABSACC.h>#include <stdio.h>#include <intrins.h>#define uchar unsigned char;#define uint unsigned int;/Port De

34、finitions*sbit p3_6=P21;sbit LcdRs= P32;sbit LcdRw= P31;sbit LcdEn = P30;sfr DBPort = 0x80;/P0=0x80,P1=0x90,P2=0xA0,P3=0xB0.数据端口sbit P2_0=P20;uint key_val=16;uint m=0,count=0,count2=0;uint pass=0,pass0=0,pass1=0,pass2=0,o=0,n=0;uint co6=0,0,0,0,0,0;uint cp1=0;uint cq7=0,0,0,0,0,0,0; uchar sk16=0,0,0

35、,0,0,0,0,0,0,0,0,0,0,0,pa=10; uchar password6;void DelayMs(unsigned int n) unsigned int i,j; for(i=0;i<n;i+) for(j=0;j<120;j+); /*按键扫描*/ void Check_Key(void)unsigned int row,col,tmp1,tmp2;tmp1 = 0x10; /tmp1用来设置P1口的输出,取反后使P1.4P1.7中有一个为0for(row=0;row<4;row+) / 行检测P1 = 0x0f; / 先将p1.0P1.3置高P1 =

36、tmp1; / 使P1.4p1.7中有一个为0tmp1*=2; / tmp1左移一位if (P1 & 0x0f) < 0x0f) / 检测P1.0P1.3中是否有一位为0,只要有,则说明此行有键按下,进入列检测DelayMs(30);if (P1 & 0x0f) < 0x0f) / 检测P1.0P1.3中是否有一位为0,只要有,则说明行有键按下,进入列检测 tmp2 = 0x01; / tmp2用于检测出哪一列为0for(col =0;col<4;col+) / 列检测 if(P1&tmp2)=0x00) / 该列如果为低电平则可以判定为该列 key_

37、val = row*4 +col; / 获取键值,识别按键while(P1&tmp2)=0x00);return; / 退出循环tmp2*=2; / tmp2左移一位while(P1&tmp2)=0x00); void rec_key(void)/按键判断if(key_val!=16) /当按键4被按下时,标志位presskey4置位,从而去执行判断按键1,2程序 if(m>6)m=0;if(count2=1)if(key_val=0) / delay(1000) ;sk0=1 ;count+;pa=0;passwordm=0;m+;DelayMs(10);p3_6=0;

38、DelayMs(100);p3_6=1;key_val=16;if(key_val=1)/delay(1000) ;sk1=1 ;count+;pa=1;passwordm=1;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val=2)/delay(1000) ;sk2=1 ;count+;pa=2;passwordm=2;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val=3)/delay(1000) ;sk3=1 ;count+;pa=3

39、;passwordm=3;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val=4)/delay(1000) ;sk4=1 ;count+;pa=4;passwordm=4;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16;if(key_val=5)/delay(1000) ;sk5=1 ;count+;pa=5;passwordm=5;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val

40、=6)/delay(1000) ;sk6=1 ;count+;pa=6;passwordm=6;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val=7)/delay(1000) ;sk7=1 ;count+;pa=7;passwordm=7;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val=8)/delay(1000) ;sk8=1 ;count+;pa=8;passwordm=8;m+;DelayMs(10);p3_6=0;DelayM

41、s(100);p3_6=1;key_val=16; if(key_val=9)/delay(1000) ;sk9=1 ;count+;pa=9;passwordm=9;m+;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16;if(m>9)m=0;if(key_val=10)/delay(1000) ;sk10=1 ;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16; if(key_val=11)/delay(1000) ;sk11=1 ;DelayMs(10);p3_6=0;DelayMs

42、(100);p3_6=1;key_val=16;if(key_val=12)/delay(1000) ;sk12=1 ;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16;if(key_val=13)/delay(1000) ;sk13=1 ;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16;if(key_val=14)/delay(1000) ;sk14=1 ;DelayMs(10);p3_6=0;DelayMs(200);p3_6=1;key_val=16;if(key_val=15)/del

43、ay(1000) ;sk15=1;DelayMs(10);p3_6=0;DelayMs(100);p3_6=1;key_val=16;if(m>10)m=0; /内部等待函数*unsigned char LCD_Wait(void)LcdEn=0;LcdRs=0;LcdRw=1;_nop_();LcdEn=1;_nop_();LcdEn=0;_nop_();while(DBPort&0x80)/在用Proteus仿真时,注意用屏蔽此语句,在调用GotoXY()时,会进入死循环,/可能在写该控制字时,该模块没有返回写入完备命令,即DBPort&0x80=0x80/实际硬件时

44、打开此语句return DBPort;/向LCD写入命令或数据*#define LCD_COMMAND0 / Command#define LCD_DATA1 / Data#define LCD_CLEAR_SCREEN0x01 / 清屏#define LCD_HOMING 0x02 / 光标返回原点void LCD_Write(bit style, unsigned char input) LCD_Wait();LcdEn=0;LcdRs=style;LcdRw=0;_nop_();DBPort=input;_nop_();/注意顺序LcdEn=1;_nop_();/注意顺序LcdEn=0;

45、_nop_();/设置显示模式*#define LCD_SHOW0x04 /显示开#define LCD_HIDE0x00 /显示关 #define LCD_CURSOR0x02 /显示光标#define LCD_NO_CURSOR0x00 /无光标 #define LCD_FLASH0x01 /光标闪动#define LCD_NO_FLASH0x00 /光标不闪动void LCD_SetDisplay(unsigned char DisplayMode)LCD_Write(LCD_COMMAND, 0x08|DisplayMode);/设置输入模式*#define LCD_AC_UP0x02

46、#define LCD_AC_DOWN0x00 / default#define LCD_MOVE0x01 / 画面可平移#define LCD_NO_MOVE0x00 /defaultvoid LCD_SetInput(unsigned char InputMode)LCD_Write(LCD_COMMAND, 0x04|InputMode);/移动光标或屏幕*/*#define LCD_CURSOR0x02 #define LCD_SCREEN0x08#define LCD_LEFT0x00#define LCD_RIGHT0x04void LCD_Move(unsigned char object, unsigned char direction) if(object=LCD_CURSOR)LCD_Write(LCD_COMMAND,0x10|direction);if(object=LCD_SCREEN)LCD_Write(LCD_COMMAND,0x18|direction);*/初始化LCD*void LCD_Initial()LcdEn=0;LCD_Write(LCD_COMMAND,0x38); /8位数据端口,2行显示,5*7点阵LCD_Write(LCD_COMMAND,0x38);LCD_SetDisplay(LCD_SH

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论