瀏覽代碼

Merge pull request #2085 from Nordsoft91/mapeditor-fix

[1.2.1] Fix portrait serialization
Ivan Savenko 2 年之前
父節點
當前提交
3ae4819fcb
共有 1 個文件被更改,包括 10 次插入1 次删除
  1. 10 1
      lib/mapObjects/CGHeroInstance.cpp

+ 10 - 1
lib/mapObjects/CGHeroInstance.cpp

@@ -1469,7 +1469,12 @@ void CGHeroInstance::serializeCommonOptions(JsonSerializeFormat & handler)
 			if(portrait >= 0)
 			if(portrait >= 0)
 			{
 			{
 				if(portrait < legacyHeroes || portrait >= moddedStart)
 				if(portrait < legacyHeroes || portrait >= moddedStart)
-					handler.serializeId<si32, si32, HeroTypeID>("portrait", portrait, -1);
+				{
+					int tempPortrait = portrait >= moddedStart
+						? portrait - GameConstants::HERO_PORTRAIT_SHIFT
+						: portrait;
+					handler.serializeId<si32, si32, HeroTypeID>("portrait", tempPortrait, -1);
+				}
 				else
 				else
 					handler.serializeInt("portrait", portrait, -1);
 					handler.serializeInt("portrait", portrait, -1);
 			}
 			}
@@ -1479,7 +1484,11 @@ void CGHeroInstance::serializeCommonOptions(JsonSerializeFormat & handler)
 			const JsonNode & portraitNode = handler.getCurrent()["portrait"];
 			const JsonNode & portraitNode = handler.getCurrent()["portrait"];
 
 
 			if(portraitNode.getType() == JsonNode::JsonType::DATA_STRING)
 			if(portraitNode.getType() == JsonNode::JsonType::DATA_STRING)
+			{
 				handler.serializeId<si32, si32, HeroTypeID>("portrait", portrait, -1);
 				handler.serializeId<si32, si32, HeroTypeID>("portrait", portrait, -1);
+				if(portrait >= legacyHeroes)
+					portrait += GameConstants::HERO_PORTRAIT_SHIFT;
+			}
 			else
 			else
 				handler.serializeInt("portrait", portrait, -1);
 				handler.serializeInt("portrait", portrait, -1);
 		}
 		}