自己做的基于单片机的密码锁设计(c语言设计)_第1页
自己做的基于单片机的密码锁设计(c语言设计)_第2页
自己做的基于单片机的密码锁设计(c语言设计)_第3页
自己做的基于单片机的密码锁设计(c语言设计)_第4页
自己做的基于单片机的密码锁设计(c语言设计)_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

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

文档简介

1、自己做的基于单片机的密码锁设计(c语言设计)    自己做的基于单片机的密码锁设计(c语言设计)系统说明     该系统如图所示使用了80C51单片机、普通键盘、排阻、1602液晶。该系统的功能:    该系统输入正确的密码LED灯会亮(其实就是很多操作都可以,用LED只是代表作用,主要是操作简单,效果明显。)系统可以修改密码;(系统断电后重启后必须用初始密码(初始密码是:000000)重新改密,当然修改的密码可以与掉电前的一样。)具体操作:   

2、0;  系统开机时显示请输入密码的提示,直接输入密码#键确认系统会自动提醒密码错误,数秒后系统会再次提醒重新输密码。在系统提醒输入密码的界面可以按*键修改密码,系统会提醒输入两次密码,并且会检查两次密码是否相同。同则修改成功。否则在数秒后可以重新按*键修改。在改密前(就是按了*键后系统)会提醒身份识别,请输入旧密码,系统判断旧密码正确方可更改密码。源程序#include<reg52.h>#define uchar unsigned char#define uint unsigned intsbit lcdrs=P30;sbit lcdrw=P31;sbit lcden=P

3、32;sbit h1=P10;sbit h2=P11;sbit h3=P12;sbit sa=P13;sbit sb=P14;sbit sc=P15;sbit sd=P16;sbit kd=P37;uchar code table="  PLEASE INPUT "uchar code table1="CODE:        "uchar code table2=" *WIN*"uchar code table3=" PLEASE AFFIRM

4、"uchar code table4=" *FAIL*"uchar code table5="   MODIFICATION"uchar code table6=" IDENTITY LIMITS "uchar unm,M1,M2,M3,M4,M5,M6,sex,k1,k2,k3,k4,k5,k6,flge,flge1;uchar q1,q2,q3,q4,q5,q6,w1,w2,w3,w4,w5,w6,g;void delay(int z) int x,y; for(x=z;x>

5、0;x-)  for(y=110;y>0;y-);void delay1(int z) int x,y; for(x=z;x>0;x-)  for(y=20000;y>0;y-);void writen_com(uchar com)   /1602写命令 lcdrs=0; P0=com; delay(1); lcden=1; delay(1); lcden=0;void writen_dat(uchar dat)   /1602写数据&#

6、160;lcdrs=1; P0=dat; delay(1); lcden=1; delay(1); lcden=0;void main();void cheak_mima()    /检查第二次确认密码是否与第一次相同if(q1=w1) if(q2=w2)   if(q3=w3)     if(q4=w4)       if(q5=w5)   if(q6=w6)   

7、   writen_com(0x01);    writen_com(0x0f);       writen_com(0x06);       writen_com(0x80);      for(unm=0;unm<14;unm+)            

8、60; writen_dat(table5unm);        delay(5);             writen_com(0x80+0x40+1);        for(unm=0;unm<14;unm+)           &

9、#160;       writen_dat(table2unm);    delay(5);                     M1=w1;  M2=w2;  M3=w3;  M4=w4;  M5=w5;  M6

10、=w6;  delay1(6);  main();   /*-*/   /密码确认错误返回   writen_com(0x01);   writen_com(0x80);      for(unm=0;unm<14;unm+)              writen_dat(table4unm

11、);        delay(5);         delay1(6);   main();              writen_com(0x01);   writen_com(0x80);      for(unm=0;unm<14;unm+)

12、              writen_dat(table4unm);        delay(5);         delay1(6);   main();         writen_com(0x01);   writ

13、en_com(0x80);      for(unm=0;unm<14;unm+)              writen_dat(table4unm);        delay(5);         delay1(6);   main();  &#

14、160;     writen_com(0x01);   writen_com(0x80);      for(unm=0;unm<14;unm+)              writen_dat(table4unm);        delay(5);   &#

15、160;     delay1(6);   main();        writen_com(0x01);   writen_com(0x80);      for(unm=0;unm<14;unm+)              writen_dat(table4unm); 

16、60;      delay(5);         delay1(6);   main();       writen_com(0x01);   writen_com(0x80);      for(unm=0;unm<14;unm+)        

17、      writen_dat(table4unm);        delay(5);         delay1(6);   main();/*-*/  /第二次确认密码void affirm_code() P1=0x07; if(P1!=0x07)  delay(1);  if(P1!=0x07)   

18、60;   P1=0x77;    if(h1=0)     delay(1);   if(h1=0)       while(!h1);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)       case 0:w1=1;break; 

19、   case 1:w2=1;break;    case 2:w3=1;break;    case 3:w4=1;break;    case 4:w5=1;break;    case 5:w6=1;break;      sex+;       if(h2=0)     delay(1);   if(h2=0)

20、       while(!h2);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)       case 0:w1=2;break;    case 1:w2=2;break;    case 2:w3=2;break;    case 3:w4=2;br

21、eak;    case 4:w5=2;break;    case 5:w6=2;break;      sex+;    if(h3=0)     delay(1);   if(h3=0)       while(!h3);   writen_com(0x80+0x45+sex);   writen_dat('*&#

22、39;);   switch(sex)       case 0:w1=3;break;    case 1:w2=3;break;    case 2:w3=3;break;    case 3:w4=3;break;    case 4:w5=3;break;    case 5:w6=3;break;      sex+; 

23、;  /*-*/    P1=0x6f;    if(h1=0)     delay(1);   if(h1=0)       while(!h1);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)       case 0:w

24、1=4;break;    case 1:w2=4;break;    case 2:w3=4;break;    case 3:w4=4;break;    case 4:w5=4;break;    case 5:w6=4;break;      sex+;       if(h2=0)     delay(1); 

25、;  if(h2=0)       while(!h2);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)       case 0:w1=5;break;    case 1:w2=5;break;    case 2:w3=5;break;   

26、; case 3:w4=5;break;    case 4:w5=5;break;    case 5:w6=5;break;      sex+;    if(h3=0)     delay(1);   if(h3=0)       while(!h3);   writen_com(0x80+0x45+sex);   wri

27、ten_dat('*');   switch(sex)       case 0:w1=6;break;    case 1:w2=6;break;    case 2:w3=6;break;    case 3:w4=6;break;    case 4:w5=6;break;    case 5:w6=6;break;    &

28、#160; sex+;   /*-*/    P1=0x5f;    if(h1=0)     delay(1);   if(h1=0)       while(!h1);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)     

29、;  case 0:w1=7;break;    case 1:w2=7;break;    case 2:w3=7;break;    case 3:w4=7;break;    case 4:w5=7;break;    case 5:w6=7;break;      sex+;       if(h2=0)    

30、; delay(1);   if(h2=0)       while(!h2);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)       case 0:w1=8;break;    case 1:w2=8;break;    case 2:w3=8;break;&

31、#160;   case 3:w4=8;break;    case 4:w5=8;break;    case 5:w6=8;break;      sex+;    if(h3=0)     delay(1);   if(h3=0)       while(!h3);   writen_com(0x80+0x45+sex);   writen_dat('*');   switch(sex)     

温馨提示

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

评论

0/150

提交评论