1.三个退出程序消息:WM_CLOSE WM_DESTROY WM_QUIT
WM_CLOSE:单击菜单栏得“关闭”按钮或者窗口的"X"号,窗口收到WM_CLOSE,DefWindowProc对 WM_CLOSE的处理是调用DestroyWindow。
WM_DESTROY:DestroyWindow完成窗口的清理工作,向窗口发送WM_DESTROY。对于 WM_DESTROY,DefWindowProc不会处理。也就是说,你如果不处理这个消息,虽然你的窗口已经销毁,但进程并不会结束。一般处理 WM_DESTROY时都是释放资源(例如申请的内存等),然后调用PostQuitMessage。
WM_QUIT:PostQuitMessage会发送WM_QUIT给消息队列。注意,WM_QUIT永远不会到达窗口过程,因为GetMessage得到WM_QUIT后就会返回FALSE,从而结束消息循环,最后进程结束,程序退出。
2.发送消息SendMessage、PostMessage
PostMessage将消息放入消息队列后马上返回,而SendMessage直到窗口过程处理完消息后才返回
3.CStatic组件
如果使用默认的ID(ID_STATIC),将不能添加变量,必须修改ID的名称(ID_STATIC1),这样就可以添加变量了
4.mfc Dialog程序中弹出控制台
打开Project -> Properties,在Build Events -> Post-Build Event里的Command Line中输入:
editbin /SUBSYSTEM:CONSOLE $(OUTDIR)\filename.exe
(其中filename.exe为可执行文件)
例如你的可执行文件名为 MFCApplication.exe,则你的Command
Line就为:
editbin /SUBSYSTEM:CONSOLE $(OUTDIR)\MFCApplication.e
5.光标定位到CEdit最后
CString strInfo;
m_Edit.GetWindowText(strInfo);
int nLength = strInfo.GetLength();
m_Edit.SetSel(nLength,nLength, FALSE);
m_Edit.SetFocus();
在CEdit里追加内容
CString strInfo;
m_Edit.GetWindowText(strInfo);
int nLength = strInfo.GetLength();
m_Edit.SetSel(nLength, nLength, FALSE);
m_Edit.ReplaceSel(str.c_str());
6.mfc中对单选按钮进行分组
每组的第一个单选按钮设置Group,Tabstop,Auto属性为true;其余按钮设置Tabstop,Auto属性为true。
Radio4,Radio5为一组
设定Radio4如下属性为true:Group,Tabstop,Auto
设定Radio5如下属性为true:Tabstop,Auto
为Radio4,Radio5一组添加关联变量,只需添加Radio4的关联变量,变量类型为int,变量值为0表示Radio4选中,值为1表示Radio5被选中
7.配置文件的保存与加载
// 配置文件的加载,并显示到界面上
OnInitDialog()
{
// 主对话框
m_var = m_confg.GetValue(); //m_confg.GetValue();是从配置文件中读取参数值,
//m_var为控件关联的值变量
UpdateData(FALSE); //将关联变量的值更新到界面上
// 子对话框,以page页为例,(m_page1)
m_page1.Create(IDD_PAGE1, GetDlgItem(IDC_TAB_PAGE));
m_page1.MoveWindow(rc);
m_page1.ShowWindow(SW_SHOW);
m_page1.m_var = m_confg.GetValue();
m_page1.UpdateData(FALSE);
}
// 将界面的参数值保存到配置文件中
OnClose() //关闭事件的回调函数
{
UpdateData(TRUE); //将界面上的参数值更新到关联变量中
m_confg.SetValue(m_var); //向配置文件中添加该参数值,此函数只是为了表明作用,具体函数需自己编写
//子对话框
m_page1.UpdateData(TRUE);
m_confg.SetValue(m_page1.m_var);
}
8.此处是自己疏忽造成的,以后需要注意
name一栏中的圆括号里面的是该控件的名称