1 /////////////////////////////////////////////////////////////////////////////// 
   2 // Name:        wx/univ/window.h 
   3 // Purpose:     wxWindow class which is the base class for all 
   4 //              wxUniv port controls, it supports the customization of the 
   5 //              window drawing and input processing. 
   6 // Author:      Vadim Zeitlin 
  10 // Copyright:   (c) 2000 SciTech Software, Inc. (www.scitechsoft.com) 
  11 // Licence:     wxWindows licence 
  12 /////////////////////////////////////////////////////////////////////////////// 
  14 #ifndef _WX_UNIV_WINDOW_H_ 
  15 #define _WX_UNIV_WINDOW_H_ 
  17 #include "wx/bitmap.h"      // for m_bitmapBg 
  19 class WXDLLIMPEXP_FWD_CORE wxControlRenderer
; 
  20 class WXDLLIMPEXP_FWD_CORE wxEventLoop
; 
  23     class WXDLLIMPEXP_FWD_CORE wxMenu
; 
  24     class WXDLLIMPEXP_FWD_CORE wxMenuBar
; 
  27 class WXDLLIMPEXP_FWD_CORE wxRenderer
; 
  30     class WXDLLIMPEXP_FWD_CORE wxScrollBar
; 
  31 #endif // wxUSE_SCROLLBAR 
  34 #define wxUSE_TWO_WINDOWS 1 
  36 #define wxUSE_TWO_WINDOWS 0 
  39 // ---------------------------------------------------------------------------- 
  41 // ---------------------------------------------------------------------------- 
  43 #if defined(__WXMSW__) 
  44 #define wxWindowNative wxWindowMSW 
  45 #elif defined(__WXGTK__) 
  46 #define wxWindowNative wxWindowGTK 
  47 #elif defined(__WXMGL__) 
  48 #define wxWindowNative wxWindowMGL 
  49 #elif defined(__WXX11__) 
  50 #define wxWindowNative wxWindowX11 
  51 #elif defined(__WXMAC__) 
  52 #define wxWindowNative wxWindowMac 
  55 class WXDLLIMPEXP_CORE wxWindow 
: public wxWindowNative
 
  58     // ctors and create functions 
  59     // --------------------------- 
  61     wxWindow() { Init(); } 
  63     wxWindow(wxWindow 
*parent
, 
  65              const wxPoint
& pos 
= wxDefaultPosition
, 
  66              const wxSize
& size 
= wxDefaultSize
, 
  68              const wxString
& name 
= wxPanelNameStr
) 
  69         : wxWindowNative(parent
, id
, pos
, size
, style 
| wxCLIP_CHILDREN
, name
) 
  72     bool Create(wxWindow 
*parent
, 
  74                 const wxPoint
& pos 
= wxDefaultPosition
, 
  75                 const wxSize
& size 
= wxDefaultSize
, 
  77                 const wxString
& name 
= wxPanelNameStr
); 
  81     // background pixmap support 
  82     // ------------------------- 
  84     virtual void SetBackground(const wxBitmap
& bitmap
, 
  85                                int alignment 
= wxALIGN_CENTRE
, 
  86                                wxStretch stretch 
= wxSTRETCH_NOT
); 
  88     const wxBitmap
& GetBackgroundBitmap(int *alignment 
= NULL
, 
  89                                         wxStretch 
*stretch 
= NULL
) const; 
  91     // scrollbars: we (re)implement it ourselves using our own scrollbars 
  92     // instead of the native ones 
  93     // ------------------------------------------------------------------ 
  95     virtual void SetScrollbar(int orient
, 
  99                               bool refresh 
= true ); 
 100     virtual void SetScrollPos(int orient
, int pos
, bool refresh 
= true); 
 101     virtual int GetScrollPos(int orient
) const; 
 102     virtual int GetScrollThumb(int orient
) const; 
 103     virtual int GetScrollRange(int orient
) const; 
 104     virtual void ScrollWindow(int dx
, int dy
, 
 105                               const wxRect
* rect 
= NULL
); 
 107     // take into account the borders here 
 108     virtual wxPoint 
GetClientAreaOrigin() const; 
 110     // popup menu support 
 111     // ------------------ 
 113     // NB: all menu related functions are implemented in menu.cpp 
 116     // this is wxUniv-specific private method to be used only by wxMenu 
 117     void DismissPopupMenu(); 
 118 #endif // wxUSE_MENUS 
 120     // miscellaneous other methods 
 121     // --------------------------- 
 123     // get the state information 
 124     virtual bool IsFocused() const; 
 125     virtual bool IsCurrent() const; 
 126     virtual bool IsPressed() const; 
 127     virtual bool IsDefault() const; 
 129     // return all state flags at once (combination of wxCONTROL_XXX values) 
 130     int GetStateFlags() const; 
 132     // set the "highlighted" flag and return true if it changed 
 133     virtual bool SetCurrent(bool doit 
= true); 
 136     // get the scrollbar (may be NULL) for the given orientation 
 137     wxScrollBar 
*GetScrollbar(int orient
) const 
 139         return orient 
& wxVERTICAL 
? m_scrollbarVert 
: m_scrollbarHorz
; 
 141 #endif // wxUSE_SCROLLBAR 
 143     // methods used by wxColourScheme to choose the colours for this window 
 144     // -------------------------------------------------------------------- 
 146     // return true if this is a panel/canvas window which contains other 
 148     virtual bool IsCanvasWindow() const { return false; } 
 150     // return true if this control can be highlighted when the mouse is over 
 151     // it (the theme decides itself whether it is really highlighted or not) 
 152     virtual bool CanBeHighlighted() const { return false; } 
 154     // return true if we should use the colours/fonts returned by the 
 155     // corresponding GetXXX() methods instead of the default ones 
 156     bool UseFgCol() const { return m_hasFgCol
; } 
 157     bool UseFont() const { return m_hasFont
; } 
 159     // return true if this window serves as a container for the other windows 
 160     // only and doesn't get any input itself 
 161     virtual bool IsStaticBox() const { return false; } 
 163     // returns the (low level) renderer to use for drawing the control by 
 164     // querying the current theme 
 165     wxRenderer 
*GetRenderer() const { return m_renderer
; } 
 167     // scrolling helper: like ScrollWindow() except that it doesn't refresh the 
 168     // uncovered window areas but returns the rectangle to update (don't call 
 169     // this with both dx and dy non zero) 
 170     wxRect 
ScrollNoRefresh(int dx
, int dy
, const wxRect 
*rect 
= NULL
); 
 172     // after scrollbars are added or removed they must be refreshed by calling 
 174     void RefreshScrollbars(); 
 176     // erase part of the control 
 177     virtual void EraseBackground(wxDC
& dc
, const wxRect
& rect
); 
 179     // overridden base class methods 
 180     // ----------------------------- 
 182     // the rect coordinates are, for us, in client coords, but if no rect is 
 183     // specified, the entire window is refreshed 
 184     virtual void Refresh(bool eraseBackground 
= true, 
 185                          const wxRect 
*rect 
= (const wxRect 
*) NULL
); 
 187     // we refresh the window when it is dis/enabled 
 188     virtual bool Enable(bool enable 
= true); 
 190     // should we use the standard control colours or not? 
 191     virtual bool ShouldInheritColours() const { return false; } 
 193     virtual bool IsClientAreaChild(const wxWindow 
*child
) const 
 196         if ( child 
== (wxWindow
*)m_scrollbarHorz 
|| 
 197              child 
== (wxWindow
*)m_scrollbarVert 
) 
 200         return wxWindowNative::IsClientAreaChild(child
); 
 204     // common part of all ctors 
 208     virtual bool DoPopupMenu(wxMenu 
*menu
, int x
, int y
); 
 209 #endif // wxUSE_MENUS 
 211     // we deal with the scrollbars in these functions 
 212     virtual void DoSetClientSize(int width
, int height
); 
 213     virtual void DoGetClientSize(int *width
, int *height
) const; 
 214     virtual wxHitTest 
DoHitTest(wxCoord x
, wxCoord y
) const; 
 217     void OnSize(wxSizeEvent
& event
); 
 218     void OnNcPaint(wxNcPaintEvent
& event
); 
 219     void OnPaint(wxPaintEvent
& event
); 
 220     void OnErase(wxEraseEvent
& event
); 
 222 #if wxUSE_ACCEL || wxUSE_MENUS 
 223     void OnKeyDown(wxKeyEvent
& event
); 
 224 #endif // wxUSE_ACCEL 
 227     void OnChar(wxKeyEvent
& event
); 
 228     void OnKeyUp(wxKeyEvent
& event
); 
 229 #endif // wxUSE_MENUS 
 231     // draw the control background, return true if done 
 232     virtual bool DoDrawBackground(wxDC
& dc
); 
 234     // draw the controls border 
 235     virtual void DoDrawBorder(wxDC
& dc
, const wxRect
& rect
); 
 237     // draw the controls contents 
 238     virtual void DoDraw(wxControlRenderer 
*renderer
); 
 240     // calculate the best size for the client area of the window: default 
 241     // implementation of DoGetBestSize() uses this method and adds the border 
 242     // width to the result 
 243     virtual wxSize 
DoGetBestClientSize() const; 
 244     virtual wxSize 
DoGetBestSize() const; 
 246     // override the base class method to return the size of the window borders 
 247     virtual wxSize 
DoGetBorderSize() const; 
 249     // adjust the size of the window to take into account its borders 
 250     wxSize 
AdjustSize(const wxSize
& size
) const; 
 252     // put the scrollbars along the edges of the window 
 253     void PositionScrollbars(); 
 256     // return the menubar of the parent frame or NULL 
 257     wxMenuBar 
*GetParentFrameMenuBar() const; 
 258 #endif // wxUSE_MENUS 
 260     // the renderer we use 
 261     wxRenderer 
*m_renderer
; 
 263     // background bitmap info 
 266     wxStretch m_stretchBgBitmap
; 
 271     // is the mouse currently inside the window? 
 276     // override MSWWindowProc() to process WM_NCHITTEST 
 277     WXLRESULT 
MSWWindowProc(WXUINT message
, WXWPARAM wParam
, WXLPARAM lParam
); 
 283     // the window scrollbars 
 284     wxScrollBar 
*m_scrollbarHorz
, 
 286 #endif // wxUSE_SCROLLBAR 
 289     // the current modal event loop for the popup menu we show or NULL 
 290     static wxEventLoop 
*ms_evtLoopPopup
; 
 292     // the last window over which Alt was pressed (used by OnKeyUp) 
 293     static wxWindow 
*ms_winLastAltPress
; 
 294 #endif // wxUSE_MENUS 
 296     DECLARE_DYNAMIC_CLASS(wxWindow
) 
 297     DECLARE_EVENT_TABLE() 
 300 #endif // _WX_UNIV_WINDOW_H_