2001-06-26 16:59:19 -04:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/univ/theme.h
|
|
|
|
// Purpose: wxTheme class manages all configurable aspects of the
|
|
|
|
// application including the look (wxRenderer), feel
|
|
|
|
// (wxInputHandler) and the colours (wxColourScheme)
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 06.08.00
|
|
|
|
// RCS-ID: $Id$
|
2001-07-02 15:42:27 -04:00
|
|
|
// Copyright: (c) 2000 SciTech Software, Inc. (www.scitechsoft.com)
|
2001-06-26 16:59:19 -04:00
|
|
|
// Licence: wxWindows license
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_UNIV_THEME_H_
|
|
|
|
#define _WX_UNIV_THEME_H_
|
|
|
|
|
|
|
|
#ifdef __GNUG__
|
|
|
|
#pragma interface "theme.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxTheme
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxRenderer;
|
|
|
|
class WXDLLEXPORT wxColourScheme;
|
|
|
|
class WXDLLEXPORT wxInputHandler;
|
|
|
|
struct WXDLLEXPORT wxThemeInfo;
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxTheme
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// static methods
|
|
|
|
// --------------
|
|
|
|
|
|
|
|
// create the default theme
|
|
|
|
static bool CreateDefault();
|
|
|
|
|
|
|
|
// create the theme by name (will return NULL if not found)
|
|
|
|
static wxTheme *Create(const wxString& name);
|
|
|
|
|
|
|
|
// change the current scheme
|
|
|
|
static wxTheme *Set(wxTheme *theme);
|
|
|
|
|
|
|
|
// get the current theme (never NULL)
|
|
|
|
static wxTheme *Get() { return ms_theme; }
|
|
|
|
|
|
|
|
// the theme methods
|
|
|
|
// -----------------
|
|
|
|
|
|
|
|
// get the renderer implementing all the control-drawing operations in
|
|
|
|
// this theme
|
|
|
|
virtual wxRenderer *GetRenderer() = 0;
|
|
|
|
|
|
|
|
// get the input handler of the given type
|
|
|
|
virtual wxInputHandler *GetInputHandler(const wxString& handlerType) = 0;
|
|
|
|
|
|
|
|
// get the colour scheme for the control with this name
|
|
|
|
virtual wxColourScheme *GetColourScheme() = 0;
|
|
|
|
|
|
|
|
// implementation only from now on
|
|
|
|
// -------------------------------
|
|
|
|
|
|
|
|
virtual ~wxTheme();
|
|
|
|
|
|
|
|
private:
|
|
|
|
// the list of descriptions of all known themes
|
|
|
|
static wxThemeInfo *ms_allThemes;
|
|
|
|
|
|
|
|
// the current theme
|
|
|
|
static wxTheme *ms_theme;
|
2001-09-10 06:43:50 -04:00
|
|
|
friend struct WXDLLEXPORT wxThemeInfo;
|
2001-06-26 16:59:19 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// dynamic theme creation helpers
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
struct WXDLLEXPORT wxThemeInfo
|
|
|
|
{
|
|
|
|
typedef wxTheme *(*Constructor)();
|
|
|
|
|
|
|
|
// theme name and (user readable) description
|
|
|
|
wxString name, desc;
|
|
|
|
|
|
|
|
// the function to create a theme object
|
|
|
|
Constructor ctor;
|
|
|
|
|
|
|
|
// next node in the linked list or NULL
|
|
|
|
wxThemeInfo *next;
|
|
|
|
|
|
|
|
// constructor for the struct itself
|
|
|
|
wxThemeInfo(Constructor ctor, const wxChar *name, const wxChar *desc);
|
|
|
|
};
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// macros
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// to use a standard theme insert this macro into one of the application files:
|
|
|
|
// without it, an over optimizing linker may discard the object module
|
|
|
|
// containing the theme implementation entirely
|
|
|
|
#define WX_USE_THEME(themename) \
|
2001-10-10 19:58:18 -04:00
|
|
|
WXDLLEXPORT_DATA(extern bool) wxThemeUse##themename; \
|
2001-06-26 16:59:19 -04:00
|
|
|
static struct wxThemeUserFor##themename \
|
|
|
|
{ \
|
|
|
|
wxThemeUserFor##themename() { wxThemeUse##themename = TRUE; } \
|
|
|
|
} wxThemeDoUse##themename
|
|
|
|
|
|
|
|
// to declare a new theme, this macro must be used in the class declaration
|
|
|
|
#define WX_DECLARE_THEME(themename) \
|
|
|
|
private: \
|
|
|
|
static wxThemeInfo ms_info##themename; \
|
|
|
|
public: \
|
|
|
|
const wxThemeInfo *GetThemeInfo() const \
|
|
|
|
{ return &ms_info##themename; }
|
|
|
|
|
|
|
|
// and this one must be inserted in the source file
|
|
|
|
#define WX_IMPLEMENT_THEME(classname, themename, themedesc) \
|
2001-10-10 19:58:18 -04:00
|
|
|
WXDLLEXPORT_DATA(bool) wxThemeUse##themename = TRUE; \
|
2001-06-26 16:59:19 -04:00
|
|
|
wxTheme *wxCtorFor##themename() { return new classname; } \
|
|
|
|
wxThemeInfo classname::ms_info##themename(wxCtorFor##themename, \
|
2001-09-20 18:07:21 -04:00
|
|
|
wxT( #themename ), themedesc)
|
2001-06-26 16:59:19 -04:00
|
|
|
|
|
|
|
#endif // _WX_UNIV_THEME_H_
|
|
|
|
|