您的位置:首页 > 健康 > 养生 > Windows图形界面(GUI)-MFC-C/C++ - MFC项目工程框架解析

Windows图形界面(GUI)-MFC-C/C++ - MFC项目工程框架解析

2024/10/7 4:27:41 来源:https://blog.csdn.net/2301_80612536/article/details/140617044  浏览:    关键词:Windows图形界面(GUI)-MFC-C/C++ - MFC项目工程框架解析
  • 公开视频 -> 链接点击跳转公开课程
  • 博客首页 -> e​​​​​​链接点击跳转博客主页

目录

MFC项目

项目选择

配置安装

程序引导

MFC框架

环境设置

程序框架

代码编写

MFC解析

程序入口

执行流程

代码结构

应用程序类

窗口框架类

消息处理

消息类型

消息处理

处理机制


MFC项目

项目选择

配置安装

程序引导

MFC框架

环境设置

  • 创建空项目
  • 源文件必须设置为CPP格式后缀
  • 链接器 - 系统 - 设置窗口
  • 配置属性 - 高级 - 设置MFC使用
程序框架
  • MFC头文件
  • 应用程序对象
    • MFC应用程序是基于CWinApp类(应用程序对象)。
    • CWinApp提供了消息循环来检索消息并将消息调度给应用程序的窗口。
    • MFC程序有且只能有一个应用程序对象,对象必须声明在全局范围内有效。
  • CWinApp::InitInstance
    • InitInstance是CWinApp中的虚函数,默认执行操作为返回真,通过返回值决定程序是否正常执行。
    • InitInstance目的是为应用程序提供一个初始化的入口。
代码编写
#include <afxwin.h>class CMyApp : public CWinApp
{
public:virtual BOOL InitInstance();
};class CMainWindow : public CFrameWnd
{
public:CMainWindow();
};CMyApp myApp;BOOL CMyApp::InitInstance()
{m_pMainWnd = new CMainWindow;m_pMainWnd->ShowWindow(m_nCmdShow);m_pMainWnd->UpdateWindow();return TRUE;
}CMainWindow::CMainWindow()
{Create(NULL, _T("The Hello Application"));
}

MFC解析

程序入口
  • 控制台程序 - main
  • 动态链接库 - DllMain
  • 应用程序类 - WinMain
  • 驱动程序类 - DriverEntry
  • MFC - AfxWinMain
执行流程

  • 全局应用程序类对象实例化初始。
  • 通过afxWinMain完成初始化(InitInstance)。
  • InitInstance中创建窗口类对象触发构成函数完成窗口创建。
  • 创建窗口成功后将数据保存在m_pMainWndz。
  • 通过窗口类显示以及更新窗口。
代码结构

  • 应用程序类
    • 每个MFC应用程序都必须至少有一个派生自CWinApp的类的实例,该实例代表了应用程序本身。
    • CWinApp类处理应用程序的启动、初始化、运行和退出。
    • InitInstance(): 这是一个必须由派生类重写的虚拟函数。它在应用程序启动时被自动调用,并且是初始化应用程序的主要函数。
    • Run(): 开始应用程序的消息循环。
    • ExitInstance(): 在应用程序退出前被调用,用于清理资源。
    • m_pMainWnd: 指向应用程序的主窗口的指针。
  • 窗口框架类
    • CFrameWnd类代表了一个标准的窗口框架,包括标题栏、菜单栏、工具栏以及状态栏等。
    • 在MFC中,大多数应用程序的主窗口都是从CFrameWnd类派生出来的。
    • LoadFrame(): 根据资源ID加载窗口框架并初始化。
    • Create(): 手动创建窗口框架。
    • PreCreateWindow(): 在窗口创建之前调用,可以修改窗口创建的样式。
    • OnCreate(): 在窗口创建时调用,可以在此添加额外的初始化代码,如创建工具栏和状态栏。
消息处理

  • 消息类型
    • 窗口消息(Window Messages):如WM_LBUTTONDOWNWM_KEYDOWN等,通常由窗口过程处理。

    • 命令消息(Command Messages):如菜单项、工具栏按钮的点击,消息ID以WM_COMMAND形式出现。

    • 控件通知消息(Control Notification Messages):如按钮点击、列表框选择等,通常由父窗口处理。

    • 自定义消息:开发者可以定义自己的消息,并使用SendMessagePostMessage发送。

  • 消息处理
    • MFC的消息处理机制是基于消息映射(Message Map)的,它允许开发者将特定的Windows消息映射到特定的成员函数(称为消息处理函数)上。

  • 处理机制
    • DECLARE_MESSAGE_MAP是一个宏,它必须在MFC类的头文件中声明,以便MFC框架能够识别该类具有消息映射。

    • BEGIN_MESSAGE_MAPEND_MESSAGE_MAP宏来定义消息映射。

      • BEGIN_MESSAGE_MAP宏接受两个参数:当前类的名称和基类的名称。

      • END_MESSAGE_MAP宏标记消息映射的结束。

  • 代码示例
  • #include <afxwin.h>class CMyApp : public CWinApp
    {
    public:virtual BOOL InitInstance();
    };class CMainWindow : public CFrameWnd
    {
    public:CMainWindow();DECLARE_MESSAGE_MAP()afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
    };CMyApp myApp;BOOL CMyApp::InitInstance()
    {m_pMainWnd = new CMainWindow;m_pMainWnd->ShowWindow(m_nCmdShow);m_pMainWnd->UpdateWindow();return TRUE;
    }CMainWindow::CMainWindow()
    {Create(NULL, _T("0xCC"));
    }BEGIN_MESSAGE_MAP(CMainWindow, CFrameWnd)ON_WM_LBUTTONDOWN()
    END_MESSAGE_MAP()void CMainWindow::OnLButtonDown(UINT nFlags, CPoint point)
    {// TODO: 在此添加消息处理程序代码和/或调用默认值}
    

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com