2006-12-16 23:04:44 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2006 Aaron Seigo <aseigo@kde.org>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Library General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PLASMA_THEME_H
|
|
|
|
#define PLASMA_THEME_H
|
|
|
|
|
|
|
|
#include <QtCore/QObject>
|
|
|
|
|
2007-06-02 17:29:39 +00:00
|
|
|
#include <plasma/plasma_export.h>
|
2007-01-01 04:31:43 +00:00
|
|
|
|
2006-12-16 23:04:44 +00:00
|
|
|
namespace Plasma
|
|
|
|
{
|
2007-05-22 01:30:03 +00:00
|
|
|
/**
|
|
|
|
* @short Interface to the Plasma theme
|
|
|
|
*
|
|
|
|
* Accessed via Plasma::Theme::self() e.g:
|
|
|
|
* \code
|
|
|
|
* QString image = Plasma::Theme::self()->image("widgets/clock")
|
|
|
|
* \endcode
|
|
|
|
*
|
2007-05-24 18:14:54 +00:00
|
|
|
* Plasma::Theme provides access to a common and standardized set of graphic
|
|
|
|
* elements stored in SVG format. This allows artists to create single packages
|
|
|
|
* of SVGs that will affect the look and feel of all workspace components.
|
|
|
|
*
|
|
|
|
* Plasma::Svg uses Plasma::Theme internally to locate and load the appropriate
|
|
|
|
* SVG data. Alternatively, Plasma::Theme can be used directly to retrieve
|
|
|
|
* file system paths to SVGs by name.
|
2007-05-22 01:30:03 +00:00
|
|
|
*/
|
2007-05-20 20:13:46 +00:00
|
|
|
class PLASMA_EXPORT Theme : public QObject
|
2006-12-16 23:04:44 +00:00
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
public:
|
2007-03-07 23:27:37 +00:00
|
|
|
/**
|
|
|
|
* Singleton pattern accessor
|
|
|
|
**/
|
|
|
|
static Theme* self();
|
|
|
|
|
2007-05-29 07:56:58 +00:00
|
|
|
/**
|
|
|
|
* Default constructor. Usually you want to use the singleton instead.
|
|
|
|
*/
|
2007-03-03 01:41:27 +00:00
|
|
|
explicit Theme( QObject* parent = 0 );
|
2006-12-16 23:04:44 +00:00
|
|
|
~Theme();
|
|
|
|
|
2007-07-17 20:51:12 +00:00
|
|
|
/**
|
|
|
|
* Sets the application the theme setting is associated with. This
|
|
|
|
* allows for individual applications that use libplasma to have the
|
|
|
|
* theme set independantly.
|
|
|
|
*
|
|
|
|
* @param appname name of the application
|
|
|
|
**/
|
|
|
|
void setApplication(const QString &appname);
|
|
|
|
|
2007-05-22 01:30:03 +00:00
|
|
|
/**
|
2007-05-24 18:14:54 +00:00
|
|
|
* @return the name of the theme. "default" is none set.
|
2007-05-22 01:30:03 +00:00
|
|
|
*/
|
2006-12-16 23:04:44 +00:00
|
|
|
QString themeName() const;
|
2007-05-24 18:14:54 +00:00
|
|
|
|
2007-05-22 01:30:03 +00:00
|
|
|
/**
|
2007-05-29 07:56:58 +00:00
|
|
|
* Retrieve the path for an SVG image in the current theme.
|
|
|
|
*
|
|
|
|
* @arg name the name of the file in the theme directory (without the
|
|
|
|
* ".svg" part or a leading slash)
|
2007-05-22 01:30:03 +00:00
|
|
|
* @return the full path to the requested file for the current theme
|
|
|
|
*/
|
2007-03-05 00:07:21 +00:00
|
|
|
QString image( const QString& name ) const;
|
2006-12-16 23:04:44 +00:00
|
|
|
|
2007-04-22 09:35:04 +00:00
|
|
|
Q_SIGNALS:
|
2007-05-29 07:56:58 +00:00
|
|
|
/**
|
|
|
|
* Emitted when the user changes the theme. SVGs should be reloaded at
|
|
|
|
* that point
|
|
|
|
*/
|
2006-12-16 23:04:44 +00:00
|
|
|
void changed();
|
|
|
|
|
2007-07-17 20:51:12 +00:00
|
|
|
public Q_SLOTS:
|
|
|
|
/**
|
|
|
|
* Notifies the Theme object that the theme settings have changed
|
|
|
|
* and should be read from the config file
|
|
|
|
**/
|
|
|
|
void settingsChanged();
|
|
|
|
|
2006-12-16 23:04:44 +00:00
|
|
|
private:
|
|
|
|
class Private;
|
2007-05-21 14:28:03 +00:00
|
|
|
Private* const d;
|
2006-12-16 23:04:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // Plasma namespace
|
|
|
|
|
|
|
|
#endif // multiple inclusion guard
|
|
|
|
|