1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        wx/msw/window.h 
   3 // Purpose:     wxWindowMSW class 
   4 // Author:      Julian Smart 
   5 // Modified by: Vadim Zeitlin on 13.05.99: complete refont of message handling, 
   6 //              elimination of Default(), ... 
   9 // Copyright:   (c) Julian Smart 
  10 // Licence:     wxWindows licence 
  11 ///////////////////////////////////////////////////////////////////////////// 
  16 #include "wx/settings.h"        // solely for wxSystemColour 
  18 // if this is set to 1, we use deferred window sizing to reduce flicker when 
  19 // resizing complicated window hierarchies, but this can in theory result in 
  20 // different behaviour than the old code so we keep the possibility to use it 
  21 // by setting this to 0 (in the future this should be removed completely) 
  23     #define wxUSE_DEFERRED_SIZING 0 
  25     #define wxUSE_DEFERRED_SIZING 1 
  28 // --------------------------------------------------------------------------- 
  29 // wxWindow declaration for MSW 
  30 // --------------------------------------------------------------------------- 
  32 class WXDLLIMPEXP_CORE wxWindowMSW 
: public wxWindowBase
 
  34     friend class wxSpinCtrl
; 
  35     friend class wxSlider
; 
  36     friend class wxRadioBox
; 
  37 #if defined __VISUALC__ && __VISUALC__ <= 1200 
  38     friend class wxWindowMSW
; 
  41     wxWindowMSW() { Init(); } 
  43     wxWindowMSW(wxWindow 
*parent
, 
  45                 const wxPoint
& pos 
= wxDefaultPosition
, 
  46                 const wxSize
& size 
= wxDefaultSize
, 
  48                 const wxString
& name 
= wxPanelNameStr
) 
  51         Create(parent
, id
, pos
, size
, style
, name
); 
  54     virtual ~wxWindowMSW(); 
  56     bool Create(wxWindow 
*parent
, 
  58                 const wxPoint
& pos 
= wxDefaultPosition
, 
  59                 const wxSize
& size 
= wxDefaultSize
, 
  61                 const wxString
& name 
= wxPanelNameStr
); 
  63     // implement base class pure virtuals 
  64     virtual void SetLabel(const wxString
& label
); 
  65     virtual wxString 
GetLabel() const; 
  70     virtual bool Show(bool show 
= true); 
  71     virtual bool ShowWithEffect(wxShowEffect effect
, 
  74         return MSWShowWithEffect(true, effect
, timeout
); 
  76     virtual bool HideWithEffect(wxShowEffect effect
, 
  79         return MSWShowWithEffect(false, effect
, timeout
); 
  82     virtual void SetFocus(); 
  83     virtual void SetFocusFromKbd(); 
  85     virtual bool Reparent(wxWindowBase 
*newParent
); 
  87     virtual void WarpPointer(int x
, int y
); 
  89     virtual void Refresh( bool eraseBackground 
= true, 
  90                           const wxRect 
*rect 
= (const wxRect 
*) NULL 
); 
  91     virtual void Update(); 
  93     virtual void SetWindowStyleFlag(long style
); 
  94     virtual void SetExtraStyle(long exStyle
); 
  95     virtual bool SetCursor( const wxCursor 
&cursor 
); 
  96     virtual bool SetFont( const wxFont 
&font 
); 
  98     virtual int GetCharHeight() const; 
  99     virtual int GetCharWidth() const; 
 101     virtual void SetScrollbar( int orient
, int pos
, int thumbVisible
, 
 102                                int range
, bool refresh 
= true ); 
 103     virtual void SetScrollPos( int orient
, int pos
, bool refresh 
= true ); 
 104     virtual int GetScrollPos( int orient 
) const; 
 105     virtual int GetScrollThumb( int orient 
) const; 
 106     virtual int GetScrollRange( int orient 
) const; 
 107     virtual void ScrollWindow( int dx
, int dy
, 
 108                                const wxRect
* rect 
= NULL 
); 
 110     virtual bool ScrollLines(int lines
); 
 111     virtual bool ScrollPages(int pages
); 
 113     virtual void SetLayoutDirection(wxLayoutDirection dir
); 
 114     virtual wxLayoutDirection 
GetLayoutDirection() const; 
 115     virtual wxCoord 
AdjustForLayoutDirection(wxCoord x
, 
 117                                              wxCoord widthTotal
) const; 
 119 #if wxUSE_DRAG_AND_DROP 
 120     virtual void SetDropTarget( wxDropTarget 
*dropTarget 
); 
 121 #endif // wxUSE_DRAG_AND_DROP 
 123     // Accept files for dragging 
 124     virtual void DragAcceptFiles(bool accept
); 
 126 #ifndef __WXUNIVERSAL__ 
 127     // Native resource loading (implemented in src/msw/nativdlg.cpp) 
 128     // FIXME: should they really be all virtual? 
 129     virtual bool LoadNativeDialog(wxWindow
* parent
, wxWindowID
& id
); 
 130     virtual bool LoadNativeDialog(wxWindow
* parent
, const wxString
& name
); 
 131     wxWindow
* GetWindowChild1(wxWindowID id
); 
 132     wxWindow
* GetWindowChild(wxWindowID id
); 
 133 #endif // __WXUNIVERSAL__ 
 136     // install and deinstall a system wide hotkey 
 137     virtual bool RegisterHotKey(int hotkeyId
, int modifiers
, int keycode
); 
 138     virtual bool UnregisterHotKey(int hotkeyId
); 
 139 #endif // wxUSE_HOTKEY 
 142     bool IsContextMenuEnabled() const { return m_contextMenuEnabled
; } 
 143     void EnableContextMenu(bool enable 
= true) { m_contextMenuEnabled 
= enable
; } 
 146     // window handle stuff 
 147     // ------------------- 
 149     WXHWND 
GetHWND() const { return m_hWnd
; } 
 150     void SetHWND(WXHWND hWnd
) { m_hWnd 
= hWnd
; } 
 151     virtual WXWidget 
GetHandle() const { return GetHWND(); } 
 153     void AssociateHandle(WXWidget handle
); 
 154     void DissociateHandle(); 
 156     // does this window have deferred position and/or size? 
 157     bool IsSizeDeferred() const; 
 159     // these functions allow to register a global handler for the given Windows 
 160     // message: it will be called from MSWWindowProc() of any window which gets 
 161     // this event if it's not processed before (i.e. unlike a hook procedure it 
 162     // does not override the normal processing) 
 164     // notice that if you want to process a message for a given window only you 
 165     // should override its MSWWindowProc() instead 
 167     // type of the handler: it is called with the message parameters (except 
 168     // that the window object is passed instead of window handle) and should 
 169     // return true if it handled the message or false if it should be passed to 
 171     typedef bool (*MSWMessageHandler
)(wxWindowMSW 
*win
, 
 176     // install a handler, shouldn't be called more than one for the same message 
 177     static bool MSWRegisterMessageHandler(int msg
, MSWMessageHandler handler
); 
 179     // unregister a previously registered handler 
 180     static void MSWUnregisterMessageHandler(int msg
, MSWMessageHandler handler
); 
 183     // implementation from now on 
 184     // ========================== 
 189     void OnPaint(wxPaintEvent
& event
); 
 191     void OnInitDialog(wxInitDialogEvent
& event
); 
 195     // Windows subclassing 
 196     void SubclassWin(WXHWND hWnd
); 
 197     void UnsubclassWin(); 
 199     WXFARPROC 
MSWGetOldWndProc() const { return m_oldWndProc
; } 
 200     void MSWSetOldWndProc(WXFARPROC proc
) { m_oldWndProc 
= proc
; } 
 202     // return true if the window is of a standard (i.e. not wxWidgets') class 
 204     // to understand why does it work, look at SubclassWin() code and comments 
 205     bool IsOfStandardClass() const { return m_oldWndProc 
!= NULL
; } 
 207     wxWindow 
*FindItem(long id
) const; 
 208     wxWindow 
*FindItemByHWND(WXHWND hWnd
, bool controlOnly 
= false) const; 
 210     // MSW only: true if this control is part of the main control 
 211     virtual bool ContainsHWND(WXHWND 
WXUNUSED(hWnd
)) const { return false; } 
 214     // MSW only: true if this window or any of its children have a tooltip 
 215     virtual bool HasToolTips() const { return GetToolTip() != NULL
; } 
 216 #endif // wxUSE_TOOLTIPS 
 218     // translate wxWidgets style flags for this control into the Windows style 
 219     // and optional extended style for the corresponding native control 
 221     // this is the function that should be overridden in the derived classes, 
 222     // but you will mostly use MSWGetCreateWindowFlags() below 
 223     virtual WXDWORD 
MSWGetStyle(long flags
, WXDWORD 
*exstyle 
= NULL
) const ; 
 225     // get the MSW window flags corresponding to wxWidgets ones 
 227     // the functions returns the flags (WS_XXX) directly and puts the ext 
 228     // (WS_EX_XXX) flags into the provided pointer if not NULL 
 229     WXDWORD 
MSWGetCreateWindowFlags(WXDWORD 
*exflags 
= NULL
) const 
 230         { return MSWGetStyle(GetWindowStyle(), exflags
); } 
 232     // update the real underlying window style flags to correspond to the 
 233     // current wxWindow object style (safe to call even if window isn't fully 
 235     void MSWUpdateStyle(long flagsOld
, long exflagsOld
); 
 237     // get the HWND to be used as parent of this window with CreateWindow() 
 238     virtual WXHWND 
MSWGetParent() const; 
 240     // get the Win32 window class name used by all wxWindow objects by default 
 241     static const wxChar 
*MSWGetRegisteredClassName(); 
 243     // creates the window of specified Windows class with given style, extended 
 244     // style, title and geometry (default values 
 246     // returns true if the window has been created, false if creation failed 
 247     bool MSWCreate(const wxChar 
*wclass
, 
 248                    const wxChar 
*title 
= NULL
, 
 249                    const wxPoint
& pos 
= wxDefaultPosition
, 
 250                    const wxSize
& size 
= wxDefaultSize
, 
 252                    WXDWORD exendedStyle 
= 0); 
 254     virtual bool MSWCommand(WXUINT param
, WXWORD id
); 
 256 #ifndef __WXUNIVERSAL__ 
 257     // Create an appropriate wxWindow from a HWND 
 258     virtual wxWindow
* CreateWindowFromHWND(wxWindow
* parent
, WXHWND hWnd
); 
 260     // Make sure the window style reflects the HWND style (roughly) 
 261     virtual void AdoptAttributesFromHWND(); 
 262 #endif // __WXUNIVERSAL__ 
 264     // Setup background and foreground colours correctly 
 265     virtual void SetupColours(); 
 267     // ------------------------------------------------------------------------ 
 268     // helpers for message handlers: these perform the same function as the 
 269     // message crackers from <windowsx.h> - they unpack WPARAM and LPARAM into 
 270     // the correct parameters 
 271     // ------------------------------------------------------------------------ 
 273     void UnpackCommand(WXWPARAM wParam
, WXLPARAM lParam
, 
 274                        WXWORD 
*id
, WXHWND 
*hwnd
, WXWORD 
*cmd
); 
 275     void UnpackActivate(WXWPARAM wParam
, WXLPARAM lParam
, 
 276                         WXWORD 
*state
, WXWORD 
*minimized
, WXHWND 
*hwnd
); 
 277     void UnpackScroll(WXWPARAM wParam
, WXLPARAM lParam
, 
 278                       WXWORD 
*code
, WXWORD 
*pos
, WXHWND 
*hwnd
); 
 279     void UnpackCtlColor(WXWPARAM wParam
, WXLPARAM lParam
, 
 280                         WXHDC 
*hdc
, WXHWND 
*hwnd
); 
 281     void UnpackMenuSelect(WXWPARAM wParam
, WXLPARAM lParam
, 
 282                           WXWORD 
*item
, WXWORD 
*flags
, WXHMENU 
*hmenu
); 
 284     // ------------------------------------------------------------------------ 
 285     // internal handlers for MSW messages: all handlers return a boolean value: 
 286     // true means that the handler processed the event and false that it didn't 
 287     // ------------------------------------------------------------------------ 
 289     // there are several cases where we have virtual functions for Windows 
 290     // message processing: this is because these messages often require to be 
 291     // processed in a different manner in the derived classes. For all other 
 292     // messages, however, we do *not* have corresponding MSWOnXXX() function 
 293     // and if the derived class wants to process them, it should override 
 294     // MSWWindowProc() directly. 
 296     // scroll event (both horizontal and vertical) 
 297     virtual bool MSWOnScroll(int orientation
, WXWORD nSBCode
, 
 298                              WXWORD pos
, WXHWND control
); 
 300     // child control notifications 
 301     virtual bool MSWOnNotify(int idCtrl
, WXLPARAM lParam
, WXLPARAM 
*result
); 
 303     // owner-drawn controls need to process these messages 
 304     virtual bool MSWOnDrawItem(int id
, WXDRAWITEMSTRUCT 
*item
); 
 305     virtual bool MSWOnMeasureItem(int id
, WXMEASUREITEMSTRUCT 
*item
); 
 307     // the rest are not virtual 
 308     bool HandleCreate(WXLPCREATESTRUCT cs
, bool *mayCreate
); 
 309     bool HandleInitDialog(WXHWND hWndFocus
); 
 310     bool HandleDestroy(); 
 313     bool HandlePrintClient(WXHDC hDC
); 
 314     bool HandleEraseBkgnd(WXHDC hDC
); 
 316     bool HandleMinimize(); 
 317     bool HandleMaximize(); 
 318     bool HandleSize(int x
, int y
, WXUINT flag
); 
 319     bool HandleSizing(wxRect
& rect
); 
 320     bool HandleGetMinMaxInfo(void *mmInfo
); 
 321     bool HandleEnterSizeMove(); 
 322     bool HandleExitSizeMove(); 
 324     bool HandleShow(bool show
, int status
); 
 325     bool HandleActivate(int flag
, bool minimized
, WXHWND activate
); 
 327     bool HandleCommand(WXWORD id
, WXWORD cmd
, WXHWND control
); 
 329     bool HandleCtlColor(WXHBRUSH 
*hBrush
, WXHDC hdc
, WXHWND hWnd
); 
 331     bool HandlePaletteChanged(WXHWND hWndPalChange
); 
 332     bool HandleQueryNewPalette(); 
 333     bool HandleSysColorChange(); 
 334     bool HandleDisplayChange(); 
 335     bool HandleCaptureChanged(WXHWND gainedCapture
); 
 336     virtual bool HandleSettingChange(WXWPARAM wParam
, WXLPARAM lParam
); 
 338     bool HandleQueryEndSession(long logOff
, bool *mayEnd
); 
 339     bool HandleEndSession(bool endSession
, long logOff
); 
 341     bool HandleSetFocus(WXHWND wnd
); 
 342     bool HandleKillFocus(WXHWND wnd
); 
 344     bool HandleDropFiles(WXWPARAM wParam
); 
 346     bool HandleMouseEvent(WXUINT msg
, int x
, int y
, WXUINT flags
); 
 347     bool HandleMouseMove(int x
, int y
, WXUINT flags
); 
 348     bool HandleMouseWheel(WXWPARAM wParam
, WXLPARAM lParam
); 
 350     bool HandleChar(WXWPARAM wParam
, WXLPARAM lParam
); 
 351     bool HandleKeyDown(WXWPARAM wParam
, WXLPARAM lParam
); 
 352     bool HandleKeyUp(WXWPARAM wParam
, WXLPARAM lParam
); 
 354     bool HandleHotKey(WXWPARAM wParam
, WXLPARAM lParam
); 
 357     int HandleMenuChar(int chAccel
, WXLPARAM lParam
); 
 359     // Create and process a clipboard event specified by type. 
 360     bool HandleClipboardEvent( WXUINT nMsg 
); 
 362     bool HandleQueryDragIcon(WXHICON 
*hIcon
); 
 364     bool HandleSetCursor(WXHWND hWnd
, short nHitTest
, int mouseMsg
); 
 366     bool HandlePower(WXWPARAM wParam
, WXLPARAM lParam
, bool *vetoed
); 
 369     // The main body of common window proc for all wxWindow objects. It tries 
 370     // to handle the given message and returns true if it was handled (the 
 371     // appropriate return value is then put in result, which must be non-NULL) 
 372     // or false if it wasn't. 
 374     // This function should be overridden in any new code instead of 
 375     // MSWWindowProc() even if currently most of the code overrides 
 376     // MSWWindowProc() as it had been written before this function was added. 
 377     virtual bool MSWHandleMessage(WXLRESULT 
*result
, 
 382     // Common Window procedure for all wxWindow objects: forwards to 
 383     // MSWHandleMessage() and MSWDefWindowProc() if the message wasn't handled. 
 384     virtual WXLRESULT 
MSWWindowProc(WXUINT nMsg
, WXWPARAM wParam
, WXLPARAM lParam
); 
 386     // Calls an appropriate default window procedure 
 387     virtual WXLRESULT 
MSWDefWindowProc(WXUINT nMsg
, WXWPARAM wParam
, WXLPARAM lParam
); 
 389     // message processing helpers 
 391     // return false if the message shouldn't be translated/preprocessed but 
 392     // dispatched normally 
 393     virtual bool MSWShouldPreProcessMessage(WXMSG
* pMsg
); 
 395     // return true if the message was preprocessed and shouldn't be dispatched 
 396     virtual bool MSWProcessMessage(WXMSG
* pMsg
); 
 398     // return true if the message was translated and shouldn't be dispatched 
 399     virtual bool MSWTranslateMessage(WXMSG
* pMsg
); 
 401     // called when the window is about to be destroyed 
 402     virtual void MSWDestroyWindow(); 
 405     // Functions dealing with painting the window background. The derived 
 406     // classes should normally only need to reimplement MSWGetBgBrush() if they 
 407     // need to use a non-solid brush for erasing their background. This 
 408     // function is called by MSWGetBgBrushForChild() which only exists for the 
 409     // weird wxToolBar case and MSWGetBgBrushForChild() itself is used by 
 410     // MSWGetBgBrush() to actually find the right brush to use. 
 412     // The brush returned from here must remain valid at least until the next 
 413     // event loop iteration. Returning 0, as is done by default, indicates 
 414     // there is no custom background brush. 
 415     virtual WXHBRUSH 
MSWGetCustomBgBrush() { return 0; } 
 417     // this function should return the brush to paint the children controls 
 418     // background or 0 if this window doesn't impose any particular background 
 421     // the hDC parameter is the DC background will be drawn on, it can be used 
 422     // to call SetBrushOrgEx() on it if the returned brush is a bitmap one 
 424     // child parameter is never NULL, it can be this window itself or one of 
 425     // its (grand)children 
 427     // the base class version returns a solid brush if we have a non default 
 428     // background colour or 0 otherwise 
 429     virtual WXHBRUSH 
MSWGetBgBrushForChild(WXHDC hDC
, wxWindowMSW 
*child
); 
 431     // return the background brush to use for painting the given window by 
 432     // querying the parent windows via MSWGetBgBrushForChild() recursively 
 433     WXHBRUSH 
MSWGetBgBrush(WXHDC hDC
); 
 438         ThemeColourBackground
, 
 442     // returns a specific theme colour, or if that is not possible then 
 443     // wxSystemSettings::GetColour(fallback) 
 444     wxColour 
MSWGetThemeColour(const wchar_t *themeName
, 
 447                                MSWThemeColour themeColour
, 
 448                                wxSystemColour fallback
) const; 
 450     // gives the parent the possibility to draw its children background, e.g. 
 451     // this is used by wxNotebook to do it using DrawThemeBackground() 
 453     // return true if background was drawn, false otherwise 
 454     virtual bool MSWPrintChild(WXHDC 
WXUNUSED(hDC
), wxWindow 
* WXUNUSED(child
)) 
 459     // some controls (e.g. wxListBox) need to set the return value themselves 
 461     // return true to let parent handle it if we don't, false otherwise 
 462     virtual bool MSWShouldPropagatePrintChild() 
 467     // This should be overridden to return true for the controls which have 
 468     // themed background that should through their children. Currently only 
 469     // wxNotebook uses this. 
 471     // The base class version already returns true if we have a solid 
 472     // background colour that should be propagated to our children. 
 473     virtual bool MSWHasInheritableBackground() const 
 475         return InheritsBackgroundColour(); 
 478 #if !defined(__WXWINCE__) && !defined(__WXUNIVERSAL__) 
 479     #define wxHAS_MSW_BACKGROUND_ERASE_HOOK 
 482 #ifdef wxHAS_MSW_BACKGROUND_ERASE_HOOK 
 483     // allows the child to hook into its parent WM_ERASEBKGND processing: call 
 484     // MSWSetEraseBgHook() with a non-NULL window to make parent call 
 485     // MSWEraseBgHook() on this window (don't forget to reset it to NULL 
 488     // this hack is used by wxToolBar, see comments there 
 489     void MSWSetEraseBgHook(wxWindow 
*child
); 
 491     // return true if WM_ERASEBKGND is currently hooked 
 492     bool MSWHasEraseBgHook() const; 
 494     // called when the window on which MSWSetEraseBgHook() had been called 
 495     // receives WM_ERASEBKGND 
 496     virtual bool MSWEraseBgHook(WXHDC 
WXUNUSED(hDC
)) { return false; } 
 497 #endif // wxHAS_MSW_BACKGROUND_ERASE_HOOK 
 499     // common part of Show/HideWithEffect() 
 500     bool MSWShowWithEffect(bool show
, 
 504     // Responds to colour changes: passes event on to children. 
 505     void OnSysColourChanged(wxSysColourChangedEvent
& event
); 
 507     // initialize various fields of wxMouseEvent (common part of MSWOnMouseXXX) 
 508     void InitMouseEvent(wxMouseEvent
& event
, int x
, int y
, WXUINT flags
); 
 510     // check if mouse is in the window 
 511     bool IsMouseInWindow() const; 
 513     // check if a native double-buffering applies for this window 
 514     virtual bool IsDoubleBuffered() const; 
 516     void SetDoubleBuffered(bool on
); 
 518     // synthesize a wxEVT_LEAVE_WINDOW event and set m_mouseInWindow to false 
 519     void GenerateMouseLeave(); 
 521     // virtual function for implementing internal idle 
 523     virtual void OnInternalIdle(); 
 526     // this allows you to implement standard control borders without 
 527     // repeating the code in different classes that are not derived from 
 529     virtual wxBorder 
GetDefaultBorderForControl() const; 
 531     // choose the default border for this window 
 532     virtual wxBorder 
GetDefaultBorder() const; 
 534     // Translate wxBORDER_THEME (and other border styles if necessary to the value 
 535     // that makes most sense for this Windows environment 
 536     virtual wxBorder 
TranslateBorder(wxBorder border
) const; 
 538 #if wxUSE_MENUS_NATIVE 
 539     virtual bool DoPopupMenu( wxMenu 
*menu
, int x
, int y 
); 
 540 #endif // wxUSE_MENUS_NATIVE 
 545     // the old window proc (we subclass all windows) 
 546     WXFARPROC             m_oldWndProc
; 
 548     // additional (MSW specific) flags 
 549     bool                  m_mouseInWindow
:1; 
 550     bool                  m_lastKeydownProcessed
:1; 
 552     // the size of one page for scrolling 
 556     // implement the base class pure virtuals 
 557     virtual void DoGetTextExtent(const wxString
& string
, 
 560                                  int *externalLeading 
= NULL
, 
 561                                  const wxFont 
*font 
= NULL
) const; 
 562     virtual void DoClientToScreen( int *x
, int *y 
) const; 
 563     virtual void DoScreenToClient( int *x
, int *y 
) const; 
 564     virtual void DoGetPosition( int *x
, int *y 
) const; 
 565     virtual void DoGetSize( int *width
, int *height 
) const; 
 566     virtual void DoGetClientSize( int *width
, int *height 
) const; 
 567     virtual void DoSetSize(int x
, int y
, 
 568                            int width
, int height
, 
 569                            int sizeFlags 
= wxSIZE_AUTO
); 
 570     virtual void DoSetClientSize(int width
, int height
); 
 572     virtual wxSize 
DoGetBorderSize() const; 
 574     virtual void DoCaptureMouse(); 
 575     virtual void DoReleaseMouse(); 
 577     virtual void DoEnable(bool enable
); 
 579     virtual void DoFreeze(); 
 580     virtual void DoThaw(); 
 582     // this simply moves/resizes the given HWND which is supposed to be our 
 583     // sibling (this is useful for controls which are composite at MSW level 
 584     // and for which DoMoveWindow() is not enough) 
 586     // returns true if the window move was deferred, false if it was moved 
 587     // immediately (no error return) 
 588     bool DoMoveSibling(WXHWND hwnd
, int x
, int y
, int width
, int height
); 
 590     // move the window to the specified location and resize it: this is called 
 591     // from both DoSetSize() and DoSetClientSize() and would usually just call 
 592     // ::MoveWindow() except for composite controls which will want to arrange 
 593     // themselves inside the given rectangle 
 594     virtual void DoMoveWindow(int x
, int y
, int width
, int height
); 
 597     virtual void DoSetToolTip( wxToolTip 
*tip 
); 
 599     // process TTN_NEEDTEXT message properly (i.e. fixing the bugs in 
 600     // comctl32.dll in our code -- see the function body for more info) 
 601     bool HandleTooltipNotify(WXUINT code
, 
 603                              const wxString
& ttip
); 
 604 #endif // wxUSE_TOOLTIPS 
 606     // This is used by CreateKeyEvent() and also for wxEVT_CHAR[_HOOK] event 
 607     // creation. Notice that this method doesn't initialize wxKeyEvent 
 608     // m_keyCode and m_uniChar fields. 
 609     void InitAnyKeyEvent(wxKeyEvent
& event
, 
 611                          WXLPARAM lParam
) const; 
 613     // Helper functions used by HandleKeyXXX() methods and some derived 
 614     // classes, wParam and lParam have the same meaning as in WM_KEY{DOWN,UP}. 
 616     // NB: evType here must be wxEVT_KEY_{DOWN,UP} as wParam here contains the 
 617     //     virtual key code, not character! 
 618     wxKeyEvent 
CreateKeyEvent(wxEventType evType
, 
 620                               WXLPARAM lParam 
= 0) const; 
 622     // Another helper for creating wxKeyEvent for wxEVT_CHAR and related types. 
 624     // The wParam and lParam here must come from WM_CHAR event parameters, i.e. 
 625     // wParam must be a character and not a virtual code. 
 626     wxKeyEvent 
CreateCharEvent(wxEventType evType
, 
 628                                WXLPARAM lParam
) const; 
 631     // default OnEraseBackground() implementation, return true if we did erase 
 632     // the background, false otherwise (i.e. the system should erase it) 
 633     bool DoEraseBackground(WXHDC hDC
); 
 635     // generate WM_CHANGEUISTATE if it's needed for the OS we're running under 
 637     // action should be one of the UIS_XXX constants 
 638     // state should be one or more of the UISF_XXX constants 
 639     // if action == UIS_INITIALIZE then it doesn't seem to matter what we use 
 640     // for state as the system will decide for us what needs to be set 
 641     void MSWUpdateUIState(int action
, int state 
= 0); 
 643     // translate wxWidgets coords into Windows ones suitable to be passed to 
 644     // ::CreateWindow(), called from MSWCreate() 
 645     virtual void MSWGetCreateWindowCoords(const wxPoint
& pos
, 
 648                                           int& w
, int& h
) const; 
 650     bool MSWEnableHWND(WXHWND hWnd
, bool enable
); 
 653     // common part of all ctors 
 656     // the (non-virtual) handlers for the events 
 657     bool HandleMove(int x
, int y
); 
 658     bool HandleMoving(wxRect
& rect
); 
 659     bool HandleJoystickEvent(WXUINT msg
, int x
, int y
, WXUINT flags
); 
 660     bool HandleNotify(int idCtrl
, WXLPARAM lParam
, WXLPARAM 
*result
); 
 662 #if wxUSE_DEFERRED_SIZING 
 664     // this function is called after the window was resized to its new size 
 665     virtual void MSWEndDeferWindowPos() 
 667         m_pendingPosition 
= wxDefaultPosition
; 
 668         m_pendingSize 
= wxDefaultSize
; 
 671     // current defer window position operation handle (may be NULL) 
 674     // When deferred positioning is done these hold the pending changes, and 
 675     // are used for the default values if another size/pos changes is done on 
 676     // this window before the group of deferred changes is completed. 
 677     wxPoint     m_pendingPosition
; 
 678     wxSize      m_pendingSize
; 
 679 #endif // wxUSE_DEFERRED_SIZING 
 683     bool        m_contextMenuEnabled
; 
 686     DECLARE_DYNAMIC_CLASS(wxWindowMSW
) 
 687     wxDECLARE_NO_COPY_CLASS(wxWindowMSW
); 
 688     DECLARE_EVENT_TABLE() 
 691 // window creation helper class: before creating a new HWND, instantiate an 
 692 // object of this class on stack - this allows to process the messages sent to 
 693 // the window even before CreateWindow() returns 
 694 class wxWindowCreationHook
 
 697     wxWindowCreationHook(wxWindowMSW 
*winBeingCreated
); 
 698     ~wxWindowCreationHook(); 
 701 #endif // _WX_WINDOW_H_