深入剖析WTL—WTL框架窗口分析(2)

转载 2007年09月30日 11:04:00
ATL的消息处理宏


消息映射的目的是实现ProcessWindowMessage()。ProcessWindowMessage()函数是窗口函数的关键逻辑。

一共有三种消息处理宏,分别对应三类窗口消息——普通窗口消息(如WM_CREATE),命令消息(WM_COMMANS)和通知消息(WM_NOTIFY)。

消息处理宏的目的是将消息和相应的处理函数(该窗口的成员函数)联系起来。

· 普通消息处理宏

有两个这样的宏:MESSAGE_HANDLER和MESSAGE_RANGE_HANDLER。

第一个宏将一个消息和一个消息处理函数连在一起。第二个宏将一定范围内的消息和一个消息处理函数连在一起。

消息处理函数通常是下面这样的:

LRESULT MessageHandler(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);


注意最后一个参数bHandled。它的作用是该处理函数是否处理该消息。如果它为FALSE,消息MAP的其它处理函数会来处理这个消息。

我们看一下MESSAGE_HANDLE的定义:

#define MESSAGE_HANDLER(msg, func) /	if(uMsg == msg) /	{ /		bHandled = TRUE; /		lResult = func(uMsg, wParam, lParam, bHandled); /		if(bHandled) /			return TRUE; /	}


在上面的代码中,首先判断是否是想要处理的消息。如果是的,那么调用第二个参数表示的消息处理函数来处理该消息。

注意bHandled,如果在消息处理函数中设置为TRUE,那么,在完成该消息处理后,会进入return TRUE语句,从ProcessWindowMessage()函数中返回。

如果bHandled在调用消息处理函数时,设置为FALSE,则不会从ProcessWindowMessage中返回,而是继续执行下去。

· 命令消息处理宏和通知消息处理宏

命令消息处理宏有五个——COMMAND_HANDLER,COMMAND_ID_HANDLER,COMMAND_CODE_HANDLER,COMMAND_RANGE_HANDLER和COMMAND_RANGE_CODE_HANDLER。

通知消息处理宏有五个--NOTIFY_HANDLER,NOTIFY_ID_HANDLER,NOTIFY_CODE_HANDLER,NOTIFY_RANGE_HANDLER和NOTIFY_RANGE_CODE_HANDLER

我们不再详细分析。

通过上面的分析,我们知道了ATL是怎样实现窗口函数逻辑的。那么ATL是怎样封装窗口函数的呢?为了能理解ATL的封装方法,还必须了解ATL中的窗口subclass等技术。我们将在分析完这些技术之后,再分析ATL对窗口消息处理函数的封装。

扩展窗口类的功能


我们知道Windows窗口的功能由它的窗口函数指定。通常在创建Windows应用程序时,我们要开发一个窗口函数。通过定义对某些消息的相应来实现窗口的功能。

在每个窗口处理函数的最后,我们一般用下面的语句:

     default:      return DefWindowProc(hWnd, message, wParam, lParam);


它的意思是,对于没有处理的消息,我们将它传递给Windows的确省窗口函数。

Windows除了提供这个缺省的窗口函数,还为某些标准的控制提供了一些预定义的窗口函数。

我们在注册窗口类的时候,指定了该窗口类的窗口处理函数。

扩展窗口类的功能,就是要改变窗口函数中对某些消息的处理逻辑。

下面我们来看几种扩展窗口功能的技术,以及看看ATL是怎样实现的。

派生和CHAIN_MSG_MAP()

很自然,我们会在一个窗口类的基础上派生另一个。然后通过定义不同的消息处理函数。

下面是一个简单的实例(该例子摘自MSDN)。

class CBase: public CWindowImpl< CBase >// simple base window class: shuts down app when closed{   BEGIN_MSG_MAP( CBase )      MESSAGE_HANDLER( WM_DESTROY, OnDestroy )   END_MSG_MAP()   LRESULT OnDestroy( UINT, WPARAM, LPARAM, BOOL& )   {      PostQuitMessage( 0 );      return 0;   }};class CDerived: public CBase// derived from CBase; handles mouse button events{   BEGIN_MSG_MAP( CDerived )      MESSAGE_HANDLER( WM_LBUTTONDOWN, OnButtonDown )      CHAIN_MSG_MAP( CBase ) // chain to base class   END_MSG_MAP()   LRESULT OnButtonDown( UINT, WPARAM, LPARAM, BOOL& )   {      ATLTRACE( "button down/n" );      return 0;   }};

 

 

深入剖析WTL—WTL框架窗口分析

WTL的基础是ATL。WTL的框架窗口是ATL窗口类的继承。因此,先介绍一下ATL对Windows窗口的封装。 由第一部分介绍的Windows应用程序可以知道创建窗口和窗口工作的逻辑是: ...
  • zcxin
  • zcxin
  • 2013年10月23日 01:42
  • 1412

深入剖析WTL窗口框架

深入剖析WTL 1、  wtl对窗口的封装 2、  消息封装 3、  消息路由   一、Wtl对窗口的封装 一般我们使用WTL创建窗口的时候继承CWindowImpl和CDialog...

深入剖析WTL框架(二)

ATL的消息处理宏 消息映射的目的是实现ProcessWindowMessage()。ProcessWindowMessage()函数是窗口函数的关键逻辑。 一共有三种消息处理宏,分别...
  • a199228
  • a199228
  • 2011年11月28日 20:36
  • 449

深入剖析WTL框架(一)

WTL的基础是ATL。WTL的框架窗口是ATL窗口类的继承。因此,先介绍一下ATL对Windows窗口的封装。 由第一部分介绍的Windows应用程序可以知道创建窗口和窗口工作的逻辑是: 1 注...
  • a199228
  • a199228
  • 2011年11月28日 20:34
  • 757

深入剖析WTL框架(五)

ATL对窗口消息处理函数的封装 在本节开始部分谈到的封装窗口的两个难题,其中第一个问题是怎样解决将窗口函数的消息转发到HWND相对应的类的实例中的相应函数。 下面我们来看一下,ATL采用的是...
  • a199228
  • a199228
  • 2011年11月28日 20:39
  • 490

深入剖析WTL框架(六)

WTL对框架窗口的封装 ATL仅仅是封装了窗口函数和提供了消息映射。实际应用中,需要各种种类的窗口,比如,每个界面线程所对应的框架窗口。WTL正是在ATL基础上,为我们提供了框架窗口和其他各...
  • a199228
  • a199228
  • 2011年11月28日 20:40
  • 722

深入剖析WTL框架(四)

superclass superclass是一种生成新的窗口类的方法。它的中心思想是依靠现有的窗口类,克隆出另一个窗口类。被克隆的类可以是Windows预定义的窗口类,这些预定义的窗口类有按钮或下...
  • a199228
  • a199228
  • 2011年11月28日 20:38
  • 574

VC—主框架窗口绘制背景

  • 2011年04月26日 22:41
  • 28KB
  • 下载

WTL 通过IWebBrowser2接口使WebBrowser控件在自己的窗口打开网页 .

WTL 通过IWebBrowser2接口使WebBrowser控件在自己的窗口打开网页 . 标签: webbrowsercommandmicrosoftie浏览器browser 2011-06-19...
  • aasmfox
  • aasmfox
  • 2016年04月14日 12:38
  • 413

WTL 通过IWebBrowser2接口使WebBrowser控件在自己的窗口打开网页

http://blog.csdn.net/tujiaw/article/details/6554994    遇到的问题是这样的, 在WTL中我用了一个WebBrowser控件来显示网页,但是...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深入剖析WTL—WTL框架窗口分析(2)
举报原因:
原因补充:

(最多只允许输入30个字)