]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/msw/frame.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/frame.h
3 // Purpose: wxFrameMSW 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 wxFrameMSW
: public wxFrameBase
23 wxFrameMSW() { Init(); }
24 wxFrameMSW(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
);
45 virtual ~wxFrameMSW();
47 // implement base class pure virtuals
48 virtual bool ShowFullScreen(bool show
, long style
= wxFULLSCREEN_ALL
);
49 virtual bool IsFullScreen() const { return m_fsIsShowing
; };
52 // implementation only from now on
53 // -------------------------------
56 void OnActivate(wxActivateEvent
& event
);
57 void OnSysColourChanged(wxSysColourChangedEvent
& event
);
61 virtual wxToolBar
* CreateToolBar(long style
= wxNO_BORDER
| wxTB_HORIZONTAL
| wxTB_FLAT
,
63 const wxString
& name
= wxToolBarNameStr
);
65 virtual void PositionToolBar();
66 #endif // wxUSE_TOOLBAR
70 virtual wxStatusBar
* OnCreateStatusBar(int number
= 1,
71 long style
= wxST_SIZEGRIP
,
73 const wxString
& name
= wxStatusLineNameStr
);
75 virtual void PositionStatusBar();
77 // Hint to tell framework which status bar to use: the default is to use
78 // native one for the platforms which support it (Win32), the generic one
81 // TODO: should this go into a wxFrameworkSettings class perhaps?
82 static void UseNativeStatusBar(bool useNative
)
83 { m_useNativeStatusBar
= useNative
; };
84 static bool UsesNativeStatusBar()
85 { return m_useNativeStatusBar
; };
86 #endif // wxUSE_STATUSBAR
88 WXHMENU
GetWinMenu() const { return m_hMenu
; }
92 bool HandleSize(int x
, int y
, WXUINT flag
);
93 bool HandleCommand(WXWORD id
, WXWORD cmd
, WXHWND control
);
94 bool HandleMenuSelect(WXWORD nItem
, WXWORD nFlags
, WXHMENU hMenu
);
96 bool MSWCreate(int id
, wxWindow
*parent
, const wxChar
*wclass
,
97 wxWindow
*wx_win
, const wxChar
*title
,
98 int x
, int y
, int width
, int height
, long style
);
100 // tooltip management
102 WXHWND
GetToolTipCtrl() const { return m_hwndToolTip
; }
103 void SetToolTipCtrl(WXHWND hwndTT
) { m_hwndToolTip
= hwndTT
; }
106 // a MSW only function which sends a size event to the window using its
107 // current size - this has an effect of refreshing the window layout
108 void SendSizeEvent();
110 // called by wxWindow whenever it gets focus
111 void SetLastFocus(wxWindow
*win
) { m_winLastFocused
= win
; }
112 wxWindow
*GetLastFocus() const { return m_winLastFocused
; }
115 // common part of all ctors
118 // override base class virtuals
119 virtual void DoGetClientSize(int *width
, int *height
) const;
120 virtual void DoSetClientSize(int width
, int height
);
122 #if wxUSE_MENUS_NATIVE
123 // perform MSW-specific action when menubar is changed
124 virtual void AttachMenuBar(wxMenuBar
*menubar
);
126 // a plug in for MDI frame classes which need to do something special when
127 // the menubar is set
128 virtual void InternalSetMenuBar();
129 #endif // wxUSE_MENUS_NATIVE
131 // propagate our state change to all child frames
132 void IconizeChildFrames(bool bIconize
);
134 // we add menu bar accel processing
135 bool MSWTranslateMessage(WXMSG
* pMsg
);
137 // window proc for the frames
138 long MSWWindowProc(WXUINT message
, WXWPARAM wParam
, WXLPARAM lParam
);
140 virtual bool IsMDIChild() const { return FALSE
; }
142 // get default (wxWindows) icon for the frame
143 virtual WXHICON
GetDefaultIcon() const;
146 static bool m_useNativeStatusBar
;
147 #endif // wxUSE_STATUSBAR
149 // the last focused child: we restore focus to it on activation
150 wxWindow
*m_winLastFocused
;
152 // Data to save/restore when calling ShowFullScreen
153 long m_fsStyle
; // Passed to ShowFullScreen
155 long m_fsOldWindowStyle
;
156 int m_fsStatusBarFields
; // 0 for no status bar
157 int m_fsStatusBarHeight
;
158 int m_fsToolBarHeight
;
160 bool m_fsIsMaximized
;
165 WXHWND m_hwndToolTip
;
168 DECLARE_EVENT_TABLE()