BOOL CDumpMsgBox::OnDumpOut(LPSTR pszDumpBuffer, UINT nBufferSize)
{
ASSERT(pszDumpBuffer != NULL && nBufferSize != 0);
ASSERT(AfxIsValidString(pszDumpBuffer, nBufferSize));
// calculate '\n' occur times in buffer.
int
nPosition, nLine = 0;
for
(nPosition = 0; nPosition < (int)nBufferSize; nPosition ++)
{
if
(pszDumpBuffer[nPosition] == '\0')
break;
if
(pszDumpBuffer[nPosition] == '\n')
nLine ++;
}
// alloc enough memory for convert.
TCHAR *pszBuffer = (TCHAR*)malloc(sizeof
(TCHAR) * (nPosition + nLine + 64));
// convert all '\n' '\r' or '\n\r' to '\r\n':
TCHAR *pszConvert = pszBuffer;
for
(nPosition = 0; nPosition < (int)nBufferSize; nPosition ++)
{
if
(pszDumpBuffer[nPosition] == '\0')
break
;
if
(pszDumpBuffer[nPosition] == '\r')
continue
;
if
(pszDumpBuffer[nPosition] == '\n')
{
*pszConvert = _T('\r');
pszConvert ++;
}
*pszConvert = (TCHAR)pszDumpBuffer[nPosition];
pszConvert ++;
}
// set end of string.
*pszConvert = '\0';
// set converted dump buffer to the edit control.
m_editDump.AssertValid();
m_editDump.SetWindowText(pszBuffer);
free(pszBuffer);
return
TRUE;
}
int
CDumpMsgBox::DoMessageBox(UINT nIDPrompt, UINT nType, UINT nIDHelp)
{
CString string;
if
(!string.LoadString(nIDPrompt))
{
TRACE1("CDumpMsgBox::DoMessageBox error: failed to load message box prompt string 0x%04x.\n",
nIDPrompt);
ASSERT(FALSE);
}
if
(nIDHelp == (UINT)-1)
nIDHelp = nIDPrompt;
return
DoMessageBox(string, nType, nIDHelp);
}
int
CDumpMsgBox::DoMessageBox(LPCTSTR lpszText, UINT nType, UINT nIDHelp)
{
int
nRetCode;
// not call PreCreateWindow to initialize CREATESTRUCT data.
AfxHookWindowCreate(this
);
nRetCode = AfxMessageBox(lpszText, nType, nIDHelp);
if
(!AfxUnhookWindowCreate())
PostNcDestroy();
return
nRetCode;
}
void
CDumpMsgBox::DoDumpObject(CObject* pDumpObject)
{
m_fileDump.AssertValid();
// dump target must exist.
ASSERT(pDumpObject != NULL);
CRuntimeClass* pClass = pDumpObject->GetRuntimeClass();
if
(pClass == NULL)
return
;
// unexpect runtime-class value.
if
(AfxIsValidAddress(pDumpObject, pClass->m_nObjectSize, TRUE))
{
#ifdef
_DEBUG
pDumpObject->Dump(m_dumpContext);
#else
// ! _DEBUG
m_dumpContext << "a " << pClass->m_lpszClassName <<
" at " << (void*)pDumpObject;
m_dumpContext << "\nHex Dumps: " << pClass->m_nObjectSize <<
" bytes long.\n";
m_dumpContext.HexDump(_T("HEX"), (BYTE*)pDumpObject,
pClass->m_nObjectSize, 8);
#endif
// _DEBUG
}
}
#ifdef
_DEBUG
void
CDumpMsgBox::AssertValid() const
{
CWnd::AssertValid();
if
(m_editDump.GetSafeHwnd())
m_editDump.AssertValid();
ASSERT(AfxIsValidAddress(&m_dumpContext, sizeof(CDumpContext), TRUE));
m_fileDump.AssertValid();
}
void
CDumpMsgBox::Dump(CDumpContext& dc) const
{
if
(m_hWnd == NULL)
{
CObject::Dump(dc);
dc << "m_hWnd = NULL\n";
}
else
CWnd::Dump(dc);
if
(0 < dc.GetDepth())
{
dc << "include ";
if
(NULL == m_editDump.GetSafeHwnd())
{
m_editDump.CObject::Dump(dc);
dc << "m_hWnd = NULL\n";
}
else
m_editDump.Dump(dc);
dc << "include ";
m_fileDump.Dump(dc);
}
}
#endif
// _DEBUG
代码较为简单,为
MessageBox
增加了一个
Edit Control
,属性为
ES_MULTILINE
,
ES_READONLY
,
ES_AUTOVSCROLL
,并且拥有
WS_EX_CLIENTEDGE
属性。
该
Edit Control
的内容通过
CMemFile
和
CDumpContext
生成。构造函数
CDumpContext( CFile* pFile )
可以生成一个以
CMemFile
为目标的
CDumpContext
实例,然后调用
CObject::Dump
,最后通过
CMemFile::Detach
得到包含输出字符串的缓冲区。
以下是
CDumpMsgBox
的应用示例:
CDumpMsgBox msgBox;
// declare intsance
msgBox.DoDumpObject(&msgBox);
// dump itself
msgBox.DoMessageBox(_T("This message box used class CDumpMsgBox."), MB_OKCANCEL);
// display
以上代码在
MS Visual C++ 6.0, Win98
下调试通过。
相关推荐
在这篇文章中,我们将深入探讨 MFC 子类化机制的原理和实现方式,并提供一个实际的示例来演示如何使用子类化机制来实现一个只能输入 A、B、C 的 EDIT 控件。 什么是 Windows 子类化? -------------------- 在 ...
MFC提供了`SubclassDlgItem`函数,它允许你将一个MFC控件类与对话框中的控件ID关联起来,自动完成子类化过程。例如,我们创建一个派生自CEdit的自定义控件类`CSuperEdit`,并在其中覆盖`OnChar`消息处理函数,以便...
在VC++ 6.0中,MFC(Microsoft Foundation Classes)是一个强大的库,它为Windows应用程序开发提供了便利。MFC库基于面向对象的设计,简化了Windows API的使用,使得开发者可以更加专注于业务逻辑而非底层系统调用。...
例如,如果要对一个标准按钮进行子类化,首先创建一个继承自`CButton`的自定义类,然后在运行时调用`SubclassWindow`函数,传入要子类化的窗口句柄: ```cpp CMyButton myButton; myButton.SubclassWindow(HWND_of_...
在MFC库中,子类化和超类化被广泛应用于窗口类和控件类的设计。例如,MFC提供了CWnd类作为所有窗口类的基类,开发者可以通过子类化CWnd来创建自定义的窗口类。在子类中,可以重写CWnd的成员函数以实现特定的功能,如...
1. **子类化**:在Windows编程中,子类化是指一个窗口类继承另一个窗口类的行为,通常是为了扩展或修改默认的行为。MFC通过`ON_WM_*`宏来实现窗口消息的子类化,使得你可以定制控件的事件处理。`MFC的子类化技术.doc...
此外,还会讲解如何创建一个基本的MFC应用程序,以及事件处理机制。 2. **dissecting MFC 2e part2.pdf**:这一部分可能会深入到窗口类和控件的使用,如CWnd、CFrameWnd、CMDIChildWnd等,以及标准控件如按钮、编辑...
总的来说,无论是MFC还是Qt,子类化控件都是一种增强控件功能的有效手段,而这两者都提供了丰富的控件和API,使得开发者能够轻松创建出符合需求的用户界面。在实际开发中,可以根据项目的具体需求和技术栈来选择合适...
- 这个宏为类定义了私有成员变量`_messageEntries`,这是一个静态数组,用于存储消息映射表中的元素。此外,还定义了`GetMessageMap()`成员函数,该函数返回消息映射表的指针。 2. **消息映射的实现**: - 在类的...
4. **子类化CDocument和CDocumentView**:在MFC应用程序框架中,通常会有一个CDocument类代表数据,一个CView类用于显示数据。这两个类也需要支持序列化。在CDocument中,你需要重写OnNewDocument和OnOpenDocument...
2. **应用程序对象初始化**:在MFC中,每个应用程序对应一个CWinApp派生类的对象。在`InitInstance`函数中,应用程序对象会完成一系列初始化任务,如解析命令行参数,加载资源,初始化注册表设置,以及处理特定应用...
在Windows编程领域,MFC...总之,MFC的序列化机制为开发人员提供了便捷的方式来持久化和恢复对象状态,是构建Windows应用程序的重要组成部分。通过理解并熟练掌握这一机制,我们可以创建更强大、更灵活的应用程序。
CCmdTarget 类提供了一个基本的消息处理机制,允许派生类来重写消息处理函数。这样,程序员可以方便地处理 Windows 的各种消息,并实现更加灵活和高效的程序。 小结 MFC 的消息响应机制是 Windows 下程序设计中最...
MFC是微软公司开发的一个C++类库,它为Windows应用程序开发提供了强大的支持,使得开发者能够更容易地利用Windows API进行编程。侯俊杰作为本书的作者,以其深厚的编程经验和对MFC的独到理解,为读者呈现了一部全面...
接着,书中会详细讲解MFC的文档/视图模型,这是MFC应用程序设计中的一个重要概念。通过这个模型,开发者可以将数据存储和显示逻辑分离,使得代码更加模块化。同时,还会涉及对话框、控件、菜单、工具栏、状态栏等...
MFC是微软公司开发的一个C++类库,它封装了Windows API,为开发者提供了一种更加面向对象的方式来编写Windows应用程序。本书旨在帮助读者理解和掌握MFC的核心概念、设计模式以及实际应用技巧。 在MFC中,最重要的...
MFC是微软公司提供的一个C++类库,它封装了Windows API,使得开发者能用面向对象的方式来编写Windows应用程序。这本书深入剖析了MFC的设计原理和实现机制,旨在帮助读者掌握MFC的核心概念和实践技巧。 1. MFC基础 ...
2. **CWinApp**:这是MFC框架中的核心类,代表一个应用程序实例。开发者通常会继承这个类并重写其中的方法,以实现自定义的应用程序初始化和退出逻辑。 3. **CFrameWnd与CMDIFrameWnd**:这两个类是用来创建主框架...