基于单片机的简易密码锁
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
基于单片机的简易密码锁
一、实验目的
1、熟悉程序的编译、下载方法和过程;
2、熟悉利用max7219驱动数码管显示;
3、熟悉A T89S51单片机的相关操作;
4、熟悉案件的基本功能;
二、实验内容
1、使用液晶显示模块LCD1602;
2、使用max7219驱动数码管显示;
3、使用简易密码锁及按键模块;
三、实验步骤
1、设计硬件电路,焊制电路板,连接相关电路;
2、观察给定程序所实现的功能;
3、按照设定的功能修改程序编译程序,下载并调试程序;
四、实验程序
#include
#include
#define uchar unsigned char
#define uint unsigned int
sbit BEEP = P3^4;//蜂鸣器
sbit ACT=P3^0;//开锁器
sbit SET=P3^3;//设置密码指示灯
sbit INPUT=P3^1;//输入密码指示灯
sbit FLAG=P3^2;//密码错误指示灯
sbit wei1=P3^5;
sbit wei2=P3^6;
bit ok_flag;
uchar passwdnum;//密码位数
uchar passwd[10];//密码
//const uchar tab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80};//数码管显示0~8
//const uchar tab[] = {0x20,0x76,0x11,0x14,0x46,0x84,0x80,0x36,0x00,0x04,~0x02,~0xc0,0x a1,~0x50,0x79,0x71}; //段码控制
//const uchar dispbit[8]={0xfe,0xfd,0xfb,0xf7,0xef,0xdF,0xbF,0x7F}; //位选控制查表的方法控制
const uchar tab[] = {0xd7,0x84,0xe3,0xe6,0xb4,0x76,0x77,0xc4,0xf7,0xf6,0xf5,0x37,0x53,0 xa7}; //0~D段码控制
uchar input;//密码输入次数
uchar chaopasswd[]={0,10,11,12,13,10,11,12,13,0,0};//超级密码
uint chaonum,time;
uint num,su_flag;
void beep();
void passwd_set();
void passwd_in();
void DELA Y(uint num);
/*********************************************************/ main()
{
P2=0xff;//送数码管显示
P0=0xff;
P1=0xff;//读取按键
input=1;
ok_flag=1;
passwdnum=1;
chaonum=1;
time=0;
ACT=1;
SET=0;
su_flag=0;
FLAG=1;
BEEP=0;
wei1=0;
wei2=1;
while(passwdnum<=8)
{
passwd_set();//等待设置密码DELAY(500); passwdnum++;
P0=0xff;
P1=0xff;
}
P0=0xff;
P1=0xff;
TMOD=0x01;
TH0=(65536-45872)/256;
TL0=(65536-45872)%256; EA=1;
ET0=1;
TR0=1;
while(time!=2)//2秒响铃{
P2=tab[time+1];
beep();
}
time=0;
ET0=0;
TR0=0;
BEEP=0;
SET=1;
passwdnum=1;
while(1)
{
while(input<=3)
{
INPUT=0;//输入指示灯亮
FLAG=1;
while(passwdnum<=8)
{
passwd_in();//等待输入密码
DELA Y(500);
P0=0xff;
P1=0xff;
passwdnum++;
}
if(chaonum==9)
{
chaonum=1;
FLAG=1;
INPUT=1;//输入指示灯灭//密码正确响铃1秒TMOD=0x01;
TH0=(65536-45872)/256; TL0=(65536-45872)%256; EA=1;
ET0=1;
TR0=1;
while(time!=1)
{
P2=tab[time+1];
beep();
}
time=0;
ET0=0;
TR0=0;
BEEP=0;
DELA Y(500);