add Theme::currentThemeHasImage() that checks if the current theme has a
certain svg or if it would fallback to the default theme if loaded. this makes possible an alternative fallback mechanism between images of the same theme, used now for the TransparentBackground background hint svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=816734
This commit is contained in:
parent
e729dcd481
commit
5ddceb467b
@ -574,13 +574,8 @@ void Applet::setBackgroundHints(const BackgroundHints hints)
|
|||||||
d->background = new Plasma::PanelSvg();
|
d->background = new Plasma::PanelSvg();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hints & TranslucentBackground) {
|
if ((hints & TranslucentBackground) && Plasma::Theme::defaultTheme()->currentThemeHasImage("widgets/translucentbackground")) {
|
||||||
d->background->setImagePath("widgets/translucentbackground");
|
d->background->setImagePath("widgets/translucentbackground");
|
||||||
|
|
||||||
//FIXME: this fallback is an hack, an api like Plasma::Theme::hasImage() would be needed to make this clean
|
|
||||||
if (!Plasma::Theme::defaultTheme()->imagePath("widgets/translucentbackground").contains(Plasma::Theme::defaultTheme()->themeName())) {
|
|
||||||
d->background->setImagePath("widgets/background");
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
d->background->setImagePath("widgets/background");
|
d->background->setImagePath("widgets/background");
|
||||||
}
|
}
|
||||||
|
@ -259,6 +259,11 @@ QString Theme::imagePath(const QString& name) const
|
|||||||
return path;
|
return path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Theme::currentThemeHasImage(const QString& name) const
|
||||||
|
{
|
||||||
|
return (!d->findInTheme(name, d->themeName).isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
KSharedConfigPtr Theme::colorScheme() const
|
KSharedConfigPtr Theme::colorScheme() const
|
||||||
{
|
{
|
||||||
return d->colors;
|
return d->colors;
|
||||||
|
9
theme.h
9
theme.h
@ -100,6 +100,15 @@ class PLASMA_EXPORT Theme : public QObject
|
|||||||
*/
|
*/
|
||||||
Q_INVOKABLE QString imagePath( const QString& name ) const;
|
Q_INVOKABLE QString imagePath( const QString& name ) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks if this theme has an image named in a certain way
|
||||||
|
*
|
||||||
|
* @arg name the name of the file in the theme directory (without the
|
||||||
|
* ".svg" part or a leading slash)
|
||||||
|
* @return true if the image exists for this theme
|
||||||
|
*/
|
||||||
|
Q_INVOKABLE bool currentThemeHasImage(const QString& name) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the color scheme configurationthat goes along this theme.
|
* Returns the color scheme configurationthat goes along this theme.
|
||||||
* This can be used with KStatefulBrush and KColorScheme to determine
|
* This can be used with KStatefulBrush and KColorScheme to determine
|
||||||
|
Loading…
x
Reference in New Issue
Block a user