Sfoglia il codice sorgente

Attempt to fix freeze during map animations

Ivan Savenko 2 anni fa
parent
commit
70d44d435e
1 ha cambiato i file con 12 aggiunte e 4 eliminazioni
  1. 12 4
      client/mapView/MapViewController.cpp

+ 12 - 4
client/mapView/MapViewController.cpp

@@ -218,8 +218,9 @@ void MapViewController::afterRender()
 		if(!hero)
 		if(!hero)
 			hero = boat->hero;
 			hero = boat->hero;
 
 
-		if(movementContext->progress >= 1.0)
+		if(movementContext->progress >= 0.999)
 		{
 		{
+			logGlobal->debug("Ending movement animation");
 			setViewCenter(hero->getSightCenter());
 			setViewCenter(hero->getSightCenter());
 
 
 			removeObject(context->getObject(movementContext->target));
 			removeObject(context->getObject(movementContext->target));
@@ -229,20 +230,23 @@ void MapViewController::afterRender()
 		}
 		}
 	}
 	}
 
 
-	if(teleportContext && teleportContext->progress >= 1.0)
+	if(teleportContext && teleportContext->progress >= 0.999)
 	{
 	{
+		logGlobal->debug("Ending teleport animation");
 		activateAdventureContext(teleportContext->animationTime);
 		activateAdventureContext(teleportContext->animationTime);
 	}
 	}
 
 
-	if(fadingOutContext && fadingOutContext->progress <= 0.0)
+	if(fadingOutContext && fadingOutContext->progress <= 0.001)
 	{
 	{
+		logGlobal->debug("Ending fade out animation");
 		removeObject(context->getObject(fadingOutContext->target));
 		removeObject(context->getObject(fadingOutContext->target));
 
 
 		activateAdventureContext(fadingOutContext->animationTime);
 		activateAdventureContext(fadingOutContext->animationTime);
 	}
 	}
 
 
-	if(fadingInContext && fadingInContext->progress >= 1.0)
+	if(fadingInContext && fadingInContext->progress >= 0.999)
 	{
 	{
+		logGlobal->debug("Ending fade in animation");
 		activateAdventureContext(fadingInContext->animationTime);
 		activateAdventureContext(fadingInContext->animationTime);
 	}
 	}
 }
 }
@@ -300,6 +304,7 @@ bool MapViewController::isEventVisible(const CGHeroInstance * obj, const int3 &
 
 
 void MapViewController::fadeOutObject(const CGObjectInstance * obj)
 void MapViewController::fadeOutObject(const CGObjectInstance * obj)
 {
 {
+	logGlobal->debug("Starting fade out animation");
 	fadingOutContext = std::make_shared<MapRendererAdventureFadingContext>(*state);
 	fadingOutContext = std::make_shared<MapRendererAdventureFadingContext>(*state);
 	fadingOutContext->animationTime = adventureContext->animationTime;
 	fadingOutContext->animationTime = adventureContext->animationTime;
 	adventureContext = fadingOutContext;
 	adventureContext = fadingOutContext;
@@ -319,6 +324,7 @@ void MapViewController::fadeOutObject(const CGObjectInstance * obj)
 
 
 void MapViewController::fadeInObject(const CGObjectInstance * obj)
 void MapViewController::fadeInObject(const CGObjectInstance * obj)
 {
 {
+	logGlobal->debug("Starting fade in animation");
 	fadingInContext = std::make_shared<MapRendererAdventureFadingContext>(*state);
 	fadingInContext = std::make_shared<MapRendererAdventureFadingContext>(*state);
 	fadingInContext->animationTime = adventureContext->animationTime;
 	fadingInContext->animationTime = adventureContext->animationTime;
 	adventureContext = fadingInContext;
 	adventureContext = fadingInContext;
@@ -457,6 +463,7 @@ void MapViewController::onAfterHeroTeleported(const CGHeroInstance * obj, const
 
 
 	if(isEventVisible(obj, from, dest))
 	if(isEventVisible(obj, from, dest))
 	{
 	{
+		logGlobal->debug("Starting teleport animation");
 		teleportContext = std::make_shared<MapRendererAdventureTransitionContext>(*state);
 		teleportContext = std::make_shared<MapRendererAdventureTransitionContext>(*state);
 		teleportContext->animationTime = adventureContext->animationTime;
 		teleportContext->animationTime = adventureContext->animationTime;
 		adventureContext = teleportContext;
 		adventureContext = teleportContext;
@@ -491,6 +498,7 @@ void MapViewController::onHeroMoved(const CGHeroInstance * obj, const int3 & fro
 
 
 	if(movementTime > 1)
 	if(movementTime > 1)
 	{
 	{
+		logGlobal->debug("Starting movement animation");
 		movementContext = std::make_shared<MapRendererAdventureMovingContext>(*state);
 		movementContext = std::make_shared<MapRendererAdventureMovingContext>(*state);
 		movementContext->animationTime = adventureContext->animationTime;
 		movementContext->animationTime = adventureContext->animationTime;
 		adventureContext = movementContext;
 		adventureContext = movementContext;