1、简单计算器可视化程序编程 IMB standardization office【IMB 5AB- IMBK 08- IMB 2C】简单计算器可视化程序编程简单计算器一、基本功能描述二进制、八进制、十进制及十六进制数的加、减、乘、除、乘方、取模等简单计算科学计算函数,包括(反)正弦、(反)余弦、(反)正切、(反)余切、开方、指数等函数运行以角度、弧度两种方式实现上述部分函数具备历史计算的记忆功能对不正确的表达式能指出其错误原因二、 流程图图1 输入数据子函数流程图图2 三、 设计步骤打开Microsoft Visual C+ ,在文件中点击新建,在弹出框内选择MFC AppWizardexe工程
2、,输入工程名Calculter及其所在位置,点击确定,如图3所示。 图3 新建MFC AppWizardexe工程将弹出MFC AppWizard-step 1对话框,选择基本对话框,点击完成,如图4所示。图4 基本对话框这样,MFC AppWizard就建立了一个基于对话窗口的程序框架,如图5所示。图5 新建的对话框四、 界面设计1、创建控件在图5所示的Resoure View选项卡中打开Dialog资源组,双击IDD_CALCULATOR_DIALOG,在右边的窗口中显示出待编辑的对话框。开始摆放控件,包括编辑框和按钮的创建。按钮的创建以“1”为例进行介绍,其他按钮的创建可参照此进行操作。
3、1)在图5中Controls的“编辑框”按钮上单击鼠标左键,在对话框编辑窗口上合适的位置按下鼠标左键并拖动鼠标画出一个大小合适的编辑框。在编辑框上单击鼠标右键,在弹出的快捷莱单中选择属性选项,此时弹出Edit属性对话框,如图6所示,在该对话框中输入ID属性。 图6 Edit属性对话框2)在图3中Controls的“Button”按钮上单击鼠标左键,在对话框上的合适的位置上按下鼠标左键并拖动鼠标画出一个大小合适的下压式按钮。在按钮上单击鼠标右键,在弹出的快捷菜单中选择属性选项,此时也弹出Push Button属性对话框,如图7所示,在该对话框中输入控件的ID值和标题属性。图7 Push Butt
4、on属性按照上面的操作过程编辑其他按钮和编辑框等对象的属性。表1 各按钮和编辑框等对象的属性对象ID标题或说明编辑框IDC_DC_EDIT_INPUT结果显示按钮IDC_BUTTON11按钮IDC_BUTTON22按钮IDC_BUTTON33按钮IDC_BUTTON44按钮IDC_BUTTON55按钮IDC_BUTTON66按钮IDC_BUTTON77按钮IDC_BUTTON88按钮IDC_BUTTON99按钮IDC_BUTTON100按钮IDC_BUTTON11.按钮IDC_BUTTON12空格按钮IDC_BUTTON23-按钮IDC_BUTTON26*按钮IDC_BUTTON27/按钮ID
5、C_BUTTON38sqrt按钮IDC_BUTTON30%按钮IDC_BUTTON25按钮IDC_BUTTON31sin按钮IDC_BUTTON32cos按钮IDC_BUTTON33tan按钮IDC_BUTTON34cot按钮IDC_BUTTON40sin1按钮IDC_BUTTON41cos1按钮IDC_BUTTON35log按钮IDC_BUTTON36ln按钮IDC_BUTTON14a按钮IDC_BUTTON15b按钮IDC_BUTTON16c按钮IDC_BUTTON17d按钮IDC_BUTTON18e按钮IDC_BUTTON19f按钮IDC_BUTTON13退格按钮IDC_BUTTON37
6、e按钮IDC_BUTTON22清空按钮IDOK计算按钮IDC_RADIO_DEGREE角度按钮IDC_RADIO_RADIAN弧度按钮IDC_STATIC计算结果按钮IDC_BTN_HISTREXP历史表达式按钮IDCANCEL退出按钮IDC_BTN_CONVERT进制完成后界面如图8所示。图8 计算器界面五、计算器源程序代码; else if(decimal16) for(int i=();idecimal;i+) str+=0; str+=.0; else for(int i=0;i-decimal;i+) (0,0); (0,.); if(sign=1) (0,-); return st
7、r;double CCalculation:StoN(CString str) char *stopstring; double x; x = strtod( (0), &stopstring ); m_strTmp=stopstring; return x;CString CCalculation:TwoE(CString strExp) double x2,y,x1=StoN(strExp); strExp=m_strTmp; char op=(0); (0); x2=StoN(strExp); if(m_strTmp!=) return ERROR_+m_strTmp+未知符号_; if
8、(op=+) y=x1+x2; else if(op=*) y=x1*x2; else if(op=-) y=x1-x2; else if(op=) y=pow(x1,x2); else if(op=/) y=x1/x2; else if(op=%) y=fmod(x1,x2); else return ERROR_+m_strTmp+未知运算符_; return NtoS(y);CString CCalculation:SingleE(CString op,double dx) if(op=ln) return NtoS(log(dx); else if(op=log) return Nto
9、S(log10(dx); else if(op=sqr) return NtoS(sqrt(dx); else if(op=e) return NtoS(exp(dx); else if(op=abs) return NtoS(fabs(dx); else if(op=ac) return NtoS(acos(dx); else if(op=as) return NtoS(asin(dx); else if(op=at) return NtoS(atan(dx); if(m_bDegree) dx=dx*PI/180; if(op=tan) return NtoS(tan(dx); else
10、if(op=sin) return NtoS(sin(dx); else if(op=cos) return NtoS(cos(dx); else if(op=cot) return NtoS(1/tan(dx); else if(op=sh) return NtoS(sinh(dx); else if(op=ch) return NtoS(cosh(dx); else if(op=th) return NtoS(sinh(dx)/cosh(dx); else if(op=exp) return NtoS(pow(10,dx); return ERROR+op+_未知函数_;int CCalc
11、ulation:LocateLBra(CString strExp) int len=(); int pos=-1; for(int i=0;i=0 & (i)=) break; if(i)=() pos=i; return pos;void CCalculation:DelBracket(CString *strExp) int pos=LocateLBra(*strExp); int i,len=strExp-GetLength(); if(pos=-1) *strExp=ERROR_无效表达式_;return; for(i=pos;iGetAt(i)=) break; CString s
12、tr; str=strExp-Mid(pos+1,i-pos-1); MultiE(&str); strExp-Delete(pos,i-pos+1); strExp-Insert(pos,str);void CCalculation:MultiE(CString *strExp) if(strExp-IsEmpty() *strExp=ERROR_函数表达式为空_; if(IsDigital(*strExp) return; while(1)/*处理所有的一元运算*/ for(int i=0;iFind(opti); if(pos!=-1) CString str=strExp-Right(
13、strExp-GetLength()-pos-opti.GetLength(); double dx=StoN(str); if(m_strTmp=str) *strExp=ERROR+str+_无法识别的函数_;return; strExp-Delete(pos,strExp-GetLength()-pos); *strExp+=SingleE(opti,dx)+m_strTmp; MinusMinus(strExp); if(pos=1) char ch=strExp-GetAt(pos-1); if(ch=48 & chGetAt(pos+1)=- | pos0) if(strExp-G
14、etAt(pos+1)=+) strExp-Delete(pos+1); pos=0; continue; /*处理连减(如:-1)的情况*/ int nCount=0; while(1) if(+pos0) if(strExp-GetAt(pos)!=-) break; else nCount+; else break; if(nCount0) strExp-Delete(pos-nCount-1,nCount+1); if(nCount%2=0) strExp-Insert(pos-nCount-1,-); else if(pos-nCount-10) strExp-Insert(pos-
15、nCount-1,+); pos=0; continue; else pos-; /*/ if(pos0 & strExp-GetAt(pos-1)=+) pos+; continue; Calcu(strExp,pos); else pos+; pos=0; while(1) pos=strExp-Find(+);ind(+); if(pos=-1) break;etLength(); strExp-Insert(pos,m_strConValuei); if(pos=1) char ch=strExp-GetAt(pos-1); if(ch=48 & chFind(m_strConName
16、i); CString CCalculation:ModiResult(CString strRes) if(#IN)!=-1) return 结果有溢出或值域越界; /*去掉保护括号*/ if(0)=() (0); if()-1)=) ()-1); /*/ int pos=(.);CString str=; if(pos!=-1) if(pos=0) strRes=0+strRes; else if(0)=- & (1)=.) (1,0); if(pos16) (pos); (1,.); (%d,pos-1); str= E+str; pos=(.); if(pos=0 | pos=1 &
17、(0)=0) for(int i=pos+1;i4) ( E-%d,i-2); (pos,i-1); (1,.); strRes=(pos+16)+str; if(pos!=-1) strDF=()-pos-1); (pos,()-pos); (); len=(); for(i=0;ilen;i+) ch=(i); dx+=(ch-48)*pow(8,i); len=(); for(i=0;iInsert(index+1,strTmp); pos=strExp-Find(xo); void CCalculation:Hex2Dec(CString *strExp) int len,i,inde
18、x,pos=strExp-Find(xh); CString strTmp,strDF; char ch; double dx; while(pos!=-1) dx=0;strTmp=;strDF=; strExp-Delete(pos,2); for(i=pos-1;i=0;i-) ch=strExp-GetAt(i); if(ch=48 & ch=97 & chMid(i,1); strExp-Delete(i); else break; if(i=pos-1) *strExp=ERROR_缺少二元运算符_;return; index=i; pos=0; for(i=0;i1) *strE
19、xp=ERROR_缺少二元运算符_;return; pos=(.); if(pos!=-1) strDF=()-pos-1); (pos,()-pos); (); len=(); for(i=0;i=48 & ch=57); if(pos!=-1) strDF=()-pos-1); (pos,()-pos); (); len=(); for(i=0;ilen;i+) ch=(i); dx+=(ch-48)*pow(2,i); len=(); for(i=0;iInsert(index+1,strTmp); pos=strExp-Find(xb); void CCalculation:Dec2H
20、ex(CString *strExp/*strExp须为数字*/) bool bMinus=0; if(strExp-GetAt(0)=-) bMinus=1; strExp-Delete(0); int pos=strExp-Find(.); CString str,strDec; int nDecInt; double dDec; if(pos!=-1) strDec=strExp-Left(pos); nDecInt=atoi(0); strDec=strExp-Right(strExp-GetLength()-pos); else nDecInt=atoi(strExp-GetBuff
21、er(0); strExp-Empty(); while(nDecInt!=0) int nTmp=nDecInt%16; if(nTmp=10) str=a; else if(nTmp=11) str=b; else if(nTmp=12) str=c; else if(nTmp=13) str=d; else if(nTmp=14) str=e; else if(nTmp=15) str=f; else (%d,nTmp); nDecInt/=16; strExp-Insert(0,str); *strExp+=.; if(pos!=-1) dDec=StoN(strDec); int n
22、Count=0; while(dDec!=0) dDec*=16; int nTmp=dDec; if(nTmp=10) str=a; else if(nTmp=11) str=b; else if(nTmp=12) str=c; else if(nTmp=13) str=d; else if(nTmp=14) str=e; else if(nTmp=15) str=f; else (%d,nTmp); *strExp+=(pos); dDec-=nTmp; if(+nCount=17) break; if(bMinus) strExp-Insert(0,-); if(strExp-Find(
23、-1)!=-1 & bMinus!=1) *strExp=太大无法表示;void CCalculation:Dec2Oct(CString *strExp) bool bMinus=0; if(strExp-GetAt(0)=-) bMinus=1; strExp-Delete(0); int pos=strExp-Find(.); CString str,strDec; int nDecInt; double dDec; if(pos!=-1) strDec=strExp-Left(pos); nDecInt=atoi(0); strDec=strExp-Right(strExp-GetLength()-pos); else nDecInt=atoi(strExp-GetBuffer(0); strExp-Empty(); while(nDecInt!=0) int nTmp=nDecInt%8; (%d,nTmp); nDecInt
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1