visual c++打造简单加法计算器并实现更换颜色背景

开发环境:vs2013+.net 4.5

第一步新建mfc应用程序:

并设定项目名称,项目位置路径《visual c++打造简单加法计算器并实现更换颜色背景》

基于对话框《visual c++打造简单加法计算器并实现更换颜色背景》《visual c++打造简单加法计算器并实现更换颜色背景》

  • 添加控件,并添加变量
    《visual c++打造简单加法计算器并实现更换颜色背景》

定义三个整型变量:

CfastjsqDlg::CfastjsqDlg(CWnd* pParent /*=NULL*/)
: CDialogEx(CfastjsqDlg::IDD, pParent)
, m_n1(0)
, m_n2(0)
, m_n3(0)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME)
}
结果按钮:
void CfastjsqDlg::OnBnClickedButton1()
{
// TODO:  在此添加控件通知处理程序代码
UpdateData(true);
m_n3 = m_n2 + m_n1;
UpdateData(false);
}
清除按钮:
void CfastjsqDlg::OnBnClickedButton2()
{
// TODO:  在此添加控件通知处理程序代码
m_n1 = m_n2 = m_n3 = 0;
UpdateData(false);
}

简单计算器界面完成《visual c++打造简单加法计算器并实现更换颜色背景》

  • 添加控件,并添加变量,实现背景颜色

1、简单通过定义矩形进行默认颜色更换

void CfastjsqDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 使图标在工作区矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CRect rect;  //定义矩形
GetClientRect(rect);//得到客户端的矩形选区
CPaintDC dc(this);//定义画笔
dc.FillSolidRect(rect, RGB(2, 222, 255));//设置对话框和颜色
CDialogEx::OnPaint();
}
}

《visual c++打造简单加法计算器并实现更换颜色背景》

2、通过添加按钮调用进行默认颜色更换
《visual c++打造简单加法计算器并实现更换颜色背景》

头文件中定义r.,g,b

public:
int m_n1;
int m_n2;
int m_n3;
int r;
int g;
int b;
afx_msg void OnBnClickedButton1();
afx_msg void OnBnClickedButton2();
afx_msg void OnBnClickedButton3();
};
在绘OnPaint中定义矩形改性rgb函数变换
void CfastjsqDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 使图标在工作区矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CRect rect;
GetClientRect(rect);
CPaintDC dc(this);
dc.FillSolidRect(rect, RGB(r, g, b));    //给背景添加色
CDialog::OnPaint();
}
}
变换颜色按钮添加代码
void CfastjsqDlg::OnBnClickedButton3()
{
r = rand() % 256;
g = rand() % 256;
b = rand() % 256;
Invalidate();    //强制重新回执视图
// TODO:  在此添加控件通知处理程序代码
}

《visual c++打造简单加法计算器并实现更换颜色背景》
3.画板变色按钮功能的实现
添加按钮 换色板
双击加入代码

void CfastjsqDlg::OnBnClickedButton4()
{
// TODO:  在此添加控件通知处理程序代码
CColorDialog dlg;
if (dlg.DoModal() == IDOK) {
COLORREF color = dlg.GetColor();
r = GetRValue(color);
g = GetGValue(color);
b = GetBValue(color);
Invalidate();
}
}

 《visual c++打造简单加法计算器并实现更换颜色背景》

3.定时器功能的实现

加入按钮定时器,关闭定时器《visual c++打造简单加法计算器并实现更换颜色背景》

选择界面,点击属性,在点击消息给整个程序框添加VM_TIMER

加入代码

void CfastjsqDlg::OnTimer(UINT_PTR nIDEvent)
{
// TODO:  在此添加消息处理程序代码和/或调用默认值
if (nIDEvent == 1) {
r = rand() % 256;
g = rand() % 256;
b = rand() % 256;
Invalidate();
}
CDialogEx::OnTimer(nIDEvent);
}
双击定时器按钮
void CfastjsqDlg::OnBnClickedButton5()
{
SetTimer(1, 600, NULL);
// TODO:  在此添加控件通知处理程序代码
}
双击关闭定时器按钮
void CfastjsqDlg::OnBnClickedButton6()
{
// TODO:  在此添加控件通知处理程序代码
KillTimer(1);
}

 《visual c++打造简单加法计算器并实现更换颜色背景》 《visual c++打造简单加法计算器并实现更换颜色背景》

4.切换背景按钮功能的实现

在解决方案中头文件里

在public:下定义三个参数分别是

CBitmap m_Bmp;
CBrush m_Brush;
bool B;
初始化函数
m_Bmp.LoadBitmap(IDB_BITMAP1);        //b)中导入的图片在项目中的名称
m_Brush.CreatePatternBrush(&m_Bmp);
B = true;

右键单机资源文件,添加->资源
选择Bitmap点击引入,选择要加入的图片,图片的格式为BMP格式
《visual c++打造简单加法计算器并实现更换颜色背景》
图片引入后的默认名称为:IDB_BITMAP1
选择主窗体点击属性,Message选项选择WM_CTLCOLOR,键入代码

HBRUSH CfastjsqDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
{
HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor);
// TODO:  在此更改 DC 的任何特性
return m_Brush;
// TODO:  如果默认的不是所需画笔,则返回另一个画笔
return hbr;
}
在初始界面,双击切换背景按钮,编写按钮响应事件函数,键入以下代码:
void CfastjsqDlg::OnBnClickedButton7()
{
if (B) {
B = false;
}
else {
B = true;
}
Invalidate();
// TODO:  在此添加控件通知处理程序代码
}
定义颜色
{
CRect rect;
GetClientRect(rect);
CPaintDC dc(this);
if (!B)
dc.FillSolidRect(rect, RGB(r, g, b));    //给背景添加色
CDialog::OnPaint();
}

《visual c++打造简单加法计算器并实现更换颜色背景》

点赞