当前位置: 首页 > news >正文

基于单片机存储柜(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; }

六、全套资料包含

​​

七:项目资源获取

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

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

http://www.jsqmd.com/news/74279/

相关文章:

  • 【BUUCTF系列】[强网杯 2019]随便注
  • Wan2.2-T2V-A14B支持多语言文本理解,全球化创作新利器
  • 解锁Wan2.2-T2V-A14B隐藏功能:高级提示词工程技巧
  • 【边缘Agent部署终极指南】:Docker轻量级实战技巧全揭秘
  • (甲基化研究必备技能)R语言实现CpG位点注释与功能富集分析全流程解析
  • N皇后问题
  • 谷城县这家家电门店,竟藏着最全产品,你去过吗?
  • NVIDIA显卡性能调校深度探索:解锁隐藏配置的艺术
  • 如何利用Wan2.2-T2V-A14B生成时序连贯的长视频片段?
  • 11、MobX实战应用与特殊API解析
  • 12、MobX特殊API与实用工具深度解析
  • 13、探索 mobx-utils 和 mobx-state-tree
  • Wan2.2-T2V-A14B在跨境电商产品展示视频中的多语言适配优势
  • Wan2.2-T2V-A14B能否生成自然灾害模拟视频?应急管理培训素材制作
  • 这道LeetCode Hard题,用一个转化思想就变简单了
  • 从“调参侠“到“炼丹大师“!16种大模型微调秘籍全解锁,小白也能玩转LLM定制开发
  • 通义千问凭借“门控注意力”斩获 NeurIPS 最佳论文奖!详解Gated Attention原理
  • 开源语音合成新选择:Chatterbox TTS API赋能开发者的文本转语音解决方案
  • 80亿参数改写AI应用规则:Qwen3-VL-8B-Thinking-bnb-4bit如何开启多模态普惠时代
  • HarmonyOS 6.0 ArkWeb开发实战:从基础到进阶的ArkUI+ArkTS实践
  • Agent原理、主流框架、设计模式及应用案例
  • LLM代码评审Agent实战:基于Qwen3-Coder与RAG的企业级应用!
  • 零基础逆袭大模型!全网最细LLM学习路线图,从入门到精通一篇搞定,超详细!
  • 从加密到解析仅需2分钟:Dify自动化PDF处理黑科技曝光
  • 国内大模型产业突破:ERNIE 4.5 技术创新引领行业智能化升级新范式
  • 上海人工智能实验室安全团队实习生/全职招聘
  • 算力、模型、生态:亚马逊云科技云创计划,深度学习创业者的硬核“加速器”
  • RL并非万能药:CMU 新论文揭秘大模型推理能力的真正来源
  • 【限时关注】金融行业加密标准解读:PHP如何合规实现非对称加密
  • 【JAVA项目】基于JAVA的医院管理系统