X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ee92941afca091bf72d17e96ac8388545700d1fc..9243700fb212c2508c4d4c80fb8eb968e565e44d:/include/wx/univ/theme.h diff --git a/include/wx/univ/theme.h b/include/wx/univ/theme.h index 032fe65d62..5e761d1617 100644 --- a/include/wx/univ/theme.h +++ b/include/wx/univ/theme.h @@ -14,16 +14,18 @@ #ifndef _WX_UNIV_THEME_H_ #define _WX_UNIV_THEME_H_ +#include "wx/string.h" + // ---------------------------------------------------------------------------- // wxTheme // ---------------------------------------------------------------------------- -class WXDLLEXPORT wxArtProvider; -class WXDLLEXPORT wxColourScheme; -class WXDLLEXPORT wxInputConsumer; -class WXDLLEXPORT wxInputHandler; -class WXDLLEXPORT wxRenderer; -struct WXDLLEXPORT wxThemeInfo; +class WXDLLIMPEXP_FWD_CORE wxArtProvider; +class WXDLLIMPEXP_FWD_CORE wxColourScheme; +class WXDLLIMPEXP_FWD_CORE wxInputConsumer; +class WXDLLIMPEXP_FWD_CORE wxInputHandler; +class WXDLLIMPEXP_FWD_CORE wxRenderer; +struct WXDLLIMPEXP_FWD_CORE wxThemeInfo; class WXDLLEXPORT wxTheme { @@ -71,7 +73,35 @@ private: // the current theme static wxTheme *ms_theme; - friend struct WXDLLEXPORT wxThemeInfo; + friend struct wxThemeInfo; +}; + +// ---------------------------------------------------------------------------- +// wxDelegateTheme: it is impossible to inherit from any of standard +// themes as their declarations are in private code, but you can use this +// class to override only some of their functions - all the other ones +// will be left to the original theme +// ---------------------------------------------------------------------------- + +class wxDelegateTheme : public wxTheme +{ +public: + wxDelegateTheme(const wxString& theme); + virtual ~wxDelegateTheme(); + + virtual wxRenderer *GetRenderer(); + virtual wxArtProvider *GetArtProvider(); + virtual wxInputHandler *GetInputHandler(const wxString& control, + wxInputConsumer *consumer); + virtual wxColourScheme *GetColourScheme(); + +protected: + // gets or creates theme and sets m_theme to point to it, + // returns true on success + bool GetOrCreateTheme(); + + wxString m_themeName; + wxTheme *m_theme; }; // ---------------------------------------------------------------------------- @@ -92,7 +122,7 @@ struct WXDLLEXPORT wxThemeInfo wxThemeInfo *next; // constructor for the struct itself - wxThemeInfo(Constructor ctor, const wxChar *name, const wxChar *desc); + wxThemeInfo(Constructor ctor, const wxString& name, const wxString& desc); }; // ---------------------------------------------------------------------------- @@ -133,9 +163,13 @@ struct WXDLLEXPORT wxThemeInfo // ---------------------------------------------------------------------------- #if wxUSE_ALL_THEMES + #undef wxUSE_THEME_WIN32 #define wxUSE_THEME_WIN32 1 + #undef wxUSE_THEME_GTK #define wxUSE_THEME_GTK 1 + #undef wxUSE_THEME_MONO #define wxUSE_THEME_MONO 1 + #undef wxUSE_THEME_METAL #define wxUSE_THEME_METAL 1 #endif // wxUSE_ALL_THEMES