diff options
author | Andrei Karas <akaras@inbox.ru> | 2013-09-03 21:03:23 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2013-09-03 21:03:23 +0300 |
commit | 6938df9b82239a23637181f0de6f478336a0c33e (patch) | |
tree | 5f4558276759b8c959ea4e6352bca9a8f6732c6e | |
parent | 85accb7f6f5fdfa9f5861ef364be51be37b34513 (diff) | |
download | manaplus-6938df9b82239a23637181f0de6f478336a0c33e.tar.gz manaplus-6938df9b82239a23637181f0de6f478336a0c33e.tar.bz2 manaplus-6938df9b82239a23637181f0de6f478336a0c33e.tar.xz manaplus-6938df9b82239a23637181f0de6f478336a0c33e.zip |
show icon on protected items.
-rw-r--r-- | data/graphics/gui/CMakeLists.txt | 1 | ||||
-rw-r--r-- | data/graphics/gui/Makefile.am | 1 | ||||
-rw-r--r-- | data/graphics/gui/lock.png | bin | 0 -> 391 bytes | |||
-rw-r--r-- | src/gui/widgets/itemcontainer.cpp | 12 | ||||
-rw-r--r-- | src/gui/widgets/itemcontainer.h | 1 |
5 files changed, 15 insertions, 0 deletions
diff --git a/data/graphics/gui/CMakeLists.txt b/data/graphics/gui/CMakeLists.txt index 439542f66..afb414b4c 100644 --- a/data/graphics/gui/CMakeLists.txt +++ b/data/graphics/gui/CMakeLists.txt @@ -36,6 +36,7 @@ SET (FILES keyboard_icon.xml label.xml listbox.xml + lock.png ministatus.xml mouse.png npc.xml diff --git a/data/graphics/gui/Makefile.am b/data/graphics/gui/Makefile.am index 710cf0688..c3c8f5990 100644 --- a/data/graphics/gui/Makefile.am +++ b/data/graphics/gui/Makefile.am @@ -39,6 +39,7 @@ gui_DATA = \ keyboard_icon.xml \ label.xml \ listbox.xml \ + lock.png \ ministatus.xml \ mouse.png \ npc.xml \ diff --git a/data/graphics/gui/lock.png b/data/graphics/gui/lock.png Binary files differnew file mode 100644 index 000000000..457195c7a --- /dev/null +++ b/data/graphics/gui/lock.png diff --git a/src/gui/widgets/itemcontainer.cpp b/src/gui/widgets/itemcontainer.cpp index 99aedabcd..5ed03c516 100644 --- a/src/gui/widgets/itemcontainer.cpp +++ b/src/gui/widgets/itemcontainer.cpp @@ -166,6 +166,7 @@ ItemContainer::ItemContainer(const Widget2 *const widget, gcn::WidgetListener(), mInventory(inventory), mSelImg(Theme::getImageFromThemeXml("item_selection.xml", "")), + mProtectedImg(Theme::getImageFromTheme("lock.png")), mName(), mItemPopup(new ItemPopup), mShowMatrix(nullptr), @@ -211,6 +212,12 @@ ItemContainer::~ItemContainer() mSelImg->decRef(); mSelImg = nullptr; } + if (mProtectedImg) + { + mProtectedImg->decRef(); + mProtectedImg = nullptr; + } + if (Theme::instance()) Theme::instance()->unload(mSkin); @@ -278,6 +285,11 @@ void ItemContainer::draw(gcn::Graphics *graphics) image->setAlpha(1.0f); // ensure the image if fully drawn... g->drawImage(image, itemX + mPaddingItemX, itemY + mPaddingItemY); + if (mProtectedImg && PlayerInfo::isItemProtected(item->getId())) + { + g->drawImage(mProtectedImg, itemX + mPaddingItemX, + itemY + mPaddingItemY); + } } } } diff --git a/src/gui/widgets/itemcontainer.h b/src/gui/widgets/itemcontainer.h index da9167a7e..d17261c1c 100644 --- a/src/gui/widgets/itemcontainer.h +++ b/src/gui/widgets/itemcontainer.h @@ -194,6 +194,7 @@ class ItemContainer final : public gcn::Widget, Inventory *mInventory; Image *mSelImg; + Image *mProtectedImg; std::string mName; ItemPopup *mItemPopup; |