summaryrefslogtreecommitdiff
path: root/src/resources/db
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/resources/db
parent887a4d50d0c966af5f19e5ed2fe8b5556a6f818d (diff)
downloadmanaplus-34a04d798ed0b4f4b652082da994c8648e4517e6.tar.gz
manaplus-34a04d798ed0b4f4b652082da994c8648e4517e6.tar.bz2
manaplus-34a04d798ed0b4f4b652082da994c8648e4517e6.tar.xz
manaplus-34a04d798ed0b4f4b652082da994c8648e4517e6.zip
Add support for images in npc skined menu.
Diffstat (limited to 'src/resources/db')
-rw-r--r--src/resources/db/npcdialogdb.cpp18
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();