MFC中对话框的默认构造函数
Override default Constructor of Dialog in MFC
我想覆盖 ctestdialog 的默认构造函数,以便我可以在其中传递 cstring 。
我如何通过
CTestDialog(CString strValue = NULL);
这是MFC中的可能性吗?还是我的想象力?
class CTestDialog : public CDialog
{
DECLARE_DYNAMIC(CTestDialog)
public:
CTestDialog(CWnd* pParent = NULL); // standard constructor
CTestDialog(CString strValue = NULL); // Custom Constructor
virtual ~CTestDialog();
// Dialog Data
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_TESTDIALOG };
#endif
protected:
CString _filename;
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
DECLARE_MESSAGE_MAP()
public:
virtual BOOL OnInitDialog();
};
用法:
CString str = _T("Some Text");
CTestDialog dlg(str);
dlg.doModal();
更新1
在线:
dlg.DoModal();
调试断言失败。显示Microsoft Visual C 运行时库对话框。
更新2
IMPLEMENT_DYNAMIC(CTestDialog, CDialog)
CTestDialog::CTestDialog(CWnd* pParent /*=NULL*/)
: CDialog(IDD_TESTDIALOG, pParent)
{
}
CTestDialog::CTestDialog(CString str)
: CDialog(CTestDialog::IDD, NULL)
{
_filename = str;
}
CTestDialog::~CTestDialog()
{
}
void CTestDialog::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CTestDialog, CDialog)
END_MESSAGE_MAP()
BOOL CTestDialog::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
AfxMessageBox(_filename.GetBuffer());
return TRUE;
}
尝试:
class CTestDialog : public CDialog
{
DECLARE_DYNAMIC(CTestDialog)
public:
CTestDialog(CWnd* pParent = NULL); // standard constructor
CTestDialog(CWnd* pParent, CString strValue); // Custom Constructor
virtual ~CTestDialog();
// Dialog Data
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_TESTDIALOG };
#endif
protected:
CString _filename;
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
DECLARE_MESSAGE_MAP()
public:
virtual BOOL OnInitDialog();
};
和:
IMPLEMENT_DYNAMIC(CTestDialog, CDialog)
CTestDialog::CTestDialog(CWnd* pParent /*=NULL*/)
: CDialog(IDD_TESTDIALOG, pParent)
{
}
CTestDialog::CTestDialog(CWnd* pParent, CString str)
: CDialog(IDD_TESTDIALOG, pParent)
{
_filename = str;
}
CTestDialog::~CTestDialog()
{
}
void CTestDialog::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CTestDialog, CDialog)
END_MESSAGE_MAP()
BOOL CTestDialog::OnInitDialog()
{
CDialog::OnInitDialog();
// TODO: Add extra initialization here
AfxMessageBox(_filename.GetBuffer());
return TRUE;
}
注意:
CTestDialog::CTestDialog(CWnd* pParent, CString str)
: CDialog(IDD_TESTDIALOG, pParent)
{
_filename = str;
}
所以是:
CTestDialog dlg(NULL, "filename");
dlg.DoModal();
您看到,您的自定义构造函数首先称为。然后将所需的pParent
传递到基类构造函数中。
class CTestDialog : public CDialog
{
DECLARE_DYNAMIC(CTestDialog)
public:
CTestDialog(CWnd* pParent = NULL); // standard constructor
CTestDialog(CString strValue); // Custom Constructor
virtual ~CTestDialog();
// Dialog Data
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_TESTDIALOG };
#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
DECLARE_MESSAGE_MAP()
public:
CString _filename;
virtual BOOL OnInitDialog();
};
和用法
CTestDialog dlg(NULL, stingtopass);
dlg.doModal();
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 为什么即使我调用参数化构造函数也会调用默认构造函数?
- 具有非默认构造函数的单例类
- 在 C++ 中声明 const 对象需要用户定义的默认构造函数.如果我有一个可变成员变量,为什么不呢?
- 如何处理没有默认构造函数但在另一个构造函数中构造的对象?
- 在C++中使用默认构造函数初始化对象的不同方法
- 在没有默认构造函数的情况下创建的派生对象
- 强制使用默认构造函数对成员进行未初始化的声明
- 使用默认构造函数初始化对象的不同方法
- 创建类类型的动态分配数组,其中类不得具有默认构造函数