X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/07880314d4176c6205c83efbf0ad0ea9ad56d789..1f7d05f01923dd364101719c89d8db383e6f4903:/include/wx/msw/toplevel.h diff --git a/include/wx/msw/toplevel.h b/include/wx/msw/toplevel.h index 64359f658d..ec937af348 100644 --- a/include/wx/msw/toplevel.h +++ b/include/wx/msw/toplevel.h @@ -16,7 +16,7 @@ // wxTopLevelWindowMSW // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxTopLevelWindowMSW : public wxTopLevelWindowBase +class WXDLLIMPEXP_CORE wxTopLevelWindowMSW : public wxTopLevelWindowBase { public: // constructors and such @@ -52,29 +52,41 @@ public: virtual bool IsMaximized() const; 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(); -#ifndef __WXWINCE__ - virtual bool SetShape(const wxRegion& region); -#endif // __WXWINCE__ + virtual void SetLayoutDirection(wxLayoutDirection dir); + virtual void RequestUserAttention(int flags = wxUSER_ATTENTION_INFO); virtual bool Show(bool show = true); + virtual void ShowWithoutActivating(); 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); + virtual bool EnableCloseButton(bool enable = true); // Set window transparency if the platform supports it virtual bool SetTransparent(wxByte alpha); virtual bool CanSetTransparent(); - + + // MSW-specific methods + // -------------------- + + // Return the menu representing the "system" menu of the window. You can + // call wxMenu::AppendWhatever() methods on it but removing items from it + // is in general not a good idea. + // + // The pointer returned by this method belongs to the window and will be + // deleted when the window itself is, do not delete it yourself. May return + // NULL if getting the system menu failed. + wxMenu *MSWGetSystemMenu() const; + + // implementation from now on // -------------------------- @@ -106,6 +118,9 @@ public: // window proc for the frames WXLRESULT MSWWindowProc(WXUINT message, WXWPARAM wParam, WXLPARAM lParam); + // returns true if the platform should explicitly apply a theme border + virtual bool CanApplyThemeBorder() const { return false; } + protected: // common part of all ctors void Init(); @@ -125,6 +140,32 @@ protected: // common part of Iconize(), Maximize() and Restore() void DoShowWindow(int nShowCmd); + // override those to return the normal window coordinates even when the + // window is minimized +#ifndef __WXWINCE__ + virtual void DoGetPosition(int *x, int *y) const; + virtual void DoGetSize(int *width, int *height) const; +#endif // __WXWINCE__ + + // Top level windows have different freeze semantics on Windows + virtual void DoFreeze(); + virtual void DoThaw(); + + virtual void DoEnable(bool enable); + + // helper of SetIcons(): calls gets the icon with the size specified by the + // given system metrics (SM_C{X|Y}[SM]ICON) from the bundle and sets it + // using WM_SETICON with the specified wParam (ICOM_SMALL or ICON_BIG); + // returns true if the icon was set + bool DoSelectAndSetIcon(const wxIconBundle& icons, int smX, int smY, int i); + + // override wxWindow virtual method to use CW_USEDEFAULT if necessary + virtual void MSWGetCreateWindowCoords(const wxPoint& pos, + const wxSize& size, + int& x, int& y, + int& w, int& h) const; + + // is the window currently iconized? bool m_iconized; @@ -183,8 +224,12 @@ private: void* m_activateInfo; #endif + // The system menu: initially NULL but can be set (once) by + // MSWGetSystemMenu(). Owned by this window. + wxMenu *m_menuSystem; + DECLARE_EVENT_TABLE() - DECLARE_NO_COPY_CLASS(wxTopLevelWindowMSW) + wxDECLARE_NO_COPY_CLASS(wxTopLevelWindowMSW); }; #endif // _WX_MSW_TOPLEVEL_H_