summaryrefslogtreecommitdiff
path: root/src/gui/widgets
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2015-10-28 19:54:36 +0300
committerAndrei Karas <akaras@inbox.ru>2015-10-28 19:54:36 +0300
commit34a04d798ed0b4f4b652082da994c8648e4517e6 (patch)
treeb7d98ca0f2b9e187c7eeec92ab60b7f5f25dface /src/gui/widgets
parent887a4d50d0c966af5f19e5ed2fe8b5556a6f818d (diff)
downloadplus-34a04d798ed0b4f4b652082da994c8648e4517e6.tar.gz
plus-34a04d798ed0b4f4b652082da994c8648e4517e6.tar.bz2
plus-34a04d798ed0b4f4b652082da994c8648e4517e6.tar.xz
plus-34a04d798ed0b4f4b652082da994c8648e4517e6.zip
Add support for images in npc skined menu.
Diffstat (limited to 'src/gui/widgets')
-rw-r--r--src/gui/widgets/icon.cpp14
-rw-r--r--src/gui/widgets/icon.h9
2 files changed, 17 insertions, 6 deletions
diff --git a/src/gui/widgets/icon.cpp b/src/gui/widgets/icon.cpp
index 5876b1201..6c44cdc3a 100644
--- a/src/gui/widgets/icon.cpp
+++ b/src/gui/widgets/icon.cpp
@@ -30,9 +30,11 @@
#include "debug.h"
Icon::Icon(const Widget2 *const widget,
- const std::string &file) :
+ const std::string &file,
+ const AutoRelease autoRelease) :
Widget(widget),
- mImage(resourceManager->getImage(file))
+ mImage(resourceManager->getImage(file)),
+ mAutoRelease(autoRelease)
{
if (mImage)
{
@@ -43,9 +45,11 @@ Icon::Icon(const Widget2 *const widget,
}
Icon::Icon(const Widget2 *const widget,
- Image *const image) :
+ Image *const image,
+ const AutoRelease autoRelease) :
Widget(widget),
- mImage(image)
+ mImage(image),
+ mAutoRelease(autoRelease)
{
if (mImage)
{
@@ -59,6 +63,8 @@ Icon::~Icon()
{
if (gui)
gui->removeDragged(this);
+ if (mImage && mAutoRelease == AutoRelease_true)
+ mImage->decRef();
}
void Icon::setImage(Image *const image)
diff --git a/src/gui/widgets/icon.h b/src/gui/widgets/icon.h
index e48f71b24..c54c314ba 100644
--- a/src/gui/widgets/icon.h
+++ b/src/gui/widgets/icon.h
@@ -25,6 +25,8 @@
#include "gui/widgets/widget.h"
+#include "enums/simpletypes/autorelease.h"
+
#include "localconsts.h"
class Image;
@@ -41,13 +43,15 @@ class Icon final : public Widget
* Constructor.
*/
Icon(const Widget2 *const widget,
- const std::string &filename);
+ const std::string &filename,
+ const AutoRelease autoRelease = AutoRelease_false);
/**
* Constructor, uses an existing Image.
*/
Icon(const Widget2 *const widget,
- Image *const image);
+ Image *const image,
+ const AutoRelease autoRelease = AutoRelease_false);
A_DELETE_COPY(Icon)
@@ -73,6 +77,7 @@ class Icon final : public Widget
private:
Image *mImage;
+ AutoRelease mAutoRelease;
};
#endif // GUI_WIDGETS_ICON_H