1

我创建了一个简单的 MFC appwizard 对话框项目。我使用类向导创建了一个基于 CDialog 的名为 CMyDlg 的新类。然后我进入消息映射屏幕并双击 WM_INITDIALOG 条目以自动创建 CMyDlg::OnInitDialog() 处理程序。

我遇到的问题是 CMyDlg::OnInitDialog() 不会调用。我在那里放了一个断点,它根本不会调用。父对话框的 OnInitDialog() 方法被调用,但它不会调用 CMyDlg::OnInitDialog() 方法。

有什么特别需要做的吗?

我已经设法实现了一种解决方法,即从父对话框的 OnInitDialog() 方法发送我自己的消息并在 CMyDlg 中处理它但是..我确定这不是这样做的方法..

// MyDlg.cpp : implementation file
//

#include "stdafx.h"
#include "DeriveDlgTest.h"
#include "MyDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CMyDlg dialog

CMyDlg::CMyDlg( UINT nIDTemplate, CWnd* pParent /*=NULL*/)
    : CDialog(nIDTemplate, pParent)
{
  // PDS: THIS GETS CALLED
}

CMyDlg::CMyDlg(CWnd* pParent /*=NULL*/)
    : CDialog(CMyDlg::IDD, pParent)
{
    //{{AFX_DATA_INIT(CMyDlg)
        // NOTE: the ClassWizard will add member initialization here
    //}}AFX_DATA_INIT
}


void CMyDlg::DoDataExchange(CDataExchange* pDX)
{
    CDialog::DoDataExchange(pDX);
    //{{AFX_DATA_MAP(CMyDlg)
        // NOTE: the ClassWizard will add DDX and DDV calls here
    //}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CMyDlg, CDialog)
    //{{AFX_MSG_MAP(CMyDlg)
    //}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMyDlg message handlers

BOOL CMyDlg::OnInitDialog() 
{
  // PDS: THIS DOES NOT GET CALLED
    CDialog::OnInitDialog();


    return TRUE;  // return TRUE unless you set the focus to a control
                  // EXCEPTION: OCX Property Pages should return FALSE
}


#if !defined(AFX_MYDLG_H__ECC7F6AC_FEB3_419D_AFE2_6B6DE8196D74__INCLUDED_)
#define AFX_MYDLG_H__ECC7F6AC_FEB3_419D_AFE2_6B6DE8196D74__INCLUDED_

#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
// MyDlg.h : header file
//

/////////////////////////////////////////////////////////////////////////////
// CMyDlg dialog

class CMyDlg : public CDialog
{
// Construction
public:
    CMyDlg(CWnd* pParent = NULL);   // standard constructor
  CMyDlg( UINT nIDTemplate, CWnd* pParent = NULL);   // standard constructor
// Dialog Data
    //{{AFX_DATA(CMyDlg)
    enum { IDD = IDD_DERIVEDLGTEST_DIALOG };
        // NOTE: the ClassWizard will add data members here
    //}}AFX_DATA


// Overrides
    // ClassWizard generated virtual function overrides
    //{{AFX_VIRTUAL(CMyDlg)
    protected:
    virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
    //}}AFX_VIRTUAL

// Implementation
protected:

    // Generated message map functions
    //{{AFX_MSG(CMyDlg)
    virtual BOOL OnInitDialog();
    //}}AFX_MSG
    DECLARE_MESSAGE_MAP()
};

//{{AFX_INSERT_LOCATION}}
// Microsoft Visual C++ will insert additional declarations immediately before the previous line.

#endif // !defined(AFX_MYDLG_H__ECC7F6AC_FEB3_419D_AFE2_6B6DE8196D74__INCLUDED_)

多谢你们。我已将虚拟项目上传到下面的链接。尝试构建项目,您会发现 CMyDlg::OnInitDialog() 从未被调用。

我按照上面的建议删除了 IDD 枚举和构造函数,但它根本没有任何区别。没有CMyDlg dlg;dlg.DoModal() 调用作为主对话框本身,它从 CMyDlg 派生,而不是通常的 CDialog 类。

我还没有解决这个问题,所以任何帮助将不胜感激。

干杯

链接文本

4

4 回答 4

4

您派生 CDeriveDlgTestDlgCMyDlg但在CDeriveDlgTestDlg::OnInitDialog()您内部明确指示编译器跳过基类并执行CDialog::OnInitDialog(),因此CMyDlg::OnInitDialog()永远不会被调用。

于 2009-11-13T15:23:57.860 回答
0

如果您使用的是 MFC 对话框,则不得处理 WM_INITDIALOG 消息。MFC CDialog 类有一个名为 OnInitDialog() 的虚拟方法,您必须简单地覆盖该方法,然后调用该方法。您可以从“覆盖”选项卡而不是 VS 中的“窗口消息”选项卡自动创建该方法。

于 2009-11-11T21:15:16.120 回答
0

如果要使用 CMyDlg 作为其他对话框类的基础,则不能在 CMyDlg 类中设置 IDD。IDD 应该在从 CMyDlg 派生的类上设置。

所以你应该删除这个:

enum { IDD = IDD_DERIVEDLGTEST_DIALOG };

并替换标准构造函数:

// in the .h file:
//CMyDlg(CWnd* pParent = NULL);
CMyDlg(LPCSTR szIDTemplate, CWnd* pParent = NULL );


// in the .cpp file:
CMyDlg::CMyDlg(LPCSTR szIDTemplate,CWnd* pParent /*=NULL*/)
    : CDialog(szIDTemplate, pParent)
{
}

编辑:我刚刚看到你的链接代码。您在派生类中注意到这一点了吗?

BOOL CDeriveDlgTestDlg::OnInitDialog()
{
    CDialog::OnInitDialog();

你在打电话CDialog::OnInitDialog(),不是CMyDlg::OnInitDialog()

实际上,您应该将所有提及的CDialogtharCDeriveDlgTestDlg替换为CMyDlg. 这样做,你就可以走了。

于 2009-11-11T11:19:02.780 回答
0

如果您使用的是 Release 构建而不是 Debug,则可能无法设置断点 - 它们可能设置在错误的行上,或者完全被忽略。仔细检查以查看您是否正在使用调试版本,或者找到另一种方法来确定是否可以访问代码。我看不出您的代码有任何明显错误。

于 2009-11-11T22:04:16.993 回答