news 2026/6/15 9:18:11

基于单片机存储柜(4个柜子,LCD1602,矩阵键盘)系统Proteus仿真(含全部资料)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于单片机存储柜(4个柜子,LCD1602,矩阵键盘)系统Proteus仿真(含全部资料)

全套资料包含:Proteus仿真源文件+keil C语言源程序+AD原理图+流程图+元器件清单+说明书等

资料下载:↓↓↓

通过网盘分享的文件:资料分享
链接:百度网盘 请输入提取码提取码: tgnu


目录

资料下载:

Proteus仿真功能

项目文件资料:

一、Proteus仿真源文件

二、AD原理图文件

二、报告说明书

三、系统流程图

四、Keil c语言程序源代码


项目功能:

其中有10个数字按键(0-9)
存包-按下此按键,牛成随机密码
取包—按下此按键,进行密码输入
清除一在输入密码过程中,按下此键,可以清空输入
确认-按下此键,进行密码验证


项目文件:

一、Proteus仿真源文件

​​

二、AD原理图文件

二、报告说明书

三、系统流程图

​​

四、器件清单

元件型号数量
单片机AT89C511
电容10uf1
电容30pf2
晶振12MHZ1
电阻10k1
按钮17
存储器24C021
LED红色4
电阻100欧4
电阻1k1
三极管PNP1
蜂鸣器有源1
显示器LCD16021
排阻10k1

五、Keil c语言程序源代码(部分)

#include "reg51.h" #include <stdlib.h> #include "i2c.h" #include "lcd1602.h" #define uchar unsigned char #define uint unsigned int sbit beep=P2^5;//蜂鸣器 uchar code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//数码管编码 uint time=0; uchar mode=0;//系统变量 uchar state[]={0,0,0,0};//柜子状态 uchar mima[]={0,0,0,0,0,0,0,0}; uchar duqu[]={0,0,0,0,0,0,0,0};//输入密码 uchar num=8;//临时编号 uchar beep_time=0;//蜂鸣器定时 uchar error=0; uchar time1=0; //======================================================== //生成随机密码 void mima_rand() { uchar i=0; for(i=0;i<8;i++) { mima[i]=(rand()%100+TL0)%10; } } //存储密码 j=0-7 void save(uchar j) { uchar i=0; for(i=0;i<8;i++) { At24c02Write(j*8+8+i,mima[i]); } for(i=0;i<4;i++)//状态存储 { At24c02Write(i,state[i]); } } //读取密码 void read(uchar j) { uchar i=0; for(i=0;i<8;i++) { mima[i]=At24c02Read(j*8+8+i); } } //======================================================== //显示柜子状态 void disp1() { uchar i=0; write_com(0x80+12); for(i=0;i<4;i++) { write_data(state[i]*36+0xdb); } } //显示随机密码 void disp2() { uchar i=0; write_com(0x80); for(i=0;i<8;i++) { write_data(mima[i]+0x30); } } //显示输入密码 void disp3() { uchar i=0; write_com(0xc0); for(i=0;i<8;i++) { write_data(duqu[i]+0x30); } } //======================================================== uchar key=0; uchar key_scan()//按键检测 { uchar i,j; i=0; j=0; P1=0x0f; if(P1!=0x0f) //检测有无按下 { delay_uint(1000); if(P1!=0x0f) { switch(P1)//检测行 { case 0x0e:i=3;break; case 0x0d:i=2;break; case 0x0b:i=1;break; case 0x07:i=0; } P1=0xf0; switch(P1)//检测列 { case 0xe0:j=13;break; case 0xd0:j=9;break; case 0xb0:j=5;break; case 0x70:j=1; } } } if(key!=i+j) { key=i+j; return key; } else return 0; } void main()//主函数 { uchar i=0,j,k,m; init_1602(); for(i=0;i<4;i++)//初始化状态 { state[i]=At24c02Read(i); } if(state[0]>1) { for(i=0;i<4;i++)//初始化状态 { state[i]=0; At24c02Write(i,0); } } read(0);//密码1检查 if(mima[0]>9) { for(j=0;j<8;j++) mima[j]=0; save(0); } read(1);//密码2检查 if(mima[0]>9) { for(j=0;j<8;j++) mima[j]=0; save(1); } read(2);//密码3检查 if(mima[0]>9) { for(j=0;j<8;j++) mima[j]=0; save(2); } read(3);//密码4检查 if(mima[0]>9) { for(j=0;j<8;j++) mima[j]=0; save(3); } disp1(); TMOD|=0X01;//初始化定时器0 TH0=0X3C; TL0=0XB0; ET0=1;//打开定时器0中断允许 EA=1;//打开总中断 TR0=1;//打开定时器 while(1) { i=key_scan();//按键检测 if(mode==0)//等待模式 { P3=0xff; if(i==13)//存包 { mima_rand();//随机密码 for(j=0;j<8;j++) duqu[j]=0; num=4; for(j=0;j<4;j++) //查询空箱子 { if(state[j]==0) { num=j; break; } } if(num<4)//有空柜子 { mode=1; P3=~(1<<num);//led } else //无空柜子 { beep_time=20; P3=0xff; } } if(i==14)// 取包 { for(j=0;j<8;j++) duqu[j]=253; mode=5; time=1200; } } if(mode==1)//输入密码模式,存包 { if(i==15)//清除 { for(j=0;j<8;j++) duqu[j]=0; } if(i==12)//退出 { mode=0; for(j=0;j<8;j++)//清零 duqu[j]=0; for(j=0;j<8;j++) mima[j]=0; state[num]=0; num=4; } if((i>0)&&(i<11))//输入数字 { duqu[0]=duqu[1]; duqu[1]=duqu[2]; duqu[2]=duqu[3]; duqu[3]=duqu[4]; duqu[4]=duqu[5]; duqu[5]=duqu[6]; duqu[6]=duqu[7]; duqu[7]=i-1; beep_time=10; } if(i==16)//OK { k=0; for(j=0;j<8;j++) { if(mima[j]==duqu[j]) k++; } if(k==8)//密码正确 { mode=2; error=0; save(num);//保存 for(j=0;j<8;j++)//清零 duqu[j]=0; for(j=0;j<8;j++) mima[j]=0; } else //密码错误 { if(error<3) { error++; beep_time=20; } else { mode=0; beep_time=100; } for(j=0;j<8;j++)//清零 duqu[j]=0; for(j=0;j<8;j++) mima[j]=0; } } } //+++++++++++++++++++++++++++++++++++++++++ if(mode==5)//拿取 { disp3(); if(i==15)//清除 { for(j=0;j<8;j++) duqu[j]=253; P3=0xff; } if(i==12)//退出 { mode=0; for(j=0;j<8;j++)//清零 duqu[j]=0; for(j=0;j<8;j++) mima[j]=0; state[num]=0; num=4; } if((i>0)&&(i<11))//输入数字 { duqu[0]=duqu[1]; duqu[1]=duqu[2]; duqu[5]=duqu[6]; duqu[6]=duqu[7]; duqu[7]=i-1; beep_time=10; } if(i==16)//OK { for(m=0;m<4;m++) { read(m); k=0; for(j=0;j<8;j++) { if(mima[j]==duqu[j]) k++; } if(k==8)//密码对得上 { break; } } if((m<4)&&(state[m]==1))//密码正确,开柜子 { P3=~(1<<m);//led mode=6; time=100; beep_time=8; error=0; state[m]=0; save(m); for(j=0;j<8;j++) duqu[j]=0; for(j=0;j<8;j++) mima[j]=0; } else //密码错误 { if(error<3) { error++; beep_time=60; } else { mode=0; beep_time=40; } for(j=0;j<8;j++)//清零 duqu[j]=0; for(j=0;j<8;j++) mima[j]=0; } k=8; } } } } //定时器中断 void Timer0() interrupt 1 { if(time>0)//倒计时 time--; if(time1<10)//0.5s time1++; else { time1=0; if((num<4)&&(mode==1)) state[num]=1; if(mode==2)//闪烁提示 { if(P3==0xff) P3=~(1<<num); else P3=0xff; if(error<7) error++; else { error=0; P3=0xff; mode=0; state[num]=1; } } //显示 disp1(); if((mode==6)||(mode==2)) { write_string(2,12,"OK! "); if(time==0) mode=0; } else { write_string(2,12," "); } } { beep=1; } TH0=0X3C; TL0=0XB0; }

六、全套资料包含

​​

七:项目资源获取

需要完整的资料可以点击下面的名片关注,回复“资料”!

↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 19:44:00

【限时关注】金融行业加密标准解读:PHP如何合规实现非对称加密

第一章&#xff1a;金融支付中非对称加密的合规背景在金融支付系统中&#xff0c;数据安全与用户隐私保护是监管机构关注的核心议题。随着《支付卡行业数据安全标准》&#xff08;PCI DSS&#xff09;、《通用数据保护条例》&#xff08;GDPR&#xff09;以及中国《网络安全法》…

作者头像 李华
网站建设 2026/6/15 13:13:00

Wan2.2-T2V-A14B在汽车发布会虚拟舞台设计中的全流程应用

Wan2.2-T2V-A14B在汽车发布会虚拟舞台设计中的全流程应用 在高端汽车品牌的新品发布会上&#xff0c;观众早已不再满足于静态展示或简单的PPT讲解。他们期待的是沉浸式的感官冲击——灯光随引擎声浪跳动&#xff0c;车身在全息舞台上缓缓升起&#xff0c;背景城市随着车辆启动而…

作者头像 李华
网站建设 2026/6/15 13:53:22

正则表达式

今天我们来讲讲正则表达式&#xff0c;那么什么是正则表达式呢&#xff0c;正则表达式是通过元字符&#xff08;具有特殊含义的字符&#xff09;和普通字符&#xff08;如字母&#xff0c;数字&#xff09;组合而成的“规则字符串”。语法都是各种符号,不好理解,不好记忆&#…

作者头像 李华
网站建设 2026/6/15 13:14:37

Wan2.2-T2V-A14B能否生成股市走势预测动画?金融内容边界探讨

Wan2.2-T2V-A14B能否生成股市走势预测动画&#xff1f;金融内容边界探讨 在短视频与AI技术深度融合的今天&#xff0c;一个看似简单的问题正在挑战行业的认知边界&#xff1a;我们能不能让大模型“画”出明天的股价&#xff1f;更具体地说&#xff0c;像 Wan2.2-T2V-A14B 这样参…

作者头像 李华