数字电子技术课程设计,设计一个密码锁
电子密码锁
一、设计任务与要求
1.用电子器件设计制作一个密码锁,使之在输入正确的代码时开锁。
2.在锁的控制电路中设一个可以修改的4位代码,当输入的代码和控制电路的代码一致是锁打开。
3.用红灯亮、绿灯灭表示关锁,绿灯亮、红灯灭表示开锁
4.如5s内未将锁打开,则电路自动复位进入自锁状态,并发报警信号。
二、方案设计与论证
1、用按键输入四位十进制数字,输入密码要存储。
2、比较输入密码和原始密码。当输入正确密码时,给出开锁信号,开锁信号用一个绿色指示灯表示,绿灯亮表示密码输入正确;如果输入密码不正确,用红灯表示。
3、锁的开关用红灯和绿灯表示,一次只能亮一盏。红灯亮、绿灯灭表示关锁,绿灯亮、红灯灭表示开锁。
4、设置倒计时电路和自锁电路。如果密码在5s内未能输入正确则发出报警声,并且自锁电路。
5、设置密码设置开关,开关闭合后,允许设置密码,设置好密码后,打开此开关。
6、需要在输入密码开始时识别输入,并由此触发计时电路。
一、设计要求
用中小规模集成芯片设计并制作九位按键数字密码锁电路,具体要求如下:
1、编码按钮分别为1,2,…,9九个按键,其中5个密码键,4个伪码键。
2、用发光二极管作为输出指示灯,灯亮代表锁“开”,暗为“不开”。
3、设计开锁密码,并按此密码设计电路。密码可以是1~9位数。若按动的开锁密码正确,发光二极管变亮,表示电子锁打开。并在开锁7秒后,电路恢复初始状态。
4、该电路应具有防盗功能,密码顺序不对或密码有误时系统自动复位;若按错4个伪码键中任何一个,电路将被封锁5分钟。
二、主要参考元器件
CC4017、9013、8050、1N4148、555、BS202,蜂鸣器、电阻、电容若干。
三、扩展
1、防盗报警功能。密码顺序不对或密码有误时系统自动复位;如果开锁时间超过5分钟,则蜂鸣器发出l kHz频率信号报警。
2、设计门铃电路,按动门铃按钮,发出500Hz的频率信号或音乐信号,可使编码电路清零,同时可解除报警。
苹果8p设置微信密码锁的方法如下:
1、打开手机,在手机主界面找到设置功能,点击进入手机设置;
2、进入设置后找到通用,点击进入通用设置;
3、在通用设置中可以在下面的一个地方找到访问限制,然后开启;
4、点击启用访问限制,接下来会提示输入密码,这里设置一个密码作为访问限制的密码;
四位设定开关和四位输入开关的每一位值都相等,这等于是求二者的抑或非关系,也就是说设定值和新输入值相等就输出就输出一,反之输出零。这样,用四个双输入端抑或门做输入端然后每个抑或门输出端另接一个非门即可。
要求是四位相等就开箱,反之开警报。这就是个四位与关系,因为输入端是四抑或门加四个非门,麻烦,所以用负逻辑,改为四个抑或门接四输入端或非门。省了四个非门。具体如何推导,你自己列卡诺化简图或者写推导公式。
输出控制,执行机构用一个9013间接控制微型电磁铁。报警机构由输出端直接驱动蜂鸣器。这样或非门输出一时,继电器吸合;输出零时,蜂鸣器报警(工作电流一毫安就够)。
另外,我告诉你答案不是冲着那几分,而是第一看你忒可怜了,我要是上四年学还不会设计数字电路,我准保去找校长退学费。第二,看你还算明白人情世故,不像你那些同学,明明是求人办事却搞得像找爹妈要钱一样理所当然。
S6---S15 数字键0-9
S16---更改密码 S17---更改密码完毕后确认
S18---重试密码、重新设定 S19---关闭密码锁
初始密码:000000 密码位数:6位
注意:掉电后,所设密码会丢失,重新上点时,密码恢复为原始的000000
与P1相连的8位发光LED点亮代表锁被打开;熄灭代表锁被锁上
程序功能: 本程序结合了24C02存储器的存储功能,可以掉电保存密码。
第一次运行时,若输入000000原始密码后无反应,可以试验着将主程序中前面的
一小段被注释线屏蔽的程序前的注释线删掉,然后重新编译下载(可以将密码还原为000000)。
此后,再将这小段程序屏蔽掉,再编译下载。方可正常使用。
1、开锁:
下载程序后,直接按六次S7(即代表数字1),8位LED亮,锁被打开,输入密码时,
六位数码管依次显示小横杠。
2、更改密码:
只有当开锁(LED亮)后,该功能方可使用。
首先按下更改密码键S16,然后设置相应密码,此时六位数码管会显示设置密码对应
的数字。最后设置完六位后,按下S17确认密码更改,此后新密码即生效。
3、重试密码:
当输入密码时,密码输错后按下键S18,可重新输入六位密码。
当设置密码时,设置中途想更改密码,也可按下此键重新设置。
4、关闭密码锁:
按下S19即可将打开的密码锁关闭。
推荐初级演示步骤:输入原始密码000000---按下更改密码按键S16---按0到9设置密码---按S17
确认密码更改---按S18关闭密码锁---输入新的密码打开密码锁
*******************************************************************************/
#include<reg52.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
uchar old1,old2,old3,old4,old5,old6//原始密码000000
uchar new1,new2,new3,new4,new5,new6 //每次MCU采集到的密码输入
uchar a=16,b=16,c=16,d=16,e=16,f=16//送入数码管显示的变量
uchar wei,key,temp
bit allow,genggai,ok,wanbi,retry,close //各个状态位
sbit dula=P2^6
sbit wela=P2^7
sbit beep=P2^3
sbit sda=P2^0 //IO口定义
sbit scl=P2^1
unsigned char code table[]=
{0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,
0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00,0x40}
void nop()
{
_nop_()
_nop_()
}
/////////24C02读写驱动程序////////////////////
void delay1(unsigned int m)
{ unsigned int n
for(n=0n<mn++)
}
void init() //24c02初始化子程序
{
scl=1
nop()
sda=1
nop()
}
void start()//启动I2C总线
{
sda=1
nop()
scl=1
nop()
sda=0
nop()
scl=0
nop()
}
void stop() //停止I2C总线
{
sda=0
nop()
scl=1
nop()
sda=1
nop()
}
void writebyte(unsigned char j) //写一个字节
{
unsigned char i,temp
temp=j
for (i=0i<8i++)
{
temp=temp<<1
scl=0
nop()
sda=CY //temp左移时,移出的值放入了CY中
nop()
scl=1 //待sda线上的数据稳定后,将scl拉高
nop()
}
scl=0
nop()
sda=1
nop()
}
unsigned char readbyte() //读一个字节
{
unsigned char i,j,k=0
scl=0nop()sda=1
for (i=0i<8i++)
{
nop()scl=1nop()
if(sda==1)
j=1
else
j=0
k=(k<<1)|j
scl=0
}
nop()
return(k)
}
void clock() //I2C总线时钟
{
unsigned char i=0
scl=1
nop()
while((sda==1)&&(i<255))
i++
scl=0
nop()
}
////////从24c02的地址address中读取一个字节数据/////
unsigned char read24c02(unsigned char address)
{
unsigned char i
start()
writebyte(0xa0)
clock()
writebyte(address)
clock()
start()
writebyte(0xa1)
clock()
i=readbyte()
stop()
delay1(100)
return(i)
}
//////向24c02的address地址中写入一字节数据info/////
void write24c02(unsigned char address,unsigned char info)
{
start()
writebyte(0xa0)
clock()
writebyte(address)
clock()
writebyte(info)
clock()
stop()
delay1(5000)//这个延时一定要足够长,否则会出错。因为24c02在从sda上取得数据后,还需要一定时间的烧录过程。
}
void delay(unsigned char i)
{
uchar j,k
for(j=ij>0j--)
for(k=125k>0k--)
}
void display(uchar a,uchar b,uchar c,uchar d,uchar e,uchar f)
{
dula=0
P0=table[a]
dula=1
dula=0
wela=0
P0=0xfe
wela=1
wela=0
delay(5)
P0=table[b]
dula=1
dula=0
P0=0xfd
wela=1
wela=0
delay(5)
P0=table[c]
dula=1
dula=0
P0=0xfb
wela=1
wela=0
delay(5)
P0=table[d]
dula=1
dula=0
P0=0xf7
wela=1
wela=0
delay(5)
P0=table[e]
dula=1
dula=0
P0=0xef
wela=1
wela=0
delay(5)
P0=table[f]
dula=1
dula=0
P0=0xdf
wela=1
wela=0
delay(5)
}
void keyscan()
{
{
P3=0xfe
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xee:
key=0
wei++
break
case 0xde:
key=1
wei++
break
case 0xbe:
key=2
wei++
break
case 0x7e:
key=3
wei++
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
}
}
P3=0xfd
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xed:
key=4
wei++
break
case 0xdd:
key=5
wei++
break
case 0xbd:
key=6
wei++
break
case 0x7d:
key=7
wei++
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
}
}
P3=0xfb
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xeb:
key=8
wei++
break
case 0xdb:
key=9
wei++
break
case 0xbb:
genggai=1
wei=0
break
case 0x7b:
if(allow)
ok=1
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
}
}
P3=0xf7
temp=P3
temp=temp&0xf0
if(temp!=0xf0)
{
delay(10)
if(temp!=0xf0)
{
temp=P3
switch(temp)
{
case 0xe7:
retry=1
break
case 0xd7:
close=1
break
}
while(temp!=0xf0)
{
temp=P3
temp=temp&0xf0
beep=0
}
beep=1
}
}
}
}
void shumima() //对按键采集来的数据进行分配
{
if(!wanbi)
{
switch(wei)
{
case 1:new1=key
if(!allow) a=17
else a=key break
case 2:new2=key
if(a==17) b=17
else b=key break
case 3:new3=key
if(a==17) c=17
else c=key break
case 4:new4=key
if(a==17) d=17
else d=key break
case 5:new5=key
if(a==17) e=17
else e=key break
case 6:new6=key
if(a==17) f=17
else f=key
wanbi=1 break
}
}
}
void yanzheng() //验证密码是否正确
{
if(wanbi) //只有当六位密码均输入完毕后方进行验证
{
if((new1==old1)&(new2==old2)&(new3==old3)&(new4==old4)&(new5==old5)&(new6==old6))
allow=1 //当输入的密码正确,会得到allowe置一
}
}
void main()
{
init() //初始化24C02
// write24c02(110,0x00)
// write24c02(111,0x00)//24c02的第110到115地址单元作为密码存储区
// write24c02(112,0x00)
// write24c02(113,0x00)
// write24c02(114,0x00)
// write24c02(115,0x00)
old1=read24c02(110)
old2=read24c02(111)
old3=read24c02(112)
old4=read24c02(113)
old5=read24c02(114)
old6=read24c02(115)
while(1)
{
keyscan()
shumima()
yanzheng()
if(allow) //验证完后,若allow为1,则开锁
{
P1=0x00
if(!genggai)
wanbi=0
}
if(genggai) //当S16更改密码键被按下,genggai会被置一
{
if(allow) //若已经把锁打开,才有更改密码的权限
{
while(!wanbi) //当新的六位密码没有设定完,则一直在这里循环
{
keyscan()
shumima()
if(retry|close) //而当探测到重试键S18或者关闭密码锁键S19被按下时,则跳出
{ wanbi=1
break
}
display(a,b,c,d,e,f)
}
}
}
if(ok) //更改密码时,当所有六位新密码均被按下时,可以按下此键,结束密码更改
{ //其他时间按下此键无效
ok=0wei=0
genggai=0
old1=new1old2=new2old3=new3//此时,旧的密码将被代替
old4=new4old5=new5old6=new6
//新密码写入存储区。
write24c02(110,old1)
write24c02(111,old2)
write24c02(112,old3)
write24c02(113,old4)
write24c02(114,old5)
write24c02(115,old6)
a=16b=16c=16d=16e=16f=16
}
if(retry) //当重试按键S18被按下,retry会被置位
{
retry=0wei=0wanbi=0
a=16b=16c=16d=16e=16f=16
new1=0new2=0new3=0new4=0new5=0new6=0
}
if(close) //当关闭密码锁按键被按下,close会被置位
{
close=0genggai=0//所有变量均被清零。
wei=0 wanbi=0
allow=0
P1=0xff
a=16b=16c=16d=16e=16f=16
new1=0new2=0new3=0new4=0new5=0new6=0
}
display(a,b,c,d,e,f)//实时显示
}
}
对着代码自己做吧,,要是还做不出来,,那我就不说什么了,,