创建一个MFC程序
第一步 依此点击文件->新建->项目->点击MFC应用程序
第二步 如下图->基于对话框->点击完成
第三步 在右下角资源管理器中可看到项目中的文件
第四步 点击执行,生成如下
MFC中类的关系
在ReadMe.txt中,说明了各个文件的作用
MFC执行流程如下
- 首先创建一个名为test的MFC工程则在源文件目录会产生一个test.cpp文件。在test.cpp中CtestApp类会产生一个theApp的全局对象
- MFC中的WinMain调用函数AfxWinMain
- MFC作了一个"乾坤大挪移",将WinMain函数的全部责任转移交给了MFC程序的入口点函数—AfxWinMain
- 初始化运行test.cpp中的InitInstance()函数BOOL CtestApp::InitInstance()
或更高版本来启用可视化方式, //则需要 InitCommonControlsEx()。 否则,将无法创建窗口。
INITCOMMONCONTROLSEX InitCtrls; InitCtrls.dwSize =
sizeof(InitCtrls); // 将它设置为包括所有要在应用程序中使用的 // 公共控件类。 InitCtrls.dwICC
= ICC_WIN95_CLASSES; InitCommonControlsEx(&InitCtrls);
CWinApp::InitInstance();
AfxEnableControlContainer();
// 创建 shell 管理器,以防对话框包含 // 任何 shell 树视图控件或 shell 列表视图控件。
CShellManager *pShellManager = new CShellManager;
// 激活“Windows Native”视觉管理器,以便在 MFC 控件中启用主题
CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows));
// 标准初始化 // 如果未使用这些功能并希望减小 // 最终可执行文件的大小,则应移除下列 // 不需要的特定初始化例程 //
更改用于存储设置的注册表项 // TODO: 应适当修改该字符串, // 例如修改为公司或组织名
SetRegistryKey(_T("应用程序向导生成的本地应用程序"));
CtestDlg dlg; m_pMainWnd = &dlg; INT_PTR nResponse = dlg.DoModal();
if (nResponse == IDOK) { // TODO: 在此放置处理何时用 // “确定”来关闭对话框的代码 }
else if (nResponse == IDCANCEL) { // TODO: 在此放置处理何时用 //
“取消”来关闭对话框的代码 } else if (nResponse == -1) { TRACE(traceAppMsg, 0,
"警告: 对话框创建失败,应用程序将意外终止。\n"); TRACE(traceAppMsg, 0, "警告: 如果您在对话框上使用
MFC 控件,则无法 #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS。\n"); }
// 删除上面创建的 shell 管理器。 if (pShellManager != NULL) { delete
pShellManager; }
// 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序, // 而不是启动应用程序的消息泵。 return FALSE;
} ```