X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/03e11df5470fd64d9d9a669d0b50b84c2d714736..22bd93879da9809ecb6ac5cd3bdf58c2aabf0da1:/include/wx/frame.h diff --git a/include/wx/frame.h b/include/wx/frame.h index de126f6a57..039d1f258e 100644 --- a/include/wx/frame.h +++ b/include/wx/frame.h @@ -27,8 +27,8 @@ WXDLLEXPORT_DATA(extern const wxChar*) wxFrameNameStr; WXDLLEXPORT_DATA(extern const wxChar*) wxStatusLineNameStr; WXDLLEXPORT_DATA(extern const wxChar*) wxToolBarNameStr; -WXDLLEXPORT_DATA(extern wxWindow*) wxWndHook; +class WXDLLEXPORT wxFrame; class WXDLLEXPORT wxMenuBar; class WXDLLEXPORT wxStatusBar; class WXDLLEXPORT wxToolBar; @@ -104,8 +104,10 @@ public: // menu bar functions // ------------------ +#if wxUSE_MENUS virtual void SetMenuBar(wxMenuBar *menubar) = 0; virtual wxMenuBar *GetMenuBar() const { return m_frameMenuBar; } +#endif // wxUSE_MENUS // call this to simulate a menu command bool Command(int id) { return ProcessCommand(id); } @@ -172,13 +174,16 @@ public: void OnCloseWindow(wxCloseEvent& event); void OnMenuHighlight(wxMenuEvent& event); void OnSize(wxSizeEvent& event); + // this should go away, but for now it's called from docview.cpp, // so should be there for all platforms void OnActivate(wxActivateEvent &WXUNUSED(event)) { } +#if wxUSE_MENUS // send wxUpdateUIEvents for all menu items (called from OnIdle()) void DoMenuUpdates(); void DoMenuUpdates(wxMenu* menu, wxWindow* focusWin); +#endif // wxUSE_MENUS protected: // the frame main menu/status/tool bars @@ -188,7 +193,15 @@ protected: // main menubar, statusbar and toolbar (if any) void DeleteAllBars(); + // test whether this window makes part of the frame + virtual bool IsOneOfBars(const wxWindow *win) const; + +#if wxUSE_MENUS + // override to update menu bar position when the frame size changes + virtual void PositionMenuBar() { } + wxMenuBar *m_frameMenuBar; +#endif // wxUSE_MENUS #if wxUSE_STATUSBAR // override to update status bar position (or anything else) when @@ -215,6 +228,9 @@ protected: virtual void DoClientToScreen(int *x, int *y) const; virtual void DoScreenToClient(int *x, int *y) const; + // send the iconize event, return TRUE if processed + bool SendIconizeEvent(bool iconized = TRUE); + // the frame icon wxIcon m_icon; @@ -223,11 +239,21 @@ protected: // include the real class declaration #if defined(__WXMSW__) + #ifndef __WXUNIVERSAL__ + #define wxFrameMSW wxFrame + #define sm_classwxFrameMSW sm_classwxFrame + #endif #include "wx/msw/frame.h" #elif defined(__WXMOTIF__) #include "wx/motif/frame.h" #elif defined(__WXGTK__) + #ifndef __WXUNIVERSAL__ + #define wxFrameGTK wxFrame + #define sm_classwxFrameGTK sm_classwxFrame + #endif #include "wx/gtk/frame.h" +#elif defined(__WXMGL__) + #include "wx/mgl/frame.h" #elif defined(__WXQT__) #include "wx/qt/frame.h" #elif defined(__WXMAC__) @@ -238,5 +264,9 @@ protected: #include "wx/stubs/frame.h" #endif +#ifdef __WXUNIVERSAL__ + #include "wx/univ/frame.h" +#endif + #endif // _WX_FRAME_H_BASE_