Browse Source

Fix caching

Ivan Savenko 2 years ago
parent
commit
d21c41e436

BIN
Mods/vcmi/Data/debug/cached.png


+ 3 - 0
client/mapRenderer/MapRendererContext.cpp

@@ -113,6 +113,9 @@ size_t MapRendererContext::terrainImageIndex(size_t groupSize) const
 
 bool MapRendererContext::tileAnimated(const int3 & coordinates) const
 {
+	if (!isInMap(coordinates))
+		return false;
+
 	if(movementAnimation)
 	{
 		auto objects = getObjects(coordinates);

+ 2 - 2
client/mapRenderer/MapViewCache.cpp

@@ -66,7 +66,7 @@ void MapViewCache::updateTile(const std::shared_ptr<const IMapRendererContext> &
 	newCacheEntry.tileY = coordinates.y;
 	newCacheEntry.checksum = mapRenderer->getTileChecksum(*context, coordinates);
 
-	if(cachedLevel == coordinates.z && oldCacheEntry == newCacheEntry)
+	if(cachedLevel == coordinates.z && oldCacheEntry == newCacheEntry && !context->tileAnimated(coordinates))
 	{
 		// debug code to check caching - cached tiles will slowly fade to black
 		//static const auto overlay = IImage::createFromFile("debug/cached");
@@ -132,7 +132,7 @@ void MapViewCache::render(const std::shared_ptr<const IMapRendererContext> & con
 			int cacheY = (terrainChecksum.shape()[1] + y) % terrainChecksum.shape()[1];
 			int3 tile(x, y, model->getLevel());
 
-			if(lazyUpdate && tilesUpToDate[cacheX][cacheY] && !context->tileAnimated(tile))
+			if(lazyUpdate && tilesUpToDate[cacheX][cacheY])
 				continue;
 
 			Canvas source = getTile(tile);