diff options
author | Andrei Karas <akaras@inbox.ru> | 2015-10-28 19:54:36 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2015-10-28 19:54:36 +0300 |
commit | 34a04d798ed0b4f4b652082da994c8648e4517e6 (patch) | |
tree | b7d98ca0f2b9e187c7eeec92ab60b7f5f25dface /src/resources/db | |
parent | 887a4d50d0c966af5f19e5ed2fe8b5556a6f818d (diff) | |
download | plus-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/resources/db')
-rw-r--r-- | src/resources/db/npcdialogdb.cpp | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/src/resources/db/npcdialogdb.cpp b/src/resources/db/npcdialogdb.cpp index cdb96a2ee..86bc712f2 100644 --- a/src/resources/db/npcdialogdb.cpp +++ b/src/resources/db/npcdialogdb.cpp @@ -80,6 +80,22 @@ static void loadNpcDialog(NpcDialogInfo *const dialog, childNode, "imageHeight", 16, 1, 1000); dialog->buttons.push_back(button); } + else if (xmlNameEqual(childNode, "image")) + { + const std::string image = XML::getProperty(childNode, "image", ""); + if (image.empty()) + { + logger->log("Error: no image attribute found in image tag."); + continue; + } + NpcImageInfo *const imageInfo = new NpcImageInfo; + imageInfo->name = image; + imageInfo->x = XML::getIntProperty( + childNode, "x", 0, 0, 10000); + imageInfo->y = XML::getIntProperty( + childNode, "y", 0, 0, 10000); + dialog->images.push_back(imageInfo); + } } } @@ -132,6 +148,7 @@ void NpcDialogDB::deleteDialog(const std::string &name) NpcDialogInfo *dialog = (*it).second; delete_all(dialog->buttons); + delete_all(dialog->images); mDialogs.erase(it); delete dialog; } @@ -144,6 +161,7 @@ void NpcDialogDB::unload() { NpcDialogInfo *dialog = (*it).second; delete_all(dialog->buttons); + delete_all(dialog->images); delete dialog; } mDialogs.clear(); |