|  | @@ -218,7 +218,7 @@ void CPlayerInterface::yourTurn()
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  STRONG_INLINE void subRect(const int & x, const int & y, const int & z, const SDL_Rect & r, const ObjectInstanceID & hid)
 |  |  STRONG_INLINE void subRect(const int & x, const int & y, const int & z, const SDL_Rect & r, const ObjectInstanceID & hid)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -	TerrainTile2 & hlp = CGI->mh->ttiles[x][y][z];
 |  | 
 | 
											
												
													
														|  | 
 |  | +	TerrainTile2 & hlp = CGI->mh->ttiles[z][x][y];
 | 
											
												
													
														|  |  	for (auto & elem : hlp.objects)
 |  |  	for (auto & elem : hlp.objects)
 | 
											
												
													
														|  |  		if (elem.obj && elem.obj->id == hid)
 |  |  		if (elem.obj && elem.obj->id == hid)
 | 
											
												
													
														|  |  		{
 |  |  		{
 | 
											
										
											
												
													
														|  | @@ -229,7 +229,7 @@ STRONG_INLINE void subRect(const int & x, const int & y, const int & z, const SD
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  STRONG_INLINE void delObjRect(const int & x, const int & y, const int & z, const ObjectInstanceID & hid)
 |  |  STRONG_INLINE void delObjRect(const int & x, const int & y, const int & z, const ObjectInstanceID & hid)
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | -	TerrainTile2 & hlp = CGI->mh->ttiles[x][y][z];
 |  | 
 | 
											
												
													
														|  | 
 |  | +	TerrainTile2 & hlp = CGI->mh->ttiles[z][x][y];
 | 
											
												
													
														|  |  	for (int h=0; h<hlp.objects.size(); ++h)
 |  |  	for (int h=0; h<hlp.objects.size(); ++h)
 | 
											
												
													
														|  |  		if (hlp.objects[h].obj && hlp.objects[h].obj->id == hid)
 |  |  		if (hlp.objects[h].obj && hlp.objects[h].obj->id == hid)
 | 
											
												
													
														|  |  		{
 |  |  		{
 | 
											
										
											
												
													
														|  | @@ -244,6 +244,7 @@ void CPlayerInterface::heroMoved(const TryMoveHero & details, bool verbose)
 | 
											
												
													
														|  |  	if(LOCPLINT != this)
 |  |  	if(LOCPLINT != this)
 | 
											
												
													
														|  |  		return;
 |  |  		return;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +	//FIXME: read once and store
 | 
											
												
													
														|  |  	if(settings["session"]["spectate"].Bool() && settings["session"]["spectate-ignore-hero"].Bool())
 |  |  	if(settings["session"]["spectate"].Bool() && settings["session"]["spectate-ignore-hero"].Bool())
 | 
											
												
													
														|  |  		return;
 |  |  		return;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -255,7 +256,7 @@ void CPlayerInterface::heroMoved(const TryMoveHero & details, bool verbose)
 | 
											
												
													
														|  |  		//AI hero left the visible area (we can't obtain info)
 |  |  		//AI hero left the visible area (we can't obtain info)
 | 
											
												
													
														|  |  		//TODO very evil workaround -> retrieve pointer to hero so we could animate it
 |  |  		//TODO very evil workaround -> retrieve pointer to hero so we could animate it
 | 
											
												
													
														|  |  		// TODO -> we should not need full CGHeroInstance structure to display animation or it should not be handled by playerint (but by the client itself)
 |  |  		// TODO -> we should not need full CGHeroInstance structure to display animation or it should not be handled by playerint (but by the client itself)
 | 
											
												
													
														|  | -		const TerrainTile2 & tile = CGI->mh->ttiles[hp.x - 1][hp.y][hp.z];
 |  | 
 | 
											
												
													
														|  | 
 |  | +		const TerrainTile2 & tile = CGI->mh->ttiles[hp.z][hp.x - 1][hp.y];
 | 
											
												
													
														|  |  		for(auto & elem : tile.objects)
 |  |  		for(auto & elem : tile.objects)
 | 
											
												
													
														|  |  			if(elem.obj && elem.obj->id == details.id)
 |  |  			if(elem.obj && elem.obj->id == details.id)
 | 
											
												
													
														|  |  				hero = dynamic_cast<const CGHeroInstance *>(elem.obj);
 |  |  				hero = dynamic_cast<const CGHeroInstance *>(elem.obj);
 | 
											
										
											
												
													
														|  | @@ -1738,41 +1739,43 @@ int CPlayerInterface::getLastIndex( std::string namePrefix)
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void CPlayerInterface::initMovement( const TryMoveHero &details, const CGHeroInstance * ho, const int3 &hp )
 |  |  void CPlayerInterface::initMovement( const TryMoveHero &details, const CGHeroInstance * ho, const int3 &hp )
 | 
											
												
													
														|  |  {
 |  |  {
 | 
											
												
													
														|  | 
 |  | +	auto subArr = (CGI->mh->ttiles)[hp.z];
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	if (details.end.x+1 == details.start.x && details.end.y+1 == details.start.y) //tl
 |  |  	if (details.end.x+1 == details.start.x && details.end.y+1 == details.start.y) //tl
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		//ho->moveDir = 1;
 |  |  		//ho->moveDir = 1;
 | 
											
												
													
														|  |  		ho->isStanding = false;
 |  |  		ho->isStanding = false;
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 1, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 33, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 65, -31)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-2][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 1, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-1][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 33, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 65, -31)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 1)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y-1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 1)));
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 1, 1), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 1, 1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 33, 1), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 33, 1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 65, 1), ho->id);
 |  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 65, 1), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 33)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 33)));
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, 1, 33), ho->id);
 |  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, 1, 33), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 33, 33), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 33, 33), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 65, 33), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 65, 33), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y-2].objects.begin(), subArr[hp.x-3][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-2][hp.y-2].objects.begin(), subArr[hp.x-2][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-1][hp.y-2].objects.begin(), subArr[hp.x-1][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x][hp.y-2].objects.begin(), subArr[hp.x][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y-1].objects.begin(), subArr[hp.x-3][hp.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y].objects.begin(), subArr[hp.x-3][hp.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x == details.start.x && details.end.y+1 == details.start.y) //t
 |  |  	else if (details.end.x == details.start.x && details.end.y+1 == details.start.y) //t
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		//ho->moveDir = 2;
 |  |  		//ho->moveDir = 2;
 | 
											
												
													
														|  |  		ho->isStanding = false;
 |  |  		ho->isStanding = false;
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 0, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 32, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 64, -31)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-2][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 0, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-1][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 32, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 64, -31)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 0, 1), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 0, 1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 32, 1), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 32, 1), ho->id);
 | 
											
										
											
												
													
														|  | @@ -1782,37 +1785,37 @@ void CPlayerInterface::initMovement( const TryMoveHero &details, const CGHeroIns
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 32, 33), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 32, 33), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 64, 33), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 64, 33), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-2][hp.y-2].objects.begin(), subArr[hp.x-2][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-1][hp.y-2].objects.begin(), subArr[hp.x-1][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x][hp.y-2].objects.begin(), subArr[hp.x][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x-1 == details.start.x && details.end.y+1 == details.start.y) //tr
 |  |  	else if (details.end.x-1 == details.start.x && details.end.y+1 == details.start.y) //tr
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		//ho->moveDir = 3;
 |  |  		//ho->moveDir = 3;
 | 
											
												
													
														|  |  		ho->isStanding = false;
 |  |  		ho->isStanding = false;
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -1, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 31, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 63, -31)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y-2][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, -31)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-2][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -1, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-1][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 31, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 63, -31)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y-2].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, -31)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, -1, 1), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, -1, 1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 31, 1), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 31, 1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 63, 1), ho->id);
 |  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 63, 1), ho->id);
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 1)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y-1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 1)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, -1, 33), ho->id);
 |  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, -1, 33), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 31, 33), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 31, 33), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 63, 33), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 63, 33), ho->id);
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 33)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 33)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-2][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-1][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y-2][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y-2][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-2][hp.y-2].objects.begin(), subArr[hp.x-2][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-1][hp.y-2].objects.begin(), subArr[hp.x-1][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x][hp.y-2].objects.begin(), subArr[hp.x][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y-2].objects.begin(), subArr[hp.x+1][hp.y-2].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y-1].objects.begin(), subArr[hp.x+1][hp.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y].objects.begin(), subArr[hp.x+1][hp.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x-1 == details.start.x && details.end.y == details.start.y) //r
 |  |  	else if (details.end.x-1 == details.start.x && details.end.y == details.start.y) //r
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
										
											
												
													
														|  | @@ -1821,16 +1824,16 @@ void CPlayerInterface::initMovement( const TryMoveHero &details, const CGHeroIns
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, -1, 0), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, -1, 0), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 31, 0), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 31, 0), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 63, 0), ho->id);
 |  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 63, 0), ho->id);
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 0)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y-1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 0)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, -1, 32), ho->id);
 |  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, -1, 32), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 31, 32), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 31, 32), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 63, 32), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 63, 32), ho->id);
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 32)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 32)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y-1].objects.begin(), subArr[hp.x+1][hp.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y].objects.begin(), subArr[hp.x+1][hp.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x-1 == details.start.x && details.end.y-1 == details.start.y) //br
 |  |  	else if (details.end.x-1 == details.start.x && details.end.y-1 == details.start.y) //br
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
										
											
												
													
														|  | @@ -1839,26 +1842,26 @@ void CPlayerInterface::initMovement( const TryMoveHero &details, const CGHeroIns
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, -1, -1), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, -1, -1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 31, -1), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 31, -1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 63, -1), ho->id);
 |  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 63, -1), ho->id);
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, -1)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y-1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, -1)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, -1, 31), ho->id);
 |  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, -1, 31), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 31, 31), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 31, 31), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 63, 31), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 63, 31), ho->id);
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 31)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 31)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -1, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 31, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 63, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x+1][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 63)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-2][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -1, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-1][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 31, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 63, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x+1][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 95, 63)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y-1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y-1].objects.begin(), subArr[hp.x+1][hp.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y].objects.begin(), subArr[hp.x+1][hp.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x+1][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x+1][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-2][hp.y+1].objects.begin(), subArr[hp.x-2][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-1][hp.y+1].objects.begin(), subArr[hp.x-1][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x][hp.y+1].objects.begin(), subArr[hp.x][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x+1][hp.y+1].objects.begin(), subArr[hp.x+1][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x == details.start.x && details.end.y-1 == details.start.y) //b
 |  |  	else if (details.end.x == details.start.x && details.end.y-1 == details.start.y) //b
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
										
											
												
													
														|  | @@ -1872,59 +1875,59 @@ void CPlayerInterface::initMovement( const TryMoveHero &details, const CGHeroIns
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 32, 31), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 32, 31), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 64, 31), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 64, 31), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 0, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 32, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 64, 63)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-2][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 0, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-1][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 32, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 64, 63)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-2][hp.y+1].objects.begin(), subArr[hp.x-2][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-1][hp.y+1].objects.begin(), subArr[hp.x-1][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x][hp.y+1].objects.begin(), subArr[hp.x][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x+1 == details.start.x && details.end.y-1 == details.start.y) //bl
 |  |  	else if (details.end.x+1 == details.start.x && details.end.y-1 == details.start.y) //bl
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		//ho->moveDir = 7;
 |  |  		//ho->moveDir = 7;
 | 
											
												
													
														|  |  		ho->isStanding = false;
 |  |  		ho->isStanding = false;
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, -1)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y-1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, -1)));
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 1, -1), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 1, -1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 33, -1), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 33, -1), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 65, -1), ho->id);
 |  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 65, -1), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 31)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 31)));
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, 1, 31), ho->id);
 |  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, 1, 31), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 33, 31), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 33, 31), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 65, 31), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 65, 31), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 1, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 33, 63)));
 |  | 
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 65, 63)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-2][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 1, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-1][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 33, 63)));
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x][hp.y+1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, 65, 63)));
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y-1].objects.begin(), subArr[hp.x-3][hp.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y].objects.begin(), subArr[hp.x-3][hp.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-2][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-1][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x][hp.y+1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y+1].objects.begin(), subArr[hp.x-3][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-2][hp.y+1].objects.begin(), subArr[hp.x-2][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-1][hp.y+1].objects.begin(), subArr[hp.x-1][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x][hp.y+1].objects.begin(), subArr[hp.x][hp.y+1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	else if (details.end.x+1 == details.start.x && details.end.y == details.start.y) //l
 |  |  	else if (details.end.x+1 == details.start.x && details.end.y == details.start.y) //l
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		//ho->moveDir = 8;
 |  |  		//ho->moveDir = 8;
 | 
											
												
													
														|  |  		ho->isStanding = false;
 |  |  		ho->isStanding = false;
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 0)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y-1].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 0)));
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 1, 0), ho->id);
 |  |  		subRect(hp.x-2, hp.y-1, hp.z, genRect(32, 32, 1, 0), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 33, 0), ho->id);
 |  |  		subRect(hp.x-1, hp.y-1, hp.z, genRect(32, 32, 33, 0), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 65, 0), ho->id);
 |  |  		subRect(hp.x, hp.y-1, hp.z, genRect(32, 32, 65, 0), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 32)));
 |  | 
 | 
											
												
													
														|  | 
 |  | +		subArr[hp.x-3][hp.y].objects.push_back(TerrainTileObject(ho, genRect(32, 32, -31, 32)));
 | 
											
												
													
														|  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, 1, 32), ho->id);
 |  |  		subRect(hp.x-2, hp.y, hp.z, genRect(32, 32, 1, 32), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 33, 32), ho->id);
 |  |  		subRect(hp.x-1, hp.y, hp.z, genRect(32, 32, 33, 32), ho->id);
 | 
											
												
													
														|  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 65, 32), ho->id);
 |  |  		subRect(hp.x, hp.y, hp.z, genRect(32, 32, 65, 32), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y-1][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y-1].objects.begin(), subArr[hp.x-3][hp.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -		std::stable_sort(CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.begin(), CGI->mh->ttiles[hp.x-3][hp.y][hp.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +		std::stable_sort(subArr[hp.x-3][hp.y].objects.begin(), subArr[hp.x-3][hp.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -2154,13 +2157,16 @@ void CPlayerInterface::finishMovement( const TryMoveHero &details, const int3 &h
 | 
											
												
													
														|  |  	subRect(details.end.x, details.end.y, details.end.z, genRect(32, 32, 64, 32), ho->id);
 |  |  	subRect(details.end.x, details.end.y, details.end.z, genRect(32, 32, 64, 32), ho->id);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	//restoring good order of objects
 |  |  	//restoring good order of objects
 | 
											
												
													
														|  | -	std::stable_sort(CGI->mh->ttiles[details.end.x-2][details.end.y-1][details.end.z].objects.begin(), CGI->mh->ttiles[details.end.x-2][details.end.y-1][details.end.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -	std::stable_sort(CGI->mh->ttiles[details.end.x-1][details.end.y-1][details.end.z].objects.begin(), CGI->mh->ttiles[details.end.x-1][details.end.y-1][details.end.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -	std::stable_sort(CGI->mh->ttiles[details.end.x][details.end.y-1][details.end.z].objects.begin(), CGI->mh->ttiles[details.end.x][details.end.y-1][details.end.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	std::stable_sort(CGI->mh->ttiles[details.end.x-2][details.end.y][details.end.z].objects.begin(), CGI->mh->ttiles[details.end.x-2][details.end.y][details.end.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -	std::stable_sort(CGI->mh->ttiles[details.end.x-1][details.end.y][details.end.z].objects.begin(), CGI->mh->ttiles[details.end.x-1][details.end.y][details.end.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | -	std::stable_sort(CGI->mh->ttiles[details.end.x][details.end.y][details.end.z].objects.begin(), CGI->mh->ttiles[details.end.x][details.end.y][details.end.z].objects.end(), objectBlitOrderSorter);
 |  | 
 | 
											
												
													
														|  | 
 |  | +	boost::detail::multi_array::sub_array<TerrainTile2, 2> subArr = (CGI->mh->ttiles)[details.end.z];
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	std::stable_sort(subArr[details.end.x-2][details.end.y-1].objects.begin(), subArr[details.end.x-2][details.end.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +	std::stable_sort(subArr[details.end.x-1][details.end.y-1].objects.begin(), subArr[details.end.x-1][details.end.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +	std::stable_sort(subArr[details.end.x][details.end.y-1].objects.begin(), subArr[details.end.x][details.end.y-1].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	std::stable_sort(subArr[details.end.x-2][details.end.y].objects.begin(), subArr[details.end.x-2][details.end.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +	std::stable_sort(subArr[details.end.x-1][details.end.y].objects.begin(), subArr[details.end.x-1][details.end.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  | 
 |  | +	std::stable_sort(subArr[details.end.x][details.end.y].objects.begin(), subArr[details.end.x][details.end.y].objects.end(), objectBlitOrderSorter);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void CPlayerInterface::gameOver(PlayerColor player, const EVictoryLossCheckResult & victoryLossCheckResult )
 |  |  void CPlayerInterface::gameOver(PlayerColor player, const EVictoryLossCheckResult & victoryLossCheckResult )
 | 
											
										
											
												
													
														|  | @@ -2882,7 +2888,7 @@ void CPlayerInterface::updateAmbientSounds(bool resetAll)
 | 
											
												
													
														|  |  	{
 |  |  	{
 | 
											
												
													
														|  |  		int dist = pos.dist(tile, int3::DIST_CHEBYSHEV);
 |  |  		int dist = pos.dist(tile, int3::DIST_CHEBYSHEV);
 | 
											
												
													
														|  |  		// We want sound for every special terrain on tile and not just one on top
 |  |  		// We want sound for every special terrain on tile and not just one on top
 | 
											
												
													
														|  | -		for(auto & ttObj : CGI->mh->ttiles[tile.x][tile.y][tile.z].objects)
 |  | 
 | 
											
												
													
														|  | 
 |  | +		for(auto & ttObj : CGI->mh->ttiles[tile.z][tile.x][tile.y].objects)
 | 
											
												
													
														|  |  		{
 |  |  		{
 | 
											
												
													
														|  |  			if(ttObj.ambientSound)
 |  |  			if(ttObj.ambientSound)
 | 
											
												
													
														|  |  				updateSounds(ttObj.ambientSound.get(), dist);
 |  |  				updateSounds(ttObj.ambientSound.get(), dist);
 |