summaryrefslogtreecommitdiff
path: root/src/gui/widgets
diff options
context:
space:
mode:
Diffstat (limited to 'src/gui/widgets')
-rw-r--r--src/gui/widgets/browserbox.cpp7
-rw-r--r--src/gui/widgets/button.cpp5
-rw-r--r--src/gui/widgets/checkbox.cpp5
-rw-r--r--src/gui/widgets/desktop.cpp7
-rw-r--r--src/gui/widgets/dropdown.cpp9
-rw-r--r--src/gui/widgets/itemcontainer.cpp3
-rw-r--r--src/gui/widgets/label.cpp7
-rw-r--r--src/gui/widgets/listbox.cpp7
-rw-r--r--src/gui/widgets/playerbox.cpp14
-rw-r--r--src/gui/widgets/popup.cpp5
-rw-r--r--src/gui/widgets/progressbar.cpp15
-rw-r--r--src/gui/widgets/radiobutton.cpp5
-rw-r--r--src/gui/widgets/scrollarea.cpp47
-rw-r--r--src/gui/widgets/skillrectanglelistbox.h4
-rw-r--r--src/gui/widgets/slider.cpp2
-rw-r--r--src/gui/widgets/staticbrowserbox.cpp7
-rw-r--r--src/gui/widgets/tabs/tab.cpp7
-rw-r--r--src/gui/widgets/textfield.cpp9
-rw-r--r--src/gui/widgets/textpreview.cpp7
-rw-r--r--src/gui/widgets/window.cpp5
20 files changed, 138 insertions, 39 deletions
diff --git a/src/gui/widgets/browserbox.cpp b/src/gui/widgets/browserbox.cpp
index 1f973c85e..fc9ae9698 100644
--- a/src/gui/widgets/browserbox.cpp
+++ b/src/gui/widgets/browserbox.cpp
@@ -100,7 +100,12 @@ BrowserBox::BrowserBox(const Widget2 *const widget,
mBackgroundColor = getThemeColor(ThemeColorId::BACKGROUND, 255U);
if (theme != nullptr)
- mSkin = theme->load(skin, "browserbox.xml");
+ {
+ mSkin = theme->load(skin,
+ "browserbox.xml",
+ true,
+ theme->getThemePath());
+ }
if (mInstances == 0)
{
mEmotes = Loader::getImageSet(
diff --git a/src/gui/widgets/button.cpp b/src/gui/widgets/button.cpp
index 25986ef8a..f8ddbc8f4 100644
--- a/src/gui/widgets/button.cpp
+++ b/src/gui/widgets/button.cpp
@@ -360,7 +360,10 @@ void Button::init()
{
for (int mode = 0; mode < BUTTON_COUNT; mode ++)
{
- Skin *const skin = theme->load(data[mode], "button.xml");
+ Skin *const skin = theme->load(data[mode],
+ "button.xml",
+ true,
+ theme->getThemePath());
if (skin != nullptr)
{
button[mode] = skin;
diff --git a/src/gui/widgets/checkbox.cpp b/src/gui/widgets/checkbox.cpp
index 8424c5c0e..81daf7cad 100644
--- a/src/gui/widgets/checkbox.cpp
+++ b/src/gui/widgets/checkbox.cpp
@@ -117,7 +117,10 @@ CheckBox::CheckBox(const Widget2 *const widget,
{
if (theme != nullptr)
{
- mSkin = theme->load("checkbox.xml", "");
+ mSkin = theme->load("checkbox.xml",
+ "",
+ true,
+ theme->getThemePath());
updateAlpha();
}
}
diff --git a/src/gui/widgets/desktop.cpp b/src/gui/widgets/desktop.cpp
index 4fe56676b..7a56035fb 100644
--- a/src/gui/widgets/desktop.cpp
+++ b/src/gui/widgets/desktop.cpp
@@ -65,7 +65,12 @@ Desktop::Desktop(const Widget2 *const widget) :
Wallpaper::loadWallpapers();
if (theme != nullptr)
- mSkin = theme->load("desktop.xml", "");
+ {
+ mSkin = theme->load("desktop.xml",
+ "",
+ true,
+ theme->getThemePath());
+ }
if (mSkin != nullptr)
mShowBackground = (mSkin->getOption("showBackground") != 0);
diff --git a/src/gui/widgets/dropdown.cpp b/src/gui/widgets/dropdown.cpp
index 7e9de9b53..1f8b54bc1 100644
--- a/src/gui/widgets/dropdown.cpp
+++ b/src/gui/widgets/dropdown.cpp
@@ -89,7 +89,10 @@ DropDown::DropDown(const Widget2 *const widget,
// Load the background skin
for (int i = 0; i < 2; i ++)
{
- Skin *const skin = theme->load(dropdownFiles[i], "dropdown.xml");
+ Skin *const skin = theme->load(dropdownFiles[i],
+ "dropdown.xml",
+ true,
+ theme->getThemePath());
if (skin != nullptr)
{
if (i == 0)
@@ -119,7 +122,7 @@ DropDown::DropDown(const Widget2 *const widget,
}
// get the border skin
- theme->loadRect(skinRect, "dropdown_background.xml", "");
+ theme->loadRect(skinRect, "dropdown_background.xml", "", 0, 8);
}
instances++;
@@ -179,7 +182,7 @@ DropDown::~DropDown()
if (theme != nullptr)
{
theme->unload(mSkin);
- Theme::unloadRect(skinRect);
+ Theme::unloadRect(skinRect, 0, 8);
}
}
}
diff --git a/src/gui/widgets/itemcontainer.cpp b/src/gui/widgets/itemcontainer.cpp
index fa9fc957e..19d3a30b3 100644
--- a/src/gui/widgets/itemcontainer.cpp
+++ b/src/gui/widgets/itemcontainer.cpp
@@ -236,7 +236,8 @@ ItemContainer::ItemContainer(const Widget2 *const widget,
mCellBackgroundImg(Theme::getImageFromThemeXml("inventory_cell.xml", "")),
mName(),
mShowMatrix(nullptr),
- mSkin(theme != nullptr ? theme->load("itemcontainer.xml", "") : nullptr),
+ mSkin(theme != nullptr ? theme->load("itemcontainer.xml", "",
+ true, theme->getThemePath()) : nullptr),
mVertexes(new ImageCollection),
mEquipedColor(getThemeColor(ThemeColorId::ITEM_EQUIPPED, 255U)),
mEquipedColor2(getThemeColor(ThemeColorId::ITEM_EQUIPPED_OUTLINE, 255U)),
diff --git a/src/gui/widgets/label.cpp b/src/gui/widgets/label.cpp
index c4d8d14f6..6fb3ae39e 100644
--- a/src/gui/widgets/label.cpp
+++ b/src/gui/widgets/label.cpp
@@ -131,7 +131,12 @@ void Label::init()
if (mInstances == 0)
{
if (theme != nullptr)
- mSkin = theme->load("label.xml", "");
+ {
+ mSkin = theme->load("label.xml",
+ "",
+ true,
+ theme->getThemePath());
+ }
}
mInstances ++;
diff --git a/src/gui/widgets/listbox.cpp b/src/gui/widgets/listbox.cpp
index eabf26e19..dcb0c4c9c 100644
--- a/src/gui/widgets/listbox.cpp
+++ b/src/gui/widgets/listbox.cpp
@@ -118,7 +118,12 @@ ListBox::ListBox(const Widget2 *const widget,
mForegroundColor2 = getThemeColor(ThemeColorId::LISTBOX_OUTLINE, 255U);
if (theme != nullptr)
- mSkin = theme->load(skin, "listbox.xml");
+ {
+ mSkin = theme->load(skin,
+ "listbox.xml",
+ true,
+ theme->getThemePath());
+ }
if (mSkin != nullptr)
{
diff --git a/src/gui/widgets/playerbox.cpp b/src/gui/widgets/playerbox.cpp
index b6217383f..98e6e8d5a 100644
--- a/src/gui/widgets/playerbox.cpp
+++ b/src/gui/widgets/playerbox.cpp
@@ -79,8 +79,8 @@ PlayerBox::~PlayerBox()
if (gui != nullptr)
gui->removeDragged(this);
- Theme::unloadRect(mBackground);
- Theme::unloadRect(mSelectedBackground);
+ Theme::unloadRect(mBackground, 0, 8);
+ Theme::unloadRect(mSelectedBackground, 0, 8);
mBeing = nullptr;
}
@@ -95,7 +95,10 @@ void PlayerBox::init(std::string name, std::string selectedName)
if (name.empty())
name = "playerbox.xml";
mSkin = theme->loadSkinRect(mBackground,
- name, "playerbox_background.xml");
+ name,
+ "playerbox_background.xml",
+ 0,
+ 8);
if (mSkin != nullptr)
{
mDrawBackground = (mSkin->getOption("drawbackground") != 0);
@@ -106,7 +109,10 @@ void PlayerBox::init(std::string name, std::string selectedName)
if (selectedName.empty())
selectedName = "playerboxselected.xml";
mSelectedSkin = theme->loadSkinRect(mSelectedBackground,
- selectedName, "playerbox_background.xml");
+ selectedName,
+ "playerbox_background.xml",
+ 0,
+ 8);
}
else
{
diff --git a/src/gui/widgets/popup.cpp b/src/gui/widgets/popup.cpp
index 0f5c5a31a..0ab2c27c8 100644
--- a/src/gui/widgets/popup.cpp
+++ b/src/gui/widgets/popup.cpp
@@ -62,7 +62,10 @@ Popup::Popup(const std::string &name,
if (theme != nullptr)
{
- mSkin = theme->load(skin, "popup.xml");
+ mSkin = theme->load(skin,
+ "popup.xml",
+ true,
+ theme->getThemePath());
if (mSkin != nullptr)
{
setPadding(mSkin->getPadding());
diff --git a/src/gui/widgets/progressbar.cpp b/src/gui/widgets/progressbar.cpp
index f1889e979..0e01876f5 100644
--- a/src/gui/widgets/progressbar.cpp
+++ b/src/gui/widgets/progressbar.cpp
@@ -83,14 +83,23 @@ ProgressBar::ProgressBar(const Widget2 *const widget,
if (theme != nullptr)
{
- mSkin = theme->load(skin, "progressbar.xml");
+ mSkin = theme->load(skin,
+ "progressbar.xml",
+ true,
+ theme->getThemePath());
if (mSkin != nullptr)
{
setPadding(mSkin->getPadding());
mFillPadding = mSkin->getOption("fillPadding");
mFillImage = mSkin->getOption("fillImage") != 0;
if (mFillImage)
- theme->loadRect(mFillRect, skinFill, "progressbar_fill.xml");
+ {
+ theme->loadRect(mFillRect,
+ skinFill,
+ "progressbar_fill.xml",
+ 0,
+ 8);
+ }
}
setHeight(2 * mPadding + getFont()->getHeight() + 2);
}
@@ -110,7 +119,7 @@ ProgressBar::~ProgressBar()
theme->unload(mSkin);
mSkin = nullptr;
}
- Theme::unloadRect(mFillRect);
+ Theme::unloadRect(mFillRect, 0, 8);
delete2(mVertexes);
mTextChunk.deleteImage();
}
diff --git a/src/gui/widgets/radiobutton.cpp b/src/gui/widgets/radiobutton.cpp
index c2e9ad505..62b5bae48 100644
--- a/src/gui/widgets/radiobutton.cpp
+++ b/src/gui/widgets/radiobutton.cpp
@@ -121,7 +121,10 @@ RadioButton::RadioButton(const Widget2 *const widget,
{
if (theme != nullptr)
{
- mSkin = theme->load("radio.xml", "");
+ mSkin = theme->load("radio.xml",
+ "",
+ true,
+ theme->getThemePath());
updateAlpha();
}
}
diff --git a/src/gui/widgets/scrollarea.cpp b/src/gui/widgets/scrollarea.cpp
index e22ecdcf3..a99d5cc3c 100644
--- a/src/gui/widgets/scrollarea.cpp
+++ b/src/gui/widgets/scrollarea.cpp
@@ -157,11 +157,11 @@ ScrollArea::~ScrollArea()
instances--;
if (instances == 0)
{
- Theme::unloadRect(background);
- Theme::unloadRect(vMarker);
- Theme::unloadRect(vMarkerHi);
- Theme::unloadRect(vBackground);
- Theme::unloadRect(hBackground);
+ Theme::unloadRect(background, 0, 8);
+ Theme::unloadRect(vMarker, 0, 8);
+ Theme::unloadRect(vMarkerHi, 0, 8);
+ Theme::unloadRect(vBackground, 0, 8);
+ Theme::unloadRect(hBackground, 0, 8);
for (int i = 0; i < 2; i ++)
{
for (int f = UP; f < BUTTONS_DIR; f ++)
@@ -203,18 +203,43 @@ void ScrollArea::init(std::string skinName)
skinName = "scroll_background.xml";
if (theme != nullptr)
{
- theme->loadRect(background, skinName, "scroll_background.xml");
- theme->loadRect(vMarker, "scroll.xml", "");
- theme->loadRect(vMarkerHi, "scroll_highlighted.xml", "scroll.xml");
- theme->loadRect(vBackground, "scroll_vbackground.xml", "");
- theme->loadRect(hBackground, "scroll_hbackground.xml", "");
+ theme->loadRect(background,
+ skinName,
+ "scroll_background.xml",
+ 0,
+ 8);
+ theme->loadRect(vMarker,
+ "scroll.xml",
+ "",
+ 0,
+ 8);
+ theme->loadRect(vMarkerHi,
+ "scroll_highlighted.xml",
+ "scroll.xml",
+ 0,
+ 8);
+ theme->loadRect(vBackground,
+ "scroll_vbackground.xml",
+ "",
+ 0,
+ 8);
+ theme->loadRect(hBackground,
+ "scroll_hbackground.xml",
+ "",
+ 0,
+ 8);
}
for (int i = 0; i < 2; i ++)
{
Skin *skin = nullptr;
if (theme != nullptr)
- skin = theme->load(buttonFiles[i], "scrollbuttons.xml");
+ {
+ skin = theme->load(buttonFiles[i],
+ "scrollbuttons.xml",
+ true,
+ theme->getThemePath());
+ }
if (skin != nullptr)
{
const ImageRect &rect = skin->getBorder();
diff --git a/src/gui/widgets/skillrectanglelistbox.h b/src/gui/widgets/skillrectanglelistbox.h
index 86ce542c6..671932d89 100644
--- a/src/gui/widgets/skillrectanglelistbox.h
+++ b/src/gui/widgets/skillrectanglelistbox.h
@@ -75,7 +75,9 @@ class SkillRectangleListBox final : public Widget,
if (theme != nullptr)
{
mSkin = theme->load("skillrectanglelistbox.xml",
- "listbox.xml");
+ "listbox.xml",
+ true,
+ theme->getThemePath());
}
if (mSkin != nullptr)
diff --git a/src/gui/widgets/slider.cpp b/src/gui/widgets/slider.cpp
index 0d25ad2c5..900df73a2 100644
--- a/src/gui/widgets/slider.cpp
+++ b/src/gui/widgets/slider.cpp
@@ -140,7 +140,7 @@ Slider::~Slider()
if (mInstances == 0)
{
for (int mode = 0; mode < 2; mode ++)
- Theme::unloadRect(buttons[mode]);
+ Theme::unloadRect(buttons[mode], 0, 8);
}
}
diff --git a/src/gui/widgets/staticbrowserbox.cpp b/src/gui/widgets/staticbrowserbox.cpp
index d602160b6..cd252cce1 100644
--- a/src/gui/widgets/staticbrowserbox.cpp
+++ b/src/gui/widgets/staticbrowserbox.cpp
@@ -95,7 +95,12 @@ StaticBrowserBox::StaticBrowserBox(const Widget2 *const widget,
mBackgroundColor = getThemeColor(ThemeColorId::BACKGROUND, 255U);
if (theme != nullptr)
- mSkin = theme->load(skin, "browserbox.xml");
+ {
+ mSkin = theme->load(skin,
+ "browserbox.xml",
+ true,
+ theme->getThemePath());
+ }
if (mInstances == 0)
{
mEmotes = Loader::getImageSet(
diff --git a/src/gui/widgets/tabs/tab.cpp b/src/gui/widgets/tabs/tab.cpp
index 88fe5d54f..9dc6c4068 100644
--- a/src/gui/widgets/tabs/tab.cpp
+++ b/src/gui/widgets/tabs/tab.cpp
@@ -165,7 +165,12 @@ void Tab::init()
if (theme != nullptr)
{
for (int mode = 0; mode < TAB_COUNT; mode ++)
- tabImg[mode] = theme->load(data[mode], "tab.xml");
+ {
+ tabImg[mode] = theme->load(data[mode],
+ "tab.xml",
+ true,
+ theme->getThemePath());
+ }
}
updateAlpha();
}
diff --git a/src/gui/widgets/textfield.cpp b/src/gui/widgets/textfield.cpp
index 8af2109d8..167d2b850 100644
--- a/src/gui/widgets/textfield.cpp
+++ b/src/gui/widgets/textfield.cpp
@@ -146,8 +146,11 @@ TextField::TextField(const Widget2 *restrict const widget,
{
if (theme != nullptr)
{
- mSkin = theme->loadSkinRect(skin, "textfield.xml",
- "textfield_background.xml");
+ mSkin = theme->loadSkinRect(skin,
+ "textfield.xml",
+ "textfield_background.xml",
+ 0,
+ 8);
}
}
@@ -181,7 +184,7 @@ TextField::~TextField()
if (theme != nullptr)
{
theme->unload(mSkin);
- Theme::unloadRect(skin);
+ Theme::unloadRect(skin, 0, 8);
}
}
mTextChunk.deleteImage();
diff --git a/src/gui/widgets/textpreview.cpp b/src/gui/widgets/textpreview.cpp
index 4d90f1f9c..3feaf08c0 100644
--- a/src/gui/widgets/textpreview.cpp
+++ b/src/gui/widgets/textpreview.cpp
@@ -56,7 +56,12 @@ TextPreview::TextPreview(const Widget2 *const widget,
if (instances == 0)
{
if (theme != nullptr)
- mSkin = theme->load("textpreview.xml", "");
+ {
+ mSkin = theme->load("textpreview.xml",
+ "",
+ true,
+ theme->getThemePath());
+ }
}
instances++;
diff --git a/src/gui/widgets/window.cpp b/src/gui/widgets/window.cpp
index 132b3f561..3fb6c458e 100644
--- a/src/gui/widgets/window.cpp
+++ b/src/gui/widgets/window.cpp
@@ -183,7 +183,10 @@ Window::Window(const std::string &caption,
// Loads the skin
if (theme != nullptr)
{
- mSkin = theme->load(skin, "window.xml");
+ mSkin = theme->load(skin,
+ "window.xml",
+ true,
+ theme->getThemePath());
if (mSkin != nullptr)
{
setPadding(mSkin->getPadding());