`
in355hz
  • 浏览: 230304 次
社区版块
存档分类
最新评论

浅谈 MFC 的子类化机制和该机制的一个应用(2)

MFC 
阅读更多

续: 浅谈 MFC 的子类化机制和该机制的一个应用( 1

 

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子类化的迷宫子类化,SUBCLASSWINDOW ,MFC消息机制

    在这篇文章中,我们将深入探讨 MFC 子类化机制的原理和实现方式,并提供一个实际的示例来演示如何使用子类化机制来实现一个只能输入 A、B、C 的 EDIT 控件。 什么是 Windows 子类化? -------------------- 在 ...

    走出MFC子类化的迷宫

    MFC提供了`SubclassDlgItem`函数,它允许你将一个MFC控件类与对话框中的控件ID关联起来,自动完成子类化过程。例如,我们创建一个派生自CEdit的自定义控件类`CSuperEdit`,并在其中覆盖`OnChar`消息处理函数,以便...

    vc++6.0 MFC 窗口子类化

    在VC++ 6.0中,MFC(Microsoft Foundation Classes)是一个强大的库,它为Windows应用程序开发提供了便利。MFC库基于面向对象的设计,简化了Windows API的使用,使得开发者可以更加专注于业务逻辑而非底层系统调用。...

    mfc_子类化+双缓冲

    例如,如果要对一个标准按钮进行子类化,首先创建一个继承自`CButton`的自定义类,然后在运行时调用`SubclassWindow`函数,传入要子类化的窗口句柄: ```cpp CMyButton myButton; myButton.SubclassWindow(HWND_of_...

    子类化 超类化 技术分析

    在MFC库中,子类化和超类化被广泛应用于窗口类和控件类的设计。例如,MFC提供了CWnd类作为所有窗口类的基类,开发者可以通过子类化CWnd来创建自定义的窗口类。在子类中,可以重写CWnd的成员函数以实现特定的功能,如...

    我收集的MFC资料,包括子类化,消息映射机制,MFC关键技术,常用数据转化

    1. **子类化**:在Windows编程中,子类化是指一个窗口类继承另一个窗口类的行为,通常是为了扩展或修改默认的行为。MFC通过`ON_WM_*`宏来实现窗口消息的子类化,使得你可以定制控件的事件处理。`MFC的子类化技术.doc...

    深入浅出MFC 深入浅出MFC 深入浅出MFC

    此外,还会讲解如何创建一个基本的MFC应用程序,以及事件处理机制。 2. **dissecting MFC 2e part2.pdf**:这一部分可能会深入到窗口类和控件的使用,如CWnd、CFrameWnd、CMDIChildWnd等,以及标准控件如按钮、编辑...

    MFC和QT的子类化与常用控件1

    总的来说,无论是MFC还是Qt,子类化控件都是一种增强控件功能的有效手段,而这两者都提供了丰富的控件和API,使得开发者能够轻松创建出符合需求的用户界面。在实际开发中,可以根据项目的具体需求和技术栈来选择合适...

    MFC的消息机制的实现原理和消息处理的过程

    - 这个宏为类定义了私有成员变量`_messageEntries`,这是一个静态数组,用于存储消息映射表中的元素。此外,还定义了`GetMessageMap()`成员函数,该函数返回消息映射表的指针。 2. **消息映射的实现**: - 在类的...

    MFC序列化应用示例

    4. **子类化CDocument和CDocumentView**:在MFC应用程序框架中,通常会有一个CDocument类代表数据,一个CView类用于显示数据。这两个类也需要支持序列化。在CDocument中,你需要重写OnNewDocument和OnOpenDocument...

    深入浅出MFC 深入浅出MFC之初始化过程 Visual Studio 2008版

    2. **应用程序对象初始化**:在MFC中,每个应用程序对应一个CWinApp派生类的对象。在`InitInstance`函数中,应用程序对象会完成一系列初始化任务,如解析命令行参数,加载资源,初始化注册表设置,以及处理特定应用...

    Windows-MFC程序-07.MFC序列化机制和序列化类对象

    在Windows编程领域,MFC...总之,MFC的序列化机制为开发人员提供了便捷的方式来持久化和恢复对象状态,是构建Windows应用程序的重要组成部分。通过理解并熟练掌握这一机制,我们可以创建更强大、更灵活的应用程序。

    MFC消息响应机制分析

    CCmdTarget 类提供了一个基本的消息处理机制,允许派生类来重写消息处理函数。这样,程序员可以方便地处理 Windows 的各种消息,并实现更加灵活和高效的程序。 小结 MFC 的消息响应机制是 Windows 下程序设计中最...

    深入浅出MFC

    MFC是微软公司开发的一个C++类库,它为Windows应用程序开发提供了强大的支持,使得开发者能够更容易地利用Windows API进行编程。侯俊杰作为本书的作者,以其深厚的编程经验和对MFC的独到理解,为读者呈现了一部全面...

    深入浅出.MFC

    接着,书中会详细讲解MFC的文档/视图模型,这是MFC应用程序设计中的一个重要概念。通过这个模型,开发者可以将数据存储和显示逻辑分离,使得代码更加模块化。同时,还会涉及对话框、控件、菜单、工具栏、状态栏等...

    深入浅出MFC--侯捷 深入浅出MFC--侯捷 深入浅出MFC--侯捷

    MFC是微软公司开发的一个C++类库,它封装了Windows API,为开发者提供了一种更加面向对象的方式来编写Windows应用程序。本书旨在帮助读者理解和掌握MFC的核心概念、设计模式以及实际应用技巧。 在MFC中,最重要的...

    深入浅出MFC(PDF)

    MFC是微软公司提供的一个C++类库,它封装了Windows API,使得开发者能用面向对象的方式来编写Windows应用程序。这本书深入剖析了MFC的设计原理和实现机制,旨在帮助读者掌握MFC的核心概念和实践技巧。 1. MFC基础 ...

    深入浅出mfc

    2. **CWinApp**:这是MFC框架中的核心类,代表一个应用程序实例。开发者通常会继承这个类并重写其中的方法,以实现自定义的应用程序初始化和退出逻辑。 3. **CFrameWnd与CMDIFrameWnd**:这两个类是用来创建主框架...

    深入浅出MFC简体中文版(附源码

    2. **基础类**:MFC中的CWinApp类是每个MFC应用程序的基础,它负责应用程序的初始化和结束。CWinApp派生自CObject,包含了应用程序全局状态的管理。而CFrameWnd是顶级窗口的基础,CDialog则用于创建对话框。 3. **...

Global site tag (gtag.js) - Google Analytics