MFC实现简单计算器

在VS2013环境下用MFC实现一个简单的计算器,主要是为了熟悉MFC编辑框的使用和消息传递机制。

实现步骤:

1、在工具箱托两个Edit control,一个显示可见,另一个不可见(用于保存操作数),分别为其添加CString类型的变量m_str1,m_str2

2、添加button按钮,分别表示0—9,左击添加响应处理函数

void Cdemo2Dlg::OnBnClickedButton1()
{
 if (flag == 0)
 {
 UpdateData(TRUE);
 m_str += "1";
 m_str2 += "1";
 UpdateData(FALSE);
 }
 else
 {
 UpdateData(TRUE);
 m_str = "";
 m_str2 = "";
 m_str += "1";
 m_str2 += "1";
 flag = 0;
 UpdateData(FALSE);
 }
}

其它按钮类似,再添加“+”、“-”、“*”、“/”按钮和对应的响应处理函数

void Cdemo2Dlg::OnBnClickedButtonjia()
{
 UpdateData(TRUE);
 m_str += "+";
 UpdateData(FALSE);
 SaveValue1();
 m_iSign = 0;
}

添加计算按钮和响应函数

void Cdemo2Dlg::Calculator()
{
 UpdateData(TRUE);
 m_fNumber2 = _tstof(m_str2);
 double f = 0.0f;
 switch (m_iSign)
 {
 //加
 case 0:
 f = m_fNumber1 + m_fNumber2;
 break;
 //减
 case 1:
 f = m_fNumber1 - m_fNumber2;
 break;
 //乘
 case 2:
 f = m_fNumber1 * m_fNumber2;
 break;
 //除
 case 3:
 if (m_fNumber2 == 0.0f)
 {
 f = m_fNumber1;
 }
 else
 {
 f = m_fNumber1 / m_fNumber2;
 }
 break;
 case 4:
 f = m_fNumber1*m_fNumber1;
 break;
 default:
 break;
 }
 //如果浮点数其实是个整数
 if (f - int(f) <= 1e-5)
 {

 m_str2.Format(_T("%d"), (int)f);
 m_str2 += " ";
 m_str += "=";
 m_str += m_str2;

 }
 else
 {
 m_str2.Format(_T("%f"), f);
 m_str2 += " ";
 m_str += "=";
 m_str += m_str2;
 }
 UpdateData(FALSE);
 m_fNumber1 = 0.0f;
 m_fNumber2 = 0.0f;
 flag = 1; //设置flag标志,当计算一次后,将之前的计算结果覆盖掉
}

3、添加清除、退后、退出和关于按钮及其响应处理函数

void Cdemo2Dlg::OnBnClickedCancel()
{
 CDialogEx::OnCancel();
}
void Cdemo2Dlg::OnBnClickedButtonback()
{
 UpdateData(TRUE);
 //移除最右边一个字符
 if (!m_str.IsEmpty())
 {
 m_str = m_str.Left(m_str.GetLength() - 1);
 m_str2 = m_str2.Left(m_str2.GetLength() - 1);
 }
 UpdateData(FALSE);
}
void Cdemo2Dlg::OnBnClickedButtonclear()
{
 UpdateData(TRUE);
 m_str = "";
 m_fNumber1 = 0.0f;
 m_fNumber2 = 0.0f;
 m_iSign = 0;
 UpdateData(FALSE);
}
void Cdemo2Dlg::OnBnClickedButtonabout()
{
 CAboutDlg dlg;
 dlg.DoModal();
}

4、添加时间显示框

先在BOOL Cdemo2Dlg::OnInitDialog()函数中添加代码

CString strTime;
 CTime tm;
 tm = CTime::GetCurrentTime();  //获取当前系统时间
 strTime = tm.Format("%y年%m月%d日 %X"); //格式化系统时间。即使系统时 间按照Format中设置的格式显示
 SetDlgItemText(IDC_TIME, strTime); //初始化编辑框显示
 SetTimer(1, 1000, NULL);  //启动定时器

消息处理函数为:

void Cdemo2Dlg::OnTimer(UINT_PTR nIDEvent)
{
 // TODO: 在此添加消息处理程序代码和/或调用默认值
 CString strTime;
 CTime tm;
 tm = CTime::GetCurrentTime();
 strTime = tm.Format("%Y-%m-%d %H:%M:%S");
 SetDlgItemText(IDC_TIME, strTime); //显示系统时间
 CDialogEx::OnTimer(nIDEvent);
}

5、效果图如下所示,貌似有点难看~

在实现的过程中遇到的问题:

1、将CString转换为double类型

一开始上网查资料用的是atof()函数,报错提示为不存在CString转换为const char *的适当转换函数,后修改为m_fNumber1 = atof((LPSTR)(LPCTSTR)m_str2);,不报错,但是运行发现四则运算时只能运算第一位,例如55+91=14,后来又查了资料,解释是“在Unicode下一个字符占两个字符,CString中一个字符占两个字符,而atof函数对字符串的处理是一个字符占一个字节的,所以不能直接调用该函数,改用_tstof函数”,果然奏效。

2、如何在进行第二次运算时覆盖掉第一次的运算结果,自己想了个方法,但是貌似比较繁琐,就是设置一个标志位flag,初始状态下为0,当进行一次运算后改为1,第二次点击0-9按钮时,加一个if语句判断,代码如下

void Cdemo2Dlg::OnBnClickedButton9()
{
 if (flag == 0)
 {
 UpdateData(TRUE);
 m_str += "9";
 m_str2 += "9";
 UpdateData(FALSE);
 }
 else
 {
 UpdateData(TRUE);
 m_str = "";
 m_str2 = "";
 m_str += "9";
 m_str2 += "9";
 flag = 0;
 UpdateData(FALSE);
 }
}

3、UpdateData(TRUE)和UpdateData(FALSE)的区别

UpdateDate(TRUE):刷新控件的值到对应的变量(外部输入值交给内部变量),即将控件的值->变量。

UpdateData(FALSE):拷贝变量值到控件显示,变量的最终运算结果值交给外部输出显示,即将变量值->控件显示

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • mfc入门教程之实现一个简单的计算器

    mfc学习之前的了解 什么是mfc? MFC是微软基础类的缩写(Microsoft Foundation Classes),是一个庞大的类库,可以理解为一种在Windows上开发软件的架构,是微软专为Visual C++定制的.该类库提供一组通用的可重用的类库供开发人员使用. 没有MFC之前,Windows上用Win32 API进行编程,之后MFC出现,在一定程度上提高了软件开发效率,它是对win32 API的封装,所以易用性好,不过性能会比win32开发低一些,二者各有所长. 在Windows

  • mfc入门教程之通过控制变量制作计算器

    mfc学习之前的了解 什么是mfc? MFC是微软基础类的缩写(Microsoft Foundation Classes),是一个庞大的类库,可以理解为一种在Windows上开发软件的架构,是微软专为Visual C++定制的.该类库提供一组通用的可重用的类库供开发人员使用. 没有MFC之前,Windows上用Win32 API进行编程,之后MFC出现,在一定程度上提高了软件开发效率,它是对win32 API的封装,所以易用性好,不过性能会比win32开发低一些,二者各有所长. 在Windows

  • MFC实现简单计算器

    在VS2013环境下用MFC实现一个简单的计算器,主要是为了熟悉MFC编辑框的使用和消息传递机制. 实现步骤: 1.在工具箱托两个Edit control,一个显示可见,另一个不可见(用于保存操作数),分别为其添加CString类型的变量m_str1,m_str2 2.添加button按钮,分别表示0-9,左击添加响应处理函数 void Cdemo2Dlg::OnBnClickedButton1() { if (flag == 0) { UpdateData(TRUE); m_str += "1

  • js的表单操作 简单计算器

    代码: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv

  • php学习之简单计算器实现代码

    复制代码 代码如下: <html> <head> <title>PHP实现简单计算器</title> <meta http-equiv="Content-Type" content="text/html;charset=gb2312"> </head> <?php //单路分支 if(isset($_GET["sub"])) { $num1=true;//数字1是否为空

  • javascript实现简单计算器效果【推荐】

    最终效果如下图-2,有bug:就是整数后点击%号结果正确,如果小数后面点击%的话结果就错误!其他都正常,求指点:input的value是string类型的,在JS中改如何正确处理下图-1中的if部分?? 图-1 图-2 HTML代码如下 <body> <div id="calculator"> <div class="LOGO"> <span class="name">简单的计算器</span

  • 纯js代码实现简单计算器

    本文实例分享了纯js代码实现简单计算器代码,相信大家会喜欢.具体如下: 运行效果截图如下: 具体代码如下: <!DOCTYPE html> <html> <head> <title> new document </title> <script type="text/javascript"> function count(){ var txt1 = parseInt( document.getElementById(

  • 基于JSP实现一个简单计算器的方法

    本文实例讲述了基于JSP实现一个简单计算器的方法.分享给大家供大家参考.具体实现方法如下: index.jsp 复制代码 代码如下: <%@ page language="java" import="java.util.*" pageEncoding="GB18030"%>  <%  String path = request.getContextPath();  String basePath = request.getSch

  • javascript简单计算器 可美化

    JS计算器代码: javascript简单计算器 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 说明: JavaScript eval() 函数 定义和用法 eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码. 返回值 通过计算 string 得到的值(如果有的话). 说明 该方法只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回.因此请不要为 eval() 函数传递 String 对象来作为参数. 如果试图

  • 使用JavaScript 编写简单计算器

    本文方法超级简单,思路非常的值得推荐,小伙伴们参考下吧 复制代码 代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />      <title>javascript 简单计算器</title>     <script>     

  • Javascript 实现简单计算器实例代码

    效果图: 刚开始做时没考虑到清零和退格两个功能,嘻嘻,后来加的整体与传统计算器比有点小瑕疵. 代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>js简单计算器</title> <style type="text/css"> *{ margin:0px; padding:0px; } input{ margi

  • 基于javascript实现简单计算器功能

    本文实例为大家介绍javascript实现简单计算器功能的详细代码,分享给大家供大家参考,具体内容如下 效果图: 实现代码: <html> <head> <script> function calc(event){ // test //window.alert(event.value); var val = new String(event.value); // clear space val = val.trim(); var res = document.getEl

随机推荐