1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/frame.h
3 // Purpose: wxFrame class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart and Markus Holzem
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
16 #pragma interface "frame.h"
19 class WXDLLEXPORT wxFrame
: public wxFrameBase
24 wxFrame(wxWindow
*parent
,
26 const wxString
& title
,
27 const wxPoint
& pos
= wxDefaultPosition
,
28 const wxSize
& size
= wxDefaultSize
,
29 long style
= wxDEFAULT_FRAME_STYLE
,
30 const wxString
& name
= wxFrameNameStr
)
34 Create(parent
, id
, title
, pos
, size
, style
, name
);
37 bool Create(wxWindow
*parent
,
39 const wxString
& title
,
40 const wxPoint
& pos
= wxDefaultPosition
,
41 const wxSize
& size
= wxDefaultSize
,
42 long style
= wxDEFAULT_FRAME_STYLE
,
43 const wxString
& name
= wxFrameNameStr
);
47 // implement base class pure virtuals
48 virtual bool ShowFullScreen(bool show
, long style
= wxFULLSCREEN_ALL
);
51 // implementation only from now on
52 // -------------------------------
55 void OnSysColourChanged(wxSysColourChangedEvent
& event
);
59 virtual wxToolBar
* CreateToolBar(long style
= wxNO_BORDER
| wxTB_HORIZONTAL
| wxTB_FLAT
,
61 const wxString
& name
= wxToolBarNameStr
);
63 virtual void PositionToolBar();
64 #endif // wxUSE_TOOLBAR
68 virtual wxStatusBar
* OnCreateStatusBar(int number
= 1,
69 long style
= wxST_SIZEGRIP
,
71 const wxString
& name
= wxStatusLineNameStr
);
73 virtual void PositionStatusBar();
75 // Hint to tell framework which status bar to use: the default is to use
76 // native one for the platforms which support it (Win32), the generic one
79 // TODO: should this go into a wxFrameworkSettings class perhaps?
80 static void UseNativeStatusBar(bool useNative
)
81 { m_useNativeStatusBar
= useNative
; };
82 static bool UsesNativeStatusBar()
83 { return m_useNativeStatusBar
; };
84 #endif // wxUSE_STATUSBAR
86 WXHMENU
GetWinMenu() const { return m_hMenu
; }
90 bool HandleSize(int x
, int y
, WXUINT flag
);
91 bool HandleCommand(WXWORD id
, WXWORD cmd
, WXHWND control
);
92 bool HandleMenuSelect(WXWORD nItem
, WXWORD nFlags
, WXHMENU hMenu
);
93 bool HandleMenuLoop(const wxEventType
& evtType
, WXWORD isPopup
);
97 WXHWND
GetToolTipCtrl() const { return m_hwndToolTip
; }
98 void SetToolTipCtrl(WXHWND hwndTT
) { m_hwndToolTip
= hwndTT
; }
101 // a MSW only function which sends a size event to the window using its
102 // current size - this has an effect of refreshing the window layout
103 virtual void SendSizeEvent();
106 // common part of all ctors
109 // override base class virtuals
110 virtual void DoGetClientSize(int *width
, int *height
) const;
111 virtual void DoSetClientSize(int width
, int height
);
113 #if wxUSE_MENUS_NATIVE
114 // perform MSW-specific action when menubar is changed
115 virtual void AttachMenuBar(wxMenuBar
*menubar
);
117 // a plug in for MDI frame classes which need to do something special when
118 // the menubar is set
119 virtual void InternalSetMenuBar();
120 #endif // wxUSE_MENUS_NATIVE
122 // propagate our state change to all child frames
123 void IconizeChildFrames(bool bIconize
);
125 // we add menu bar accel processing
126 bool MSWTranslateMessage(WXMSG
* pMsg
);
128 // window proc for the frames
129 long MSWWindowProc(WXUINT message
, WXWPARAM wParam
, WXLPARAM lParam
);
131 virtual bool IsMDIChild() const { return FALSE
; }
133 // get default (wxWindows) icon for the frame
134 virtual WXHICON
GetDefaultIcon() const;
137 static bool m_useNativeStatusBar
;
138 #endif // wxUSE_STATUSBAR
140 // Data to save/restore when calling ShowFullScreen
141 int m_fsStatusBarFields
; // 0 for no status bar
142 int m_fsStatusBarHeight
;
143 int m_fsToolBarHeight
;
147 WXHWND m_hwndToolTip
;
150 // used by IconizeChildFrames(), see comments there
153 DECLARE_EVENT_TABLE()
154 DECLARE_DYNAMIC_CLASS(wxFrame
)