Browse Source

Merge pull request #3013 from Nordsoft91/turn-timer

Nordsoft91 2 years ago
parent
commit
088ce9b948
2 changed files with 12 additions and 4 deletions
  1. 1 1
      client/CServerHandler.cpp
  2. 11 3
      client/adventureMap/TurnTimerWidget.cpp

+ 1 - 1
client/CServerHandler.cpp

@@ -300,7 +300,7 @@ void CServerHandler::applyPacksOnLobbyScreen()
 		CPackForLobby * pack = packsForLobbyScreen.front();
 		CPackForLobby * pack = packsForLobbyScreen.front();
 		packsForLobbyScreen.pop_front();
 		packsForLobbyScreen.pop_front();
 		CBaseForLobbyApply * apply = applier->getApplier(typeList.getTypeID(pack)); //find the applier
 		CBaseForLobbyApply * apply = applier->getApplier(typeList.getTypeID(pack)); //find the applier
-		apply->applyOnLobbyScreen(static_cast<CLobbyScreen *>(SEL), this, pack);
+		apply->applyOnLobbyScreen(dynamic_cast<CLobbyScreen *>(SEL), this, pack);
 		GH.windows().totalRedraw();
 		GH.windows().totalRedraw();
 		delete pack;
 		delete pack;
 	}
 	}

+ 11 - 3
client/adventureMap/TurnTimerWidget.cpp

@@ -150,10 +150,18 @@ void TurnTimerWidget::tick(uint32_t msPassed)
 	}
 	}
 	else
 	else
 	{
 	{
-		for(PlayerColor p(0); p < PlayerColor::PLAYER_LIMIT; ++p)
+		if(LOCPLINT->makingTurn)
+			updateTimer(LOCPLINT->playerID, msPassed);
+		else
 		{
 		{
-			if(LOCPLINT->cb->isPlayerMakingTurn(p))
-				updateTimer(p, msPassed);
+			for(PlayerColor p(0); p < PlayerColor::PLAYER_LIMIT; ++p)
+			{
+				if(LOCPLINT->cb->isPlayerMakingTurn(p))
+				{
+					updateTimer(p, msPassed);
+					break;
+				}
+			}
 		}
 		}
 	}
 	}
 }
 }