]>
Commit | Line | Data |
---|---|---|
2bda0e17 | 1 | ///////////////////////////////////////////////////////////////////////////// |
7c0ea335 | 2 | // Name: wx/msw/frame.h |
0d53fc34 | 3 | // Purpose: wxFrame class |
2bda0e17 KB |
4 | // Author: Julian Smart |
5 | // Modified by: | |
6 | // Created: 01/02/97 | |
7 | // RCS-ID: $Id$ | |
8 | // Copyright: (c) Julian Smart and Markus Holzem | |
16f6dfd8 | 9 | // Licence: wxWindows license |
2bda0e17 KB |
10 | ///////////////////////////////////////////////////////////////////////////// |
11 | ||
bbcdf8bc JS |
12 | #ifndef _WX_FRAME_H_ |
13 | #define _WX_FRAME_H_ | |
2bda0e17 KB |
14 | |
15 | #ifdef __GNUG__ | |
42e69d6b | 16 | #pragma interface "frame.h" |
2bda0e17 KB |
17 | #endif |
18 | ||
0d53fc34 | 19 | class WXDLLEXPORT wxFrame : public wxFrameBase |
3a19e16d | 20 | { |
2bda0e17 | 21 | public: |
7c0ea335 | 22 | // construction |
0d53fc34 VS |
23 | wxFrame() { Init(); } |
24 | wxFrame(wxWindow *parent, | |
1e6feb95 VZ |
25 | wxWindowID id, |
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) | |
3a19e16d | 31 | { |
7c0ea335 VZ |
32 | Init(); |
33 | ||
3a19e16d VZ |
34 | Create(parent, id, title, pos, size, style, name); |
35 | } | |
16f6dfd8 | 36 | |
3a19e16d VZ |
37 | bool Create(wxWindow *parent, |
38 | wxWindowID id, | |
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); | |
16f6dfd8 | 44 | |
0d53fc34 | 45 | virtual ~wxFrame(); |
16f6dfd8 | 46 | |
7c0ea335 | 47 | // implement base class pure virtuals |
a2327a9f | 48 | virtual bool ShowFullScreen(bool show, long style = wxFULLSCREEN_ALL); |
82c9f85c | 49 | virtual void Raise(); |
42e69d6b | 50 | |
7c0ea335 VZ |
51 | // implementation only from now on |
52 | // ------------------------------- | |
16f6dfd8 | 53 | |
7c0ea335 VZ |
54 | // event handlers |
55 | void OnActivate(wxActivateEvent& event); | |
56 | void OnSysColourChanged(wxSysColourChangedEvent& event); | |
16f6dfd8 | 57 | |
3a19e16d | 58 | // Toolbar |
d427503c | 59 | #if wxUSE_TOOLBAR |
3a19e16d VZ |
60 | virtual wxToolBar* CreateToolBar(long style = wxNO_BORDER | wxTB_HORIZONTAL | wxTB_FLAT, |
61 | wxWindowID id = -1, | |
62 | const wxString& name = wxToolBarNameStr); | |
63 | ||
3a19e16d | 64 | virtual void PositionToolBar(); |
d427503c | 65 | #endif // wxUSE_TOOLBAR |
16f6dfd8 | 66 | |
3a19e16d | 67 | // Status bar |
7c0ea335 VZ |
68 | #if wxUSE_STATUSBAR |
69 | virtual wxStatusBar* OnCreateStatusBar(int number = 1, | |
70 | long style = wxST_SIZEGRIP, | |
71 | wxWindowID id = 0, | |
72 | const wxString& name = wxStatusLineNameStr); | |
3a19e16d VZ |
73 | |
74 | virtual void PositionStatusBar(); | |
16f6dfd8 | 75 | |
7c0ea335 VZ |
76 | // Hint to tell framework which status bar to use: the default is to use |
77 | // native one for the platforms which support it (Win32), the generic one | |
78 | // otherwise | |
16f6dfd8 | 79 | |
3a19e16d | 80 | // TODO: should this go into a wxFrameworkSettings class perhaps? |
7c0ea335 VZ |
81 | static void UseNativeStatusBar(bool useNative) |
82 | { m_useNativeStatusBar = useNative; }; | |
83 | static bool UsesNativeStatusBar() | |
84 | { return m_useNativeStatusBar; }; | |
d427503c | 85 | #endif // wxUSE_STATUSBAR |
16f6dfd8 | 86 | |
42e69d6b | 87 | WXHMENU GetWinMenu() const { return m_hMenu; } |
16f6dfd8 | 88 | |
7c0ea335 | 89 | // event handlers |
42e69d6b VZ |
90 | bool HandlePaint(); |
91 | bool HandleSize(int x, int y, WXUINT flag); | |
92 | bool HandleCommand(WXWORD id, WXWORD cmd, WXHWND control); | |
93 | bool HandleMenuSelect(WXWORD nItem, WXWORD nFlags, WXHMENU hMenu); | |
94 | ||
7c0ea335 | 95 | // tooltip management |
3a19e16d | 96 | #if wxUSE_TOOLTIPS |
a23fd0e1 VZ |
97 | WXHWND GetToolTipCtrl() const { return m_hwndToolTip; } |
98 | void SetToolTipCtrl(WXHWND hwndTT) { m_hwndToolTip = hwndTT; } | |
3a19e16d VZ |
99 | #endif // tooltips |
100 | ||
3cfcd50b GT |
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 | void SendSizeEvent(); | |
104 | ||
4a41c655 VS |
105 | // called by wxWindow whenever it gets focus |
106 | void SetLastFocus(wxWindow *win) { m_winLastFocused = win; } | |
107 | wxWindow *GetLastFocus() const { return m_winLastFocused; } | |
108 | ||
2bda0e17 | 109 | protected: |
7c0ea335 VZ |
110 | // common part of all ctors |
111 | void Init(); | |
112 | ||
a23fd0e1 VZ |
113 | // override base class virtuals |
114 | virtual void DoGetClientSize(int *width, int *height) const; | |
a23fd0e1 | 115 | virtual void DoSetClientSize(int width, int height); |
cc2b7472 | 116 | |
1e6feb95 | 117 | #if wxUSE_MENUS_NATIVE |
6522713c VZ |
118 | // perform MSW-specific action when menubar is changed |
119 | virtual void AttachMenuBar(wxMenuBar *menubar); | |
120 | ||
42e69d6b VZ |
121 | // a plug in for MDI frame classes which need to do something special when |
122 | // the menubar is set | |
123 | virtual void InternalSetMenuBar(); | |
1e6feb95 | 124 | #endif // wxUSE_MENUS_NATIVE |
42e69d6b | 125 | |
3a19e16d VZ |
126 | // propagate our state change to all child frames |
127 | void IconizeChildFrames(bool bIconize); | |
16f6dfd8 | 128 | |
42e69d6b VZ |
129 | // we add menu bar accel processing |
130 | bool MSWTranslateMessage(WXMSG* pMsg); | |
131 | ||
a23fd0e1 VZ |
132 | // window proc for the frames |
133 | long MSWWindowProc(WXUINT message, WXWPARAM wParam, WXLPARAM lParam); | |
bf505d28 | 134 | |
91dd52fe | 135 | virtual bool IsMDIChild() const { return FALSE; } |
a23fd0e1 | 136 | |
82c9f85c VZ |
137 | // get default (wxWindows) icon for the frame |
138 | virtual WXHICON GetDefaultIcon() const; | |
d427503c VZ |
139 | |
140 | #if wxUSE_STATUSBAR | |
3a19e16d | 141 | static bool m_useNativeStatusBar; |
d427503c VZ |
142 | #endif // wxUSE_STATUSBAR |
143 | ||
f6bcfd97 BP |
144 | // the last focused child: we restore focus to it on activation |
145 | wxWindow *m_winLastFocused; | |
146 | ||
a2327a9f | 147 | // Data to save/restore when calling ShowFullScreen |
a2327a9f JS |
148 | int m_fsStatusBarFields; // 0 for no status bar |
149 | int m_fsStatusBarHeight; | |
150 | int m_fsToolBarHeight; | |
151 | // WXHMENU m_fsMenu; | |
a2327a9f | 152 | |
a23fd0e1 | 153 | private: |
3a19e16d VZ |
154 | #if wxUSE_TOOLTIPS |
155 | WXHWND m_hwndToolTip; | |
156 | #endif // tooltips | |
157 | ||
9327c3aa VZ |
158 | // used by IconizeChildFrames(), see comments there |
159 | bool m_wasMinimized; | |
160 | ||
3a19e16d | 161 | DECLARE_EVENT_TABLE() |
0d53fc34 | 162 | DECLARE_DYNAMIC_CLASS(wxFrame) |
2bda0e17 KB |
163 | }; |
164 | ||
165 | #endif | |
bbcdf8bc | 166 | // _WX_FRAME_H_ |