在 MFC(Microsoft Foundation Classes)中,CDialog 类提供了一个重要的公共方法 DoModal,用于在应用程序中创建并显示模态对话框。DoModal 方法会使程序在对话框打开期间暂停,直到用户关闭对话框为止。

以下是 CDialog 类的 DoModal 方法的声明:
INT_PTR DoModal();

DoModal 方法返回一个整数,表示对话框的返回代码。通常,返回代码为 IDOK 表示用户单击了对话框的 "OK" 按钮,而 IDCANCEL 表示用户单击了 "Cancel" 按钮。

以下是一个简单的示例,演示如何使用 DoModal 方法:
// MyDialog.h
#pragma once

#include "afxwin.h"

class CMyDialog : public CDialog
{
public:
    CMyDialog(CWnd* pParent = nullptr); // 默认构造函数

    // Dialog Data
    #ifdef AFX_DESIGN_TIME
        enum { IDD = IDD_MYDIALOG };
    #endif

protected:
    virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support

    // Implementation
protected:
    DECLARE_MESSAGE_MAP()
public:
    afx_msg void OnBnClickedOk();
    afx_msg void OnBnClickedCancel();
};

// MyDialog.cpp
#include "stdafx.h"
#include "MyDialog.h"

// CMyDialog 对话框

IMPLEMENT_DYNAMIC(CMyDialog, CDialog)

CMyDialog::CMyDialog(CWnd* pParent /*=nullptr*/)
    : CDialog(IDD_MYDIALOG, pParent)  // 使用对话框模板资源 ID 进行初始化
{
}

void CMyDialog::DoDataExchange(CDataExchange* pDX)
{
    CDialog::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CMyDialog, CDialog)
    ON_BN_CLICKED(IDOK, &CMyDialog::OnBnClickedOk)
    ON_BN_CLICKED(IDCANCEL, &CMyDialog::OnBnClickedCancel)
END_MESSAGE_MAP()

void CMyDialog::OnBnClickedOk()
{
    // TODO: 在此添加控件通知处理程序代码
    OnOK();
}

void CMyDialog::OnBnClickedCancel()
{
    // TODO: 在此添加控件通知处理程序代码
    OnCancel();
}

在这个示例中,CMyDialog 类使用默认构造函数,并在某个地方调用了 DoModal 方法。DoModal 方法会显示对话框,程序会在此处等待用户关闭对话框,然后返回相应的结果码。


转载请注明出处:http://www.zyzy.cn/article/detail/17319/MFC/CDialog