Sfoglia il codice sorgente

Lock UI while adventure map has animations

Ivan Savenko 2 anni fa
parent
commit
fa9abf6adc
1 ha cambiato i file con 9 aggiunte e 7 eliminazioni
  1. 9 7
      client/CPlayerInterface.cpp

+ 9 - 7
client/CPlayerInterface.cpp

@@ -2029,13 +2029,15 @@ bool CPlayerInterface::capturedAllEvents()
 	if (duringMovement)
 	{
 		//just inform that we are capturing events. they will be processed by heroMoved() in client thread.
-		return true;
-	}
-
-	if (ignoreEvents)
-	{
-		boost::unique_lock<boost::mutex> un(eventsM);
-		while(!SDLEventsQueue.empty())
+		return true;
+	}
+
+	bool needToLockAdventureMap = adventureInt->active && CGI->mh->hasOngoingAnimations();
+
+	if (ignoreEvents || needToLockAdventureMap)
+	{
+		boost::unique_lock<boost::mutex> un(eventsM);
+		while(!SDLEventsQueue.empty())
 		{
 			SDLEventsQueue.pop();
 		}