#ifndef _WX_FRAME_H_
#define _WX_FRAME_H_
-class WXDLLEXPORT wxFrame : public wxFrameBase
+class WXDLLIMPEXP_CORE wxFrame : public wxFrameBase
{
public:
// construction
// Status bar
#if wxUSE_STATUSBAR
virtual wxStatusBar* OnCreateStatusBar(int number = 1,
- long style = wxST_SIZEGRIP,
+ long style = wxSTB_DEFAULT_STYLE,
wxWindowID id = 0,
const wxString& name = wxStatusLineNameStr);
// TODO: should this go into a wxFrameworkSettings class perhaps?
static void UseNativeStatusBar(bool useNative)
- { m_useNativeStatusBar = useNative; };
+ { m_useNativeStatusBar = useNative; }
static bool UsesNativeStatusBar()
- { return m_useNativeStatusBar; };
+ { return m_useNativeStatusBar; }
#endif // wxUSE_STATUSBAR
-#if wxUSE_MENUS
- WXHMENU GetWinMenu() const { return m_hMenu; }
-#endif // wxUSE_MENUS
-
// event handlers
- bool HandlePaint();
bool HandleSize(int x, int y, WXUINT flag);
bool HandleCommand(WXWORD id, WXWORD cmd, WXHWND control);
bool HandleMenuSelect(WXWORD nItem, WXWORD nFlags, WXHMENU hMenu);
- bool HandleMenuLoop(const wxEventType& evtType, WXWORD isPopup);
// tooltip management
#if wxUSE_TOOLTIPS
void SetToolTipCtrl(WXHWND hwndTT) { m_hwndToolTip = hwndTT; }
#endif // tooltips
- // a MSW only function which sends a size event to the window using its
- // current size - this has an effect of refreshing the window layout
- virtual void SendSizeEvent();
+ // override the base class function to handle iconized/maximized frames
+ virtual void SendSizeEvent(int flags = 0);
virtual wxPoint GetClientAreaOrigin() const;
WXWPARAM wParam,
WXLPARAM lParam);
+#if wxUSE_MENUS
+ // get the currently active menu: this is the same as the frame menu for
+ // normal frames but is overridden by wxMDIParentFrame
+ virtual WXHMENU MSWGetActiveMenu() const { return m_hMenu; }
+#endif // wxUSE_MENUS
+
protected:
// common part of all ctors
void Init();
// wxMDIChildFrame
bool MSWDoTranslateMessage(wxFrame *frame, WXMSG *msg);
- // handle WM_INITMENUPOPUP message to generate wxEVT_MENU_OPEN
- bool HandleInitMenuPopup(WXHMENU hMenu);
+#if wxUSE_MENUS
+ // handle WM_EXITMENULOOP message for Win95 only
+ bool HandleExitMenuLoop(WXWORD isPopup);
+
+ // handle WM_(UN)INITMENUPOPUP message to generate wxEVT_MENU_OPEN/CLOSE
+ bool HandleMenuPopup(wxEventType evtType, WXHMENU hMenu);
+
+ // Command part of HandleMenuPopup() and HandleExitMenuLoop().
+ bool DoSendMenuOpenCloseEvent(wxEventType evtType, wxMenu* menu, bool popup);
+#endif // wxUSE_MENUS
+
virtual bool IsMDIChild() const { return false; }