X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/41e929e5cf10cbc6298c9a7750233123964a05f6..1d2eddff4af247681ac68d7dbe411ca2bc81742f:/include/wx/msw/toplevel.h diff --git a/include/wx/msw/toplevel.h b/include/wx/msw/toplevel.h index e84fe2267e..d09a48ce0a 100644 --- a/include/wx/msw/toplevel.h +++ b/include/wx/msw/toplevel.h @@ -55,6 +55,7 @@ public: virtual void Iconize(bool iconize = TRUE); virtual bool IsIconized() const; virtual void SetIcon(const wxIcon& icon); + virtual void SetIcons(const wxIconBundle& icons ); virtual void Restore(); virtual bool Show(bool show = TRUE); @@ -62,9 +63,20 @@ public: virtual bool ShowFullScreen(bool show, long style = wxFULLSCREEN_ALL); virtual bool IsFullScreen() const { return m_fsIsShowing; } + // wxMSW only: EnableCloseButton(FALSE) may be used to remove the "Close" + // button from the title bar + bool EnableCloseButton(bool enable = TRUE); + // implementation from now on // -------------------------- + // event handlers + void OnActivate(wxActivateEvent& event); + + // called by wxWindow whenever it gets focus + void SetLastFocus(wxWindow *win) { m_winLastFocused = win; } + wxWindow *GetLastFocus() const { return m_winLastFocused; } + protected: // common part of all ctors void Init(); @@ -76,7 +88,7 @@ protected: // create a new dialog using the given dialog template from resources, // return FALSE if it couldn't be created - bool CreateDialog(const wxChar *dlgTemplate, + bool CreateDialog(const void *dlgTemplate, const wxString& title, const wxPoint& pos, const wxSize& size); @@ -84,16 +96,13 @@ protected: // common part of Iconize(), Maximize() and Restore() void DoShowWindow(int nShowCmd); - // implement the geometry-related methods for a top level window - virtual void DoSetClientSize(int width, int height); + // translate wxWindows flags to Windows ones + virtual WXDWORD MSWGetStyle(long flags, WXDWORD *exstyle) const; - // get the MSW window flags corresponding to wxWindows ones - // - // the functions returns the flags (WS_XXX) directly and puts the ext - // (WS_EX_XXX) flags into the provided pointer if not NULL - long MSWGetCreateWindowFlags(long *exflags) const; + // choose the right parent to use with CreateWindow() + virtual WXHWND MSWGetParent() const; - // is the frame currently iconized? + // is the window currently iconized? bool m_iconized; // should the frame be maximized when it will be shown? set by Maximize() @@ -106,6 +115,15 @@ protected: long m_fsOldWindowStyle; bool m_fsIsMaximized; bool m_fsIsShowing; + + // the last focused child: we restore focus to it on activation + wxWindow *m_winLastFocused; + + // the hidden parent window for the frames which shouldn't appear in the + // taskbar + static wxWindow *ms_hiddenParent; + + DECLARE_EVENT_TABLE() }; // list of all frames and modeless dialogs