版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 单片机的简易计算器51新基于 单片机的简易计算器基于51前言: 1、 系列单片机来进行的数字计算器系统设计,可以完51本设计是基于上显示相LCD成计算器的键盘输入,进行加、减、乘、除基本四则运算,并在作单片机为主要控制电路,利用MM74C922应的结果;设计电路采用STC90C51静态显示;读取键盘上的输入;显示采用字符LCD为计算器4*4键盘的扫描IC 仿真。语言编程,并用软件方面使用CPROTUES 、设计任务:2)2键盘输入检测模块;(计算器软件程序要完成以下模块的设计: (1) 4)错误处理及提示模块。3LCD显示模块;()算术运算模块;( 3、主体设计部分: 、系统模块图:(1单片
2、输入模运算模块显示模块 )、系统总流程图:(2 开始初始化参数初始LC显读取键有否有键值数字清零功能根据上次功能键和输键入数状态清的数据计算结本次功能键结果送显示缓结果送显示缓等待数值键等待数值键结果送显示缓冲数值送显示缓冲等待数值键入LCD显示4、硬件部分 显示+1602矩阵键盘+单片机部分 如图所示为简易计算器的电路原理图。P3口用于键盘输入,接4*4矩阵键盘,键值与键盘的对应表如表-所示,p0口和p2口用于显示,p2口用于显示数值的高位,po口用于显示数值的低位。 简易计算器电路原理图 矩阵键盘有16个按键,满足对简易计算器的计算实现,显示部分 ,第一行显示计算的数值符号,第二行显示计算
3、结果。LCD1602采用 LCD显示模块: 本设计采用LCD液晶显示器来显示输出数据。通过D0-D7引脚向LCD写指令字或写数据以使LCD实现不同的功能或显示相应数据。 5、软件部分 #include #include #define uchar unsigned char sbit lcden=P27; sbit lcdrs=P26; sbit lcdrw=P25; sbit lcdbf=P07; uchar temp,key,i,j,flag,fh,k; long a,b,c; uchar code table=1,2,3,0, 4,5,6,0, 7,8,9,0, 0,0,0,0; uch
4、ar code table2=S+456-789*000/; void delay(uchar ms) uchar x,y; for(x=ms;x0;x-) for(y=110;y0;y-); /*-对LCD1602的操作-*/ bit busy(void)/判断忙碌 bit res; lcdrs=0; lcdrw=1; lcden=1; _nop_(); _nop_(); res=lcdbf; lcden=0; return res; void write_inst (uchar cmd)/写命令 忙碌就等待 while(busy()=1); /lcdrs=0; lcdrw=0; lcden
5、=0; _nop_(); _nop_(); P0=cmd; _nop_(); _nop_(); lcden=1; _nop_(); _nop_(); lcden=0; void write_com(uchar com)/写地址 write_inst(com|0x80); void write_date(uchar dat) /写数据 while(busy()=1); lcdrs=1; lcdrw=0; lcden=0; P0=dat; _nop_(); _nop_(); lcden=1; _nop_(); _nop_(); lcden=0; void init() /初始化 lcden=1;
6、write_inst(0x38);/显示8位2行 delay(5); write_inst(0x0c);/显示开,光标关,不闪烁 delay(5); write_inst(0x06);/增量方式不位移 delay(5); write_inst(0x80);/检测忙碌信号 delay(5); write_inst(0x01);/ delay(5); /*-键盘扫描-*/ void keyscan()/键盘扫描 P3=0xfe; if(P3!=0xfe) delay(100); if(P3!=0xfe) temp=P3&0xf0; switch(temp) case 0xe0:key=0;brea
7、k; case 0xd0:key=1;break; case 0xb0:key=2;break; case 0x70:key=3;break; while(P3!=0xfe); if(key=0|key=1|key=2) if(j!=0) write_inst(0x01); j=0; if(flag=0) a=a*10+tablekey; if(flag=1) b=b*10+tablekey; write_date(table2key); else if(k=0) flag=1; k=1; fh=1; write_date(table2key); P3=0xfd; if(P3!=0xfd) d
8、elay(100); if(P3!=0xfd) temp=P3&0xf0; switch(temp) case 0xe0:key=4;break; case 0xd0:key=5;break; case 0xb0:key=6;break; case 0x70:key=7;break; while(P3!=0xfd); if(key=4|key=5|key=6) if(j!=0) write_inst(0x01); j=0; if(flag=0) a=a*10+tablekey; if(flag=1) b=b*10+tablekey; write_date(table2key); else if
9、(k=0) flag=1; k=1; fh=2; write_date(table2key); P3=0xfb; if(P3!=0xfb) delay(100); if(P3!=0xfb) temp=P3&0xf0; switch(temp) case 0xe0:key=8;break; case 0xd0:key=9;break; case 0xb0:key=10;break; case 0x70:key=11;break; while(P3!=0xfb); if(key=8|key=9|key=10) if(j!=0) write_inst(0x01); j=0; if(flag=0) a
10、=a*10+tablekey; if(flag=1) b=b*10+tablekey; write_date(table2key); else if(k=0) flag=1; k=1; fh=3; write_date(table2key); P3=0xf7; if(P3!=0xf7) delay(100); if(P3!=0xf7) temp=P3&0xf0; switch(temp) case 0xe0:key=12;break; case 0xd0:key=13;break; case 0xb0:key=14;break; case 0x70:key=15;break; while(P3
11、!=0xf7); switch(key) case 12:write_inst(0x01);a=0;b=0;flag=0;fh=0;j=0;k=0; break; case 13: if(flag=0) a=a*10; write_date(0x30); P1=0; else if(flag=1) b=b*10; write_date(0x30); break; case 14: j=1; if(fh=1) write_com(0x4f); write_inst(0x04); c=a+b; while(c!=0) write_date(0x30+c_x0010_); c=c/10; write
12、_date(0x3d); a=0;b=0;flag=0;fh=0;k=0; else if(fh=2) write_com(0x4f); write_inst(0x04); if(a-b)0) c=a-b; else c=b-a; if(c=0) write_date(0x30+0); while(c!=0) write_date(0x30+c_x0010_); c=c/10; if(a-b)*(-1)0) write_date(0x2d); write_date(0x3d); a=0;b=0;flag=0;fh=0;k=0; else if(fh=3) write_com(0x4f); wr
13、ite_inst(0x04); c=a*b; if(c=0) write_date(0x30+0); while(c!=0) write_date(0x30+c_x0010_); c=c/10; write_date(0x3d); a=0;b=0;flag=0;fh=0;k=0; else if(fh=4) write_com(0x4f); write_inst(0x04); i=0; 计算c c=(long)(float)a/b)*1000); /的 数据 if(c=0) write_date(0x30+0); while(c!=0) write_date(0x30+c_x0010_); c=c/10; i+; if(i=3) write_date(0x2e); /写数据 if(a/b)=0) write_date(0x30); write_date(0x3d); a=0;b=0;flag=0;fh=0;k=0; break; case 15: if(k=0) write_date(tabl
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度房屋置换与家居定制服务合同范本3篇
- 二零二五年度校园雕塑作品采购合同范本3篇
- 2025年度环境监控系统工程合同2篇
- 海南职业技术学院《文献检索》2023-2024学年第一学期期末试卷
- 襄阳汽车课程设计招聘
- 海南师范大学《物流信息技术》2023-2024学年第一学期期末试卷
- 二零二五年度名校学区二手房买卖合同范本2篇
- 二零二五年度国际贸易实务:磋商与订立合同实务操作与法律风险防范手册9篇
- 二零二五年度海宁房产买卖纠纷调解及法律援助合同3篇
- 2025年度房地产项目销售代理合同3篇
- 阅读理解(专项训练)-2024-2025学年湘少版英语六年级上册
- 民用无人驾驶航空器产品标识要求
- 2024年医院产科工作计划例文(4篇)
- 2024-2025学年九年级英语上学期期末真题复习 专题09 单词拼写(安徽专用)
- 无创通气基本模式
- 江西省赣州市寻乌县2023-2024学年八年级上学期期末检测数学试卷(含解析)
- 《临床放射生物学》课件
- 肠造口还纳术手术配合
- 2024年中考语文试题分类汇编:诗词鉴赏(学生版)
- 科学计算语言Julia及MWORKS实践 课件 3-MWORKS简介
- 2024年10月自考04532财务会计专题试题及答案含解析
评论
0/150
提交评论