简易计算器的设计.doc_第1页
简易计算器的设计.doc_第2页
简易计算器的设计.doc_第3页
简易计算器的设计.doc_第4页
简易计算器的设计.doc_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一、功能实现:利用1602液晶显示器实现整数和小数的加法、减法、乘法、除法、开根号的运算。第一行显示输入的数据,第二行显示运算结果。二、proteus仿真图三、操作说明:每次运算完后必须按一下清零键,该系统才会重新开始执行。四、程序:#include#include#define int unsigned int#define char unsigned charvoid inti(); /初始化void delay(); /延时void anjian(); /按键显示数字和符号,第一个数存在a内void sheji(); /设计显示完后的参数void jsab();/存储两个输入数void jisuanxs(); /计算显示void chufa(); /除法计算部分void chengfa(); /乘法计算部分void jianfa(); /减法计算部分void jiafa();/加法计算部分void kaigenhao();/开根号运算部分void benshenxs(); /一个数本事显示void leijixiaoshudian(); /小数点的累计void fenli(); /计算后的结果分离,以便于显示void ql(); /清屏void xshuju(char shuju); /写数据void xzhiling(char zhiling); /写指令/char num=i love you; 显示在屏幕上int sz=0,1,2,3,4,5,6,7,8,9,+,-,*,/,=,.;char xs=enrro;sbit e=p22;sbit rs=p20;sbit rw=p21;sbit key0=p26;sbit key1=p27;sbit key2=p30;sbit key3=p31;sbit key4=p32;sbit key5=p33;sbit key6=p34;sbit key7=p35;sbit key8=p36;sbit key9=p37;sbit key10=p13;sbit key11=p14;sbit key12=p15;sbit key13=p16;sbit key14=p17;sbit qingling=p10;sbit key15=p11;sbit key16=p12;int fuhao,num,m,n,q,w,s,fuhao1,fuhao2,fuhao3,fuhao4,fuhao5,xiaoshu,cishu1,cishu2;int i,g,j,p;int t,f,h;float a,b,c,d;void main() inti();a=0;b=0;c=1.0;d=1.0;q=0;fuhao=0;xiaoshu=0;cishu1=0;cishu2=0;num=0;xzhiling(0x80+0x01);/*第一行初始地址为80h,后面加03h是指在距屏幕的起始处3空格出开始显示,第二行的初始地址为80h+40h */ while(1) while(fuhao=0) /没有计算过程,输入数据后,按等于号即输出结果 anjian(); benshenxs(); while(fuhao1=1) /加法anjian();jiafa();while(fuhao2=1)/减法anjian();jianfa();while(fuhao3=1) /乘法anjian();chengfa();while(fuhao4=1) /除法anjian();chufa(); while(fuhao5=1) /开根号anjian();kaigenhao();ql(); /清零void inti()/初始化 e=0; xzhiling(0x38);/功能设定,根据所用的液晶显示器来决定的,即开显示 xzhiling(0x0f); /0x0f设置显示功能开,有光标且闪烁,如为0x0e则为光标不闪,如为0x0c则无光标 xzhiling(0x06); /光标设置为写入字符后自动右移一位,和整屏左移 xzhiling(0x01); /清屏 void delay() /延时int i,j;for(i=5;i0;i-)for(j=110;j0;j-);void xzhiling(char zhiling) /写指令rs=0;rw=0;e=0;p0=zhiling;delay();e=1;delay();e=0;void xshuju(char shuju) /写数据rs=1;rw=0;e=0;p0=shuju;delay();e=1;delay();e=0;void anjian() /按键显示数字和符号,第一个数存在a内if(key0=0) /0 delay(); if(key0=0) xshuju(sz0); delay(); while(!key0); num=0; jsab(); leijixiaoshudian(); if(key1=0) /1 delay(); if(key1=0) xshuju(sz1); delay(); while(!key1); num=1; jsab(); leijixiaoshudian(); if(key2=0) /2 delay(); if(key2=0) xshuju(sz2); delay(); while(!key2); num=2; jsab(); leijixiaoshudian(); if(key3=0) /3 delay(); if(key3=0) xshuju(sz3); delay(); while(!key3); num=3; jsab(); leijixiaoshudian(); if(key4=0) /4 delay(); if(key4=0) xshuju(sz4); delay(); while(!key4); num=4; jsab(); leijixiaoshudian(); if(key5=0) /5 delay(); if(key5=0) xshuju(sz5); delay(); while(!key5); num=5; jsab(); leijixiaoshudian(); if(key6=0) /6 delay(); if(key6=0) xshuju(sz6); delay(); while(!key6); num=6; jsab(); leijixiaoshudian(); if(key7=0) /7 delay(); if(key7=0) xshuju(sz7); delay(); while(!key7); num=7; jsab(); leijixiaoshudian(); if(key8=0) /8 delay(); if(key8=0) xshuju(sz8); delay(); while(!key8); num=8; jsab(); leijixiaoshudian(); if(key9=0) /9 delay(); if(key9=0) xshuju(sz9); delay(); while(!key9); num=9; jsab(); leijixiaoshudian(); if(key10=0) /加 delay(); if(key10=0) xshuju(sz10); delay(); fuhao=1; xiaoshu=0; num=0; fuhao1=1; while(!key10); if(key11=0) /减 delay(); if(key11=0) xshuju(sz11); delay(); fuhao=1; xiaoshu=0; num=0; fuhao2=1; while(!key11); if(key12=0) /乘 delay(); if(key12=0) xshuju(sz12); delay(); fuhao=1; xiaoshu=0; num=0; fuhao3=1; while(!key12); if(key13=0) /除 delay(); if(key13=0) xshuju(sz13); delay(); fuhao=1; xiaoshu=0; fuhao4=1; num=0; while(!key13); if(key15=0)/小数点 delay();if(key15=0)xiaoshu=1;xshuju(sz15);delay();while(!key15); if(key16=0) /开根号 delay();if(key16=0)xshuju(0xe8);delay();fuhao5=1;fuhao=1;while(!key16); void jsab()/存储两个输入数if(fuhao=0)a=a*10+num;elseb=b*10+num;void fenli() /计算后的结果分离,以便于显示if(q=0&q=10&q=100&q1000)m=q/100;n=q%100/10;s=q%10;void jisuanxs() /计算显示 if(key14=0)delay();if(key14=0)xzhiling(0x80+0x40);if(q=0)xshuju(szq);delay();sheji();if(q=10&q=100&q0;j-)c=c*0.1;a=a*c;q=(int) a;t=(int)(a/0.01);h=t%100/10;f=t%10;if(h!=0)|(f!=0)/判断小数部分不为0时显示xzhiling(0x80+0x40);fenli();jisuanxs();xshuju(sz15);delay();xshuju(szh);delay();xshuju(szf);delay();xzhiling(0x0c);else /小数部分为0时,显示xzhiling(0x80+0x40);fenli();jisuanxs(); if(cishu1=0) q=a;xzhiling(0x80+0x40);fenli();jisuanxs();delay(); ql(); void jiafa()/加法计算部分 if(key14=0) delay();if(key14=0)if(cishu1!=0)|(cishu2!=0) for(j=cishu1;j0;j-)c=c*0.1;a=a*c; for(p=cishu2;p0;p-)d=d*0.1;b=b*d;q=(int)(a+b);t=(int)(a+b)/0.01);h=t%100/10;f=t%10;if(h!=0)|(f!=0)/判断小数部分不为0时显示xzhiling(0x80+0x40);fenli();jisuanxs();xshuju(sz15);delay();xshuju(szh);delay();xshuju(szf);delay();xzhiling(0x0c);else/小数部分为0时显示xzhiling(0x80+0x40);fenli();jisuanxs(); if(cishu1=0)&(cishu2=0) q=a+b;xzhiling(0x80+0x40);fenli();jisuanxs();delay(); ql(); void jianfa() /减法计算部分 if(key14=0) delay();if(key14=0)if(cishu1!=0)|(cishu2!=0) for(j=cishu1;j0;j-)c=c*0.1;a=a*c; for(p=cishu2;p0;p-)d=d*0.1;b=b*d;q=(int)(a-b);t=(int)(a-b)/0.01);h=t%100/10;f=t%10;if(h!=0)|(f!=0) /判断小数部分不为0时显示xzhiling(0x80+0x40);fenli();jisuanxs();xshuju(sz15);delay();xshuju(szh);delay();xshuju(szf);delay();xzhiling(0x0c);else /小数部分为0时显示xzhiling(0x80+0x40);fenli();jisuanxs(); if(cishu1=0)&(cishu2=0) q=a-b;xzhiling(0x80+0x40);fenli();jisuanxs();delay(); ql(); void chengfa() /乘法计算部分 if(key14=0) delay();if(key14=0)if(cishu1!=0)|(cishu2!=0) for(j=cishu1;j0;j-)c=c*0.1;a=a*c; for(p=cishu2;p0;p-)d=d*0.1;b=b*d;q=a*b;t=(int)(a*b)/0.01);h=t%100/10;f=t%10;if(h!=0)|(f!=0)/小数部分不为0时显示xzhiling(0x80+0x40);fenli();jisuanxs();xshuju(sz15);delay();xshuju(szh);delay();xshuju(szf);delay();xzhiling(0x0c);else /小数部分为0时显示xzhiling(0x80+0x40);fenli();jisuanxs(); if(cishu1=0)&(cishu2=0) q=a*b;xzhiling(0x80+0x40);fenli();jisuanxs();delay(); ql(); void chufa() /除法计算部分 if(key14=0) delay();if(key14=0)if(cishu1!=0)|(cishu2!=0) for(j=cishu1;j0;j-)c=c*0.1;a=a*c; for(p=cishu2;p0;p-)d=d*0.1;b=b*d;q=a/b;t=(int)(a/b)/0.01);h=t%100/10;f=t%10;if(h!=0)|(f!=0)/小数部分不为0时显示xzhiling(0x80+0x40);fenli();jisuanxs();xshuju(sz15);delay();xshuju(szh);delay();xshuju(szf);delay();xzhiling(0x0c);else /小数部分为0时显示xzhiling(0x80+0x40);fenli();jisuanxs(); if(cishu1=0)&(cishu2=0) q=a/b;t=(int)(a/b)/0.01);/小数部分保留两位h=t%100/10; /分离小数部分f=t%10;if(key14=0)delay();if(key14=0)if(h!=0)|(f!=0)xzhiling(0x80+0x40);fenli();jisuanxs();xshuju(sz15);delay();xshuju(szh);delay();xshuju(szf);delay();xzhiling(0x0c);elsexzhiling(0x80+0x40);fenli();jisuanxs();delay();ql(); /小数分离显示部分if(b=0) /分母为0时,显示enrro表示

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论