diff options
Diffstat (limited to 'src/gui/widgets')
-rw-r--r-- | src/gui/widgets/browserbox.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/button.cpp | 5 | ||||
-rw-r--r-- | src/gui/widgets/checkbox.cpp | 5 | ||||
-rw-r--r-- | src/gui/widgets/desktop.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/dropdown.cpp | 9 | ||||
-rw-r--r-- | src/gui/widgets/itemcontainer.cpp | 3 | ||||
-rw-r--r-- | src/gui/widgets/label.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/listbox.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/playerbox.cpp | 14 | ||||
-rw-r--r-- | src/gui/widgets/popup.cpp | 5 | ||||
-rw-r--r-- | src/gui/widgets/progressbar.cpp | 15 | ||||
-rw-r--r-- | src/gui/widgets/radiobutton.cpp | 5 | ||||
-rw-r--r-- | src/gui/widgets/scrollarea.cpp | 47 | ||||
-rw-r--r-- | src/gui/widgets/skillrectanglelistbox.h | 4 | ||||
-rw-r--r-- | src/gui/widgets/slider.cpp | 2 | ||||
-rw-r--r-- | src/gui/widgets/staticbrowserbox.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/tabs/tab.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/textfield.cpp | 9 | ||||
-rw-r--r-- | src/gui/widgets/textpreview.cpp | 7 | ||||
-rw-r--r-- | src/gui/widgets/window.cpp | 5 |
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()); |