#include<reg52.h>
#include <intrins.h>
#define uchar unsigned char
#define uint unsigned int
#define LCD_data P0
sbit SDA=P3^5
sbit SCL=P3^4//24C08控制口设置
sbit LCD_RS = P3^3 //寄存器选择输入
sbit LCD_RW = P3^6 //液晶读/写控制
sbit LCD_EN = P3^7 //液晶使能控制
sbit LCD_PSB = P3^2 //串/并方式控制
sbit FM=P2^4//蜂鸣器控制口
sbit RS=P2^5
sbit T_CLK = P2^0//实时时钟时钟线引脚 //
sbit T_IO = P2^1//实时时钟数据线引脚 //
sbit T_RST = P2^2//实时时钟复位线引脚 //
sbit ds=P2^3
sbit EN=P2^6
sbit ZZ=P2^7
sbit FZ=P3^1
sbit ACC0=ACC^0
sbit ACC7=ACC^7
uint temp1,s_temp //定义整形变量
float f_temp //定义浮点型变量
uchar time[]=" : : "
uchar day[]=" 20 / / ( ) "
uchar temp0[]=" 温度: . 度 "
uchar num,num1,flag,count,a,b
uchar unlock_i//解密标志位
uchar t[4]
uchar t1[4]
void delay_ms(uint z)//长延时
{
uint x,y
for(x=zx>0x--)
for(y=110y>0y--)
}
void delay() //短延时,大约5us
{
}
void reshi()
{
if(RS==1)
{ unlock_i=1
}
else
{
unlock_i=0
}
}
uchar code mima[]={'0','1','2','3','4','5','6','7','8','9','0','*'}
void lcd_xieping0(uchar x,uchar y,uchar date)
void lcd_xieping(uchar x,uchar y,uchar *str)
//********************************************************
//开机显示
//********************************************************
void kjxs()
{
uint i,j
lcd_xieping(0,0,"****************")
lcd_xieping(1,0,"欢迎进入")
lcd_xieping(2,0," 密码锁系统! ")
lcd_xieping(3,0,"****************")
delay_ms(4000)
lcd_xieping(0,0," 系统初始化中 ")
lcd_xieping(1,0,"请稍后…")
lcd_xieping(2,0,"————————")
lcd_xieping(3,0," ")
for(j=3j>0j--)
{
for(i=0i<8i++)
{
lcd_xieping(3,i,"*")
delay_ms(250)
}
lcd_xieping(3,0,"")
}
}
//********************************************************
//12864显示
//********************************************************
void write_cmd(uchar cmd)
{
LCD_RS = 0
LCD_RW = 0
LCD_EN = 0
P0 = cmd
delay_ms(5)
LCD_EN = 1
delay_ms(5)
LCD_EN = 0
}
void write_dat(uchar dat)
{
LCD_RS = 1
LCD_RW = 0
LCD_EN = 0
P0 = dat
delay_ms(5)
LCD_EN = 1
delay_ms(5)
LCD_EN = 0
}
void lcd_xieping0(uchar x,uchar y,uchar date)
{
switch(x)
{
case 0: write_cmd(0x80+y)break
case 1: write_cmd(0x90+y)break
case 2: write_cmd(0x88+y)break
case 3: write_cmd(0x98+y)break
}
write_dat(date)
}
void lcd_xieping(uchar x,uchar y,uchar *str)
{
switch(x)
{
case 0: write_cmd(0x80+y)break
case 1: write_cmd(0x90+y)break
case 2: write_cmd(0x88+y)break
case 3: write_cmd(0x98+y)break
}
while (*str)
{
write_dat(*str)
str++
}
}
void lcd_init()
{
LCD_PSB = 1//并口方式
write_cmd(0x30) //基本指令 *** 作
delay_ms(5)
write_cmd(0x0C) //显示开,关光标
delay_ms(5)
write_cmd(0x01) //清除LCD的显示内容
delay_ms(5)
}
//**************************************************************
// 键盘扫描函数
//**************************************************************
uchar keyscan1()//矩阵键盘扫描函数
{
uchar temp
while(!num)
{P1=0xfe//赋值
temp=P1//读回数据
temp=temp&0xf0 //与运算
if(temp!=0xf0) //判断
{
delay_ms(2) //延时消抖
temp=P1//读回数据
temp=temp&0xf0
if(temp!=0xf0)
{
switch(temp) //多分支选择
{
case 0x70:num=1break //跳出
case 0xb0:num=2break
case 0xd0:num=3break
case 0xe0:num=4break
}
while(temp!=0xf0)
{
temp=P1
temp=temp&0xf0
}//等待按键释放
}
}
P1=0xfd//赋值
temp=P1//读回数据
temp=temp&0xf0 //与运算
if(temp!=0xf0) //判断
{
delay_ms(2) //延时消抖
temp=P1//读回数据
temp=temp&0xf0
if(temp!=0xf0)
{
switch(temp) //多分支选择
{
case 0x70:num=5break //跳出
case 0xb0:num=6break
case 0xd0:num=7break
case 0xe0:num=8break
}
while(temp!=0xf0)
{
temp=P1
temp=temp&0xf0
}//等待按键释放
}
}
P1=0xfb//赋值
temp=P1//读回数据
temp=temp&0xf0 //与运算
if(temp!=0xf0) //判断
{
delay_ms(2) //延时消抖
temp=P1//读回数据
temp=temp&0xf0
if(temp!=0xf0)
{
switch(temp) //多分支选择
{
case 0x70:num=9break //跳出
case 0xb0:num=10break
case 0xd0:num=11break
case 0xe0:num=12break
}
while(temp!=0xf0)
{
temp=P1
temp=temp&0xf0
}//等待按键释放
}
}
}
return(num)//返回值
}
uchar keyscan2()
{
uchar temp
while(!num1)
{P1=0xf7//赋值
temp=P1//读回数据
temp=temp&0xf0 //与运算
if(temp!=0xf0) //判断
{
delay_ms(2) //延时消抖
temp=P1//读回数据
temp=temp&0xf0
if(temp!=0xf0)
{
switch(temp) //多分支选择
{
case 0x70:num1=1break //跳出
case 0xb0:num1=2break
case 0xd0:num1=3break
case 0xe0:num1=4break
}
while(temp!=0xf0)
{
temp=P1
temp=temp&0xf0
}//等待按键释放
}
}
}
return(num1)
}
//**************************************************************
//直流电机
//**************************************************************
void dianjiZZ()
{
EN=1
ZZ=1
FZ=0
}
void dianjiFZ()
{
EN=1
ZZ=0
FZ=1
}
void dianji_stop()
{
EN=0
}
//**************************************************************
//EPPROM
//**************************************************************
void start() //启动信号
{
SDA=1
delay()
SCL=1
delay()
SDA=0
delay()
}
void stop()//停止信号
{
SDA=0
delay()
SCL=1
delay()
SDA=1
delay()
}
void respons() //响应信号
{
uchar i
SCL=1
delay()
while((SDA==1)&&(i<250))
i++
SCL=0
delay()
}
void writebyte(uchar date) //写一个字节
{
uchar i,temp
temp=date
for(i=0i<8i++)
{
temp=temp<<1
SCL=0
delay()
SDA=CY
delay()
SCL=1
delay()
}
SCL=0
delay()
SDA=1//释放总线
delay()
}
uchar readbyte() //读一个字节
{
uchar i,k
SCL=0
delay()
SDA=1
for(i=0i<8i++)
{
SCL=1
delay()
k=(k<<1)|SDA
SCL=0
delay()
}
delay()
return(k)
}
void write(uchar add,uchar date) //在一个地址写一个字节
{
start()
writebyte(0xa0)
respons()
writebyte(add)
respons()
writebyte(date)
respons()
stop()
}
uchar read(uchar add) //在一个地址读一个字节
{
start()
writebyte(0xa0)
respons()
writebyte(add)
respons()
start()
writebyte(0xa1)
respons()
b=readbyte()
respons()
stop()
return(b)
}
//**************************************************************
//时间日期函数
//**************************************************************
void v_WTInputByte(uchar ucDa)
{
uchar i
ACC= ucDa
for(i=8i>0i--)
{
T_IO = ACC0//*相当于汇编中的 RRC
T_CLK = 1
T_CLK = 0
ACC =ACC>>1
}
}
uchar uc_RTOutputByte(void)
{
uchar i
for(i=8i>0i--)
{
ACC = ACC>>1//*相当于汇编中的 RRC
ACC7 = T_IO
T_CLK = 1
T_CLK = 0
}
return(ACC)
}
void v_W1302(uchar ucAddr, uchar ucDa)
{
T_RST = 0
T_CLK = 0
T_RST = 1
v_WTInputByte(ucAddr)/* 地址,命令 */
v_WTInputByte(ucDa)/* 写1Byte数据*/
T_CLK = 1
T_RST =0
}
uchar uc_R1302(uchar ucAddr)
{
uchar ucDa
T_RST = 0
T_CLK = 0
T_RST = 1
v_WTInputByte(ucAddr)// 地址,命令 //
ucDa = uc_RTOutputByte()// 读1Byte数据 //
T_CLK = 1
T_RST =0
return(ucDa)
}
void Init1302(void)
{
v_W1302(0x8e,0x00) //控制写入WP=0
v_W1302(0x80,0x80)
v_W1302(0x90,0xa9)
v_W1302(0x80,0x00) //秒
v_W1302(0x82,0x24) //分
v_W1302(0x84,0x12) //时
v_W1302(0x86,0x29) //日
v_W1302(0x88,0x10) //月
v_W1302(0x8a,0x05) //星期
v_W1302(0x8c,0x10) //年 //
v_W1302(0x8e,0x80)
}
void donetime(void)
{
uchar d
d=uc_R1302(0x87)
day[10]=(d&0x0f)+48
day[9]=((d>>4)&0x03)+48
d=uc_R1302(0x89)
day[7]=(d&0x0f)+48
day[6]=((d>>4)&0x01)+48
d=uc_R1302(0x8b)
day[13]=(d&0x07)+48
d=uc_R1302(0x8d)
day[4]=(d&0x0f)+48
day[3]=(d>>4)+48
d=uc_R1302(0x81)
time[15]=(d&0x0f)+48
time[14]=(d>>4)+48
d=uc_R1302(0x83)
time[12]=(d&0x0f)+48
time[11]=(d>>4)+48
d=uc_R1302(0x85)
time[9]=(d&0x0f)+48
time[8]=(d>>4)+48
}
//**************************************************************
//温度检测函数
//**************************************************************
void dsreset(void)//18B20复位,初始化函数
{
uint i
ds=0
i=103
while(i>0)i--
ds=1
i=4
while(i>0)i--
}
bit tempreadbit(void) //读1位函数
{
uint i
bit dat
ds=0i++ //i++ 起延时作用
ds=1i++i++
dat=ds//读数据
i=8while(i>0)i--
return (dat)
}
uchar tempread(void) //读1个字节
{
uchar i,j,dat
dat=0
for(i=1i<=8i++)
{
j=tempreadbit()
dat=(j<<7)|(dat>>1) //读出的数据最低位在最前面,这样刚好一个字节在DAT里
}
return(dat)
}
void tempwritebyte(uchar dat) //向18B20写一个字节数据
{
uint i
uchar j
bit testb
for(j=1j<=8j++)
{
testb=dat&0x01 //判断最后一位是1还是0
dat=dat>>1
if(testb) //写 1
{
ds=0
i++i++
ds=1
i=8while(i>0)i--
}
else
{
ds=0 //写 0
i=8while(i>0)i--
ds=1
i++i++
}
}
}
void tempchange(void) //DS18B20 开始获取温度并转换
{
dsreset()//初始化,每次对18B20的 *** 作都首先要初始化
delay_ms(1)
tempwritebyte(0xcc) // 写跳过读ROM指令
tempwritebyte(0x44) // 写温度转换指令
}
void get_temp() //读取寄存器中存储的温度数据
{
uchar a,b
dsreset() //初始化
delay_ms(1)
tempwritebyte(0xcc) // 写跳过读ROM指令
tempwritebyte(0xbe) //写读指令
a=tempread()//读低8位
b=tempread()//读高8位
temp1=b
temp1<<=8 //两个字节组合为1个字
temp1=temp1|a
f_temp=temp1*0.0625 //温度在寄存器中为12位 分辨率位0.0625°
}
//**************************************************************
//解密函数
//**************************************************************
void unlock()
{
uchar in,i
if(num==0)
{
lcd_xieping(0,0,"**密码锁系统**")
lcd_xieping(1,0,"—————————")
lcd_xieping(2,0," 请输入密码: ")
lcd_xieping(3,0,"")
for(i=0i<4i++)
{
t1[i]=keyscan1()
lcd_xieping(3,i,"*")
num=0
}//输密码
}
in=keyscan1()
if(in==12)//in-确定键标志位
{
in=0
num=0
if((t1[0]==t[0])&&(t1[1]==t[1])&&(t1[2]==t[2])&&(t1[3]==t[3]))
{
flag=1//解密成功与否标志位
//unlock_i=1
a=0//功能键标志
lcd_xieping(0,0,"**密码锁系统** ")
lcd_xieping(1,0,"——————————")
lcd_xieping(2,0,"密码正确!")
lcd_xieping(3,0," 您的身份已确认")
delay_ms(1500)
lcd_xieping(1,0,"————————")
lcd_xieping(2,0,"功能 I 开锁")
lcd_xieping(3,0," II修改密码")
}
else
{
flag=0
count++
if(count==3)
{
count=0
num=1
lcd_xieping(1,0,"——————————")
lcd_xieping(2,0,"您的机会已用完 ")
lcd_xieping(3,0,"对不起**无法进入")
FM=0
delay_ms(1000)
FM=1
}
}
}
}
//**************************************************************
// 修改密码函数
//**************************************************************
void xiugaimima()
{ uchar i,j,l,im,ib
uchar t2[4]
uchar t3[4]
num=0
lcd_xieping(1,0,"————————")
lcd_xieping(2,0,"请输入新密码: ")
lcd_xieping(3,0,"")
for(i=0i<4i++)
{
t2[i]=keyscan1()
lcd_xieping0(3,i,mima[num])
num=0
}
im=keyscan1()
if(im==12)//im,in,ib,同为确定键标志位
{
im=0
num=0
lcd_xieping(1,0,"————————")
lcd_xieping(2,0,"请再次输入新密码")
lcd_xieping(3,0,"")
for(i=0i<4i++)
{
t3[i]=keyscan1()
lcd_xieping0(3,i,mima[num])
num=0
}
}
ib=keyscan1()
if(ib==12)
{
ib=0
num=0
if(t2[0]==t3[0]&&t2[1]==t3[1]&&t2[2]==t3[2]&&t2[3]==t3[3])
{
t[0]=t3[0]
t[1]=t3[1]
t[2]=t3[2]
t[3]=t3[3]
lcd_xieping(1,0,"————————")
lcd_xieping(2,0,"祝贺您!")
lcd_xieping(3,0," 密码修改成功 ")
flag=0
for(j=0j<4j++)
{
l=j+1
write(l,t[j])
delay_ms(10)
}//24C08写数据
delay_ms(1000)
}
else
{
lcd_xieping(2,0,"两次输入密码不同")
lcd_xieping(3,0," 密码修改失败 ")
flag=1
delay_ms(500)
}
}
}
//**************************************************************
//显示函数
//**************************************************************
void xianshi()
{
donetime()
tempchange()
get_temp()
s_temp=f_temp*100
temp0[7]=(s_temp/1000)+48
temp0[8]=(s_temp%1000/100)+48
temp0[10]=(s_temp%100/10)+48
temp0[11]=(s_temp%10)+48
lcd_xieping(0,0,"**密码锁系统** ")
lcd_xieping(1,0,temp0)
lcd_xieping(2,0,day)
lcd_xieping(3,0,time)
num=0
}
//**************************************************************
//开锁函数
//**************************************************************
void kaisuo()
{
uchar i
lcd_xieping(2,0,"开锁中…… ")
lcd_xieping(3,0,"——耐心等待——")
for(i=3i>0i--)
{
FM=0
delay_ms(100)
FM=1
delay_ms(100)
flag=0
}
dianjiZZ()
delay_ms(10000)
dianji_stop()
lcd_xieping(2,0,"—开锁过程结束—")
lcd_xieping(3,0,"请开门")
delay_ms(5000)
dianjiFZ()
delay_ms(10000)
dianji_stop()
flag=0
}
//**************************************************************
//主函数
//**************************************************************
void main()
{
uchar m
unlock_i=1
lcd_init() //液晶初始化
//Init1302()
kjxs() //开机显示
for(m=0m<4m++)
{
t[m]=read(m+1)
delay_ms(10)
}//24C08读数据
while(1)
{
reshi()
if(!unlock_i)
{
unlock()//解密函数
}
else
{
xianshi()//时间、日期、温度显示函数
}
if(flag==1)
{
num1=0
a=keyscan2()
if(a==1)
{
kaisuo()//开锁函数
}
if(a==2)
{
xiugaimima()//修改密码函数
}
}
}
}
#include <reg52.h>#define uint unsigned int
#define uchar unsigned char
#define BIN(a,b,c,d,e,f,g,h) ((a<<7)+(b<<6)+(c<<5)+(d<<4)+(e<<3)+(f<<2)+(g<<1)+(h<<0))
//下面的code表示数组存放在ROM中,因为这个数组的值不需要改写
uchar code KeyCode[16]={15,14,12,8,30,28,24,16,60,56,48,32,120,112,96,64}//值为m*(n+1)的乘积,用于Key()
uchar dis[6]
msdelay(uint x)//延时子函数
{uchar j
while(x--)
{for(j=0j<125j++){}
}
}
//键盘子程序一,键盘值与数组值对比得到
uchar Key(void)
{uchar temp,m,n,i,j,matrix,k
P1=0xF0 /*行线电平为高,列线为低*/
temp=P1&0xf0
if (temp==0xf0) return(16)/*行仍为高,无按健,退出*/
else msdelay(10)
for(i=1i<16i=i*2)
{m=i
for(j=1j<16j=j*2)
{n=(~j)&0x0f
P1=(m<<4)|n/*m为P1的行值由i循环得到,n为列值,由j循环并取反得到*/
temp=P1&0xf0
if (!temp)
{do{temp=P1&0xf0}while(!temp)
matrix=m*(n+1)/*为避免乘积重复,n+1*/
for(k=0k<16k++){if (matrix==KeyCode[k]) return(k)} //KeyCode:见前
return(16)
} //if loop
}//j loop
}//i loop
}//Key end
//用Switch...case语句得到键盘值*/
uchar Key1(void)
{uchar temp,m,n,i,j,matrix
P1=0xF0 /*行线电平为高,列线为低*/
temp=P1&0xf0
if (temp==0xf0) return(16) /*行仍为高,无按健,退出*/
else msdelay(10)
for(i=1i<16i=i*2)
{m=i
for(j=1j<16j=j*2)
{n=(~j)&0x0f
P1=(m<<4)|n/*m为P1的行值由i循环得到,n为列值,由j循环并取反得到*/
temp=P1&0xf0
if (!temp)
{do{temp=P1&0xf0}while(!temp)
matrix=m*(n+1)
switch(matrix) //此方法的基本思路:
{case 15:return(1)break //由循环得到的m,n值赋于P1端口实现逐个键扫描
case 14:return(2)break //同时由m,n+1的值相乘得到对应键点de的积
case 12:return(3)break //m*(n+1)值扫描键点对应而得出键值
case 8:return(4)break //
case 30:return(5)break //
case 28:return(6)break //
case 24:return(7)break //
case 16:return(8)break
case 60:return(9)break
case 56:return(0)break
case 48:return(10)break
case 32:return(11)break
case 120:return(12)break
case 112:return(13)break
case 96:return(14)break
case 64:return(15)break
default:return(16)
} //switch end
} //if loop
}//j loop
}//i loop
}//Key end
//依次扫描16个按键
uchar Key2(void)
{uchar temp
P1=0xF0 /*使P1=1111 0000,行线电平为高,列线为低*/
temp=P1&0xf0
if (temp==0xf0) return(16) /*读P1=1111 xxxx,表示行仍为高,无按健,退出(x表示不关心)?/
else msdelay(10)
P1=0x1e /*P1=0001 1110,行一为高,列一为低,扫描第一个按键*/
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(1)}
P1=0x1d /*P1=0001 1101,行一为高,列二为低,扫描第二个按键,下面扫描其余按键*/
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(2)}
P1=0x1b
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(3)}
P1=0x17
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(4)}
P1=0x2e
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(5)}
P1=0x2d
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(6)}
P1=0x2b
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(7)}
P1=0x27
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(8)}
P1=0x4e
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(9)}
P1=0x4d
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(0)}
P1=0x4b
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(10)}
P1=0x47
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(11)}
P1=0x8e
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(12)}
P1=0x8d
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(13)}
P1=0x8b
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(14)}
P1=0x87
temp=P1&0xf0
if (!temp) {do{temp=P1&0xf0}while(!temp)
return(15)}
return(16) //扫描all按键都未按下,则输出16
}//Key2 end.
////////时钟中断显示子程序
void T0_int() interrupt 1
{static uchar i
if (i==6){i=0}
P0=5-i
P0=P0|(dis[i]<<4)
i++
TL0=0
TH0=252}
void distri(uint disnum)
{uint temp
dis[0]=0
dis[1]=disnum/10000
temp=disnum%10000
dis[2]=temp/1000
temp=temp%1000
dis[3]=temp/100
temp=temp%100
dis[4]=temp/10
dis[5]=temp%10
}
Main()
{uchar KeyVal,i=0
TMOD=0x01
IE=0x82
TH0=252
TL0=0
TR0=1
distri(0)
do{
KeyVal=Key()
if (KeyVal!=16) dis[1]=KeyVal//注意:当有按键时才赋于显示位dis[1],否则出错,请分析!
}while(1)
}
首先得说明我这个可是自己原创手打的,但是没去仿真了,程序可能有错误,你自己修改下吧#include<reg52.h>
typedef unsigned char uchar
typedef unsigned int uint
sbit key1=P0^0
sbit key2=P0^1
sbit key3=P0^2
sbit key4=P0^3
sbit wela=P2^0//位锁存端
#define SMG P1
sbit LED=P3^0//低电平亮
uchar code table[]={0x8d,0x86}//共阳数码管 P,E
uchar chushi_mima[]={2,1,3}
uchar shuru_mima[3]
uchar index//控制输入密码的位数
uchar flag_3s=0//3s标志位
uchar keydown//确定按键变量
#define times 15//去抖时间15Ms
uchar key1_count,key2_count,key3_count,key4_count
void init()
{
wela=0
SMG=0xff
TMOD=0x01
TH0=(65536-1000)/256
TL0=(65536-1000)%256
ET0=1
EA=1
TR0=1
LED=1;
}
void main()
{
init()
while(1)
{
switch(keydown)
{
if(index>2)index=0
case 1:
shuru_mima[index]=0
index++
break
case 2:
shuru_mima[index]=1
index++
break
case 3:
shuru_mima[index]=2
index++
break
case 4:
shuru_mima[index]=3
index++
break
}
flag_3s=0
for(i=0i<3i++)
{
if(shuru_mima[i]==chushi_mima[i])
{
LED=0
wela=1
SMG=table[0]
if(flag_3s)
{
flag_3s=0
wela=0
}
}
else
{
LED=1
wela=1
SMG=table[1]
if(flag_3s)
{
flag_3s=0
wela=0
}
}
}
}
}
void timer0() interrupt 1
{
uchar count
TH0=(65536-1000)/256
TL0=(65536-1000)%256
if(++count>=600)
{
count=0
flag_3s=1
}
/*********1ms中断扫描按键(包含去抖程序)********/
if(!key1&&key1_count!=0)
{
key1_count--
if(key1_count==0)
{
keydown=1
}
}
else if(!key1) key1_count=times
// key2,key3,key4你自己写吧
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)