summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2013-09-13 00:49:42 +0300
committerAndrei Karas <akaras@inbox.ru>2013-09-13 00:49:42 +0300
commite71aed97c2d885c8113561c1e0cad91454adeb57 (patch)
tree0ff10712fa74fd8835cc3a978b088ee9937cb681
parent7ae98a6a6626f47e613739812b75d2c42f16048e (diff)
downloadmanaplus-e71aed97c2d885c8113561c1e0cad91454adeb57.tar.gz
manaplus-e71aed97c2d885c8113561c1e0cad91454adeb57.tar.bz2
manaplus-e71aed97c2d885c8113561c1e0cad91454adeb57.tar.xz
manaplus-e71aed97c2d885c8113561c1e0cad91454adeb57.zip
fix animaed tiles in csv map format.
-rw-r--r--src/resources/mapreader.cpp16
1 files changed, 15 insertions, 1 deletions
diff --git a/src/resources/mapreader.cpp b/src/resources/mapreader.cpp
index 7481ad948..4f39c80a3 100644
--- a/src/resources/mapreader.cpp
+++ b/src/resources/mapreader.cpp
@@ -538,7 +538,7 @@ bool MapReader::readBase64Layer(const XmlNodePtr childNode, Map *const map,
}
}
- std::map<int, TileAnimation*> &tileAnimations
+ const std::map<int, TileAnimation*> &tileAnimations
= map->getTileAnimations();
const bool hasAnimations = !tileAnimations.empty();
@@ -592,6 +592,10 @@ bool MapReader::readCsvLayer(const XmlNodePtr childNode, Map *const map,
std::string csv(data);
size_t oldPos = 0;
+ const std::map<int, TileAnimation*> &tileAnimations
+ = map->getTileAnimations();
+ const bool hasAnimations = !tileAnimations.empty();
+
while (oldPos != csv.npos)
{
const size_t pos = csv.find_first_of(",", oldPos);
@@ -600,6 +604,16 @@ bool MapReader::readCsvLayer(const XmlNodePtr childNode, Map *const map,
const int gid = atoi(csv.substr(oldPos, pos - oldPos).c_str());
setTile(map, layer, x, y, gid);
+ if (hasAnimations)
+ {
+ TileAnimationMapCIter it = tileAnimations.find(gid);
+ if (it != tileAnimations.end())
+ {
+ TileAnimation *const ani = it->second;
+ if (ani)
+ ani->addAffectedTile(layer, x + y * w);
+ }
+ }
x++;
if (x == w)