diff options
author | Andrei Karas <akaras@inbox.ru> | 2013-12-12 12:34:35 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2013-12-12 12:34:35 +0300 |
commit | 840fd10e1843ac4aac01595fe0701bc35a1bcfd3 (patch) | |
tree | ce75085aed4df1462740da046af1d050cf899485 /src/gui/widgets/desktop.cpp | |
parent | 6ef15759c7e598f4d0c49a262562c9135fab0e5e (diff) | |
download | manaplus-840fd10e1843ac4aac01595fe0701bc35a1bcfd3.tar.gz manaplus-840fd10e1843ac4aac01595fe0701bc35a1bcfd3.tar.bz2 manaplus-840fd10e1843ac4aac01595fe0701bc35a1bcfd3.tar.xz manaplus-840fd10e1843ac4aac01595fe0701bc35a1bcfd3.zip |
add theming for desktop object.
New theme file: desktop.xml
Theme options: showBackground - to show or hide background
versionX - version label position by x
versionY - version label position by y
Diffstat (limited to 'src/gui/widgets/desktop.cpp')
-rw-r--r-- | src/gui/widgets/desktop.cpp | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/src/gui/widgets/desktop.cpp b/src/gui/widgets/desktop.cpp index 9bbe91cbb..d2e132c56 100644 --- a/src/gui/widgets/desktop.cpp +++ b/src/gui/widgets/desktop.cpp @@ -38,13 +38,22 @@ Desktop::Desktop(const Widget2 *const widget) : gcn::WidgetListener(), mWallpaper(nullptr), mVersionLabel(nullptr), + mSkin(nullptr), mBackgroundColor(getThemeColor(Theme::BACKGROUND, 128)), - mBackgroundGrayColor(getThemeColor(Theme::BACKGROUND_GRAY)) + mBackgroundGrayColor(getThemeColor(Theme::BACKGROUND_GRAY)), + mShowBackground(true) { addWidgetListener(this); Wallpaper::loadWallpapers(); + Theme *const theme = Theme::instance(); + if (theme) + mSkin = theme->load("desktop.xml", ""); + + if (mSkin) + mShowBackground = mSkin->getOption("showBackground"); + const std::string appName = branding.getValue("appName", std::string()); if (appName.empty()) { @@ -66,11 +75,21 @@ Desktop::~Desktop() mWallpaper->decRef(); mWallpaper = nullptr; } + if (Theme::instance()) + Theme::instance()->unload(mSkin); } void Desktop::postInit() { - add(mVersionLabel, 25, 2); + if (mSkin) + { + add(mVersionLabel, mSkin->getOption("versionX", 25), + mSkin->getOption("versionY", 2)); + } + else + { + add(mVersionLabel, 25, 2); + } } void Desktop::reloadWallpaper() @@ -132,7 +151,7 @@ void Desktop::draw(gcn::Graphics *graphics) void Desktop::setBestFittingWallpaper() { - if (!config.getBoolValue("showBackground")) + if (!mShowBackground || !config.getBoolValue("showBackground")) return; const std::string wallpaperName = |