NetPacksLobbyClient.cpp 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. /*
  2. * NetPacksLobbyClient.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "LobbyClientNetPackVisitors.h"
  12. #include "lobby/CSelectionBase.h"
  13. #include "lobby/CLobbyScreen.h"
  14. #include "lobby/OptionsTab.h"
  15. #include "lobby/RandomMapTab.h"
  16. #include "lobby/TurnOptionsTab.h"
  17. #include "lobby/ExtraOptionsTab.h"
  18. #include "lobby/SelectionTab.h"
  19. #include "lobby/CBonusSelection.h"
  20. #include "globalLobby/GlobalLobbyWindow.h"
  21. #include "globalLobby/GlobalLobbyServerSetup.h"
  22. #include "globalLobby/GlobalLobbyClient.h"
  23. #include "CServerHandler.h"
  24. #include "CGameInfo.h"
  25. #include "gui/CGuiHandler.h"
  26. #include "gui/WindowHandler.h"
  27. #include "widgets/Buttons.h"
  28. #include "widgets/TextControls.h"
  29. #include "../lib/CConfigHandler.h"
  30. #include "../lib/CGeneralTextHandler.h"
  31. #include "../lib/serializer/Connection.h"
  32. void ApplyOnLobbyHandlerNetPackVisitor::visitLobbyClientConnected(LobbyClientConnected & pack)
  33. {
  34. result = false;
  35. // Check if it's LobbyClientConnected for our client
  36. if(pack.uuid == handler.c->uuid)
  37. {
  38. handler.c->connectionID = pack.clientId;
  39. if(handler.mapToStart)
  40. {
  41. handler.setMapInfo(handler.mapToStart);
  42. }
  43. else if(!settings["session"]["headless"].Bool())
  44. {
  45. if (GH.windows().topWindow<CSimpleJoinScreen>())
  46. GH.windows().popWindows(1);
  47. if (!GH.windows().findWindows<GlobalLobbyServerSetup>().empty())
  48. {
  49. // announce opened game room
  50. // TODO: find better approach?
  51. int roomType = settings["lobby"]["roomType"].Integer();
  52. if (roomType != 0)
  53. handler.getGlobalLobby().sendOpenPrivateRoom();
  54. else
  55. handler.getGlobalLobby().sendOpenPublicRoom();
  56. }
  57. while (!GH.windows().findWindows<GlobalLobbyWindow>().empty())
  58. {
  59. // if global lobby is open, pop all dialogs on top of it as well as lobby itself
  60. GH.windows().popWindows(1);
  61. }
  62. GH.windows().createAndPushWindow<CLobbyScreen>(static_cast<ESelectionScreen>(handler.screenType));
  63. }
  64. handler.state = EClientState::LOBBY;
  65. }
  66. }
  67. void ApplyOnLobbyHandlerNetPackVisitor::visitLobbyClientDisconnected(LobbyClientDisconnected & pack)
  68. {
  69. if(pack.clientId != handler.c->connectionID)
  70. {
  71. result = false;
  72. return;
  73. }
  74. }
  75. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyClientDisconnected(LobbyClientDisconnected & pack)
  76. {
  77. if(auto w = GH.windows().topWindow<CLoadingScreen>())
  78. GH.windows().popWindow(w);
  79. if(GH.windows().count() > 0)
  80. GH.windows().popWindows(1);
  81. }
  82. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyChatMessage(LobbyChatMessage & pack)
  83. {
  84. if(lobby && lobby->card)
  85. {
  86. lobby->card->chat->addNewMessage(pack.playerName + ": " + pack.message);
  87. lobby->card->setChat(true);
  88. if(lobby->buttonChat)
  89. lobby->buttonChat->addTextOverlay(CGI->generaltexth->allTexts[531], FONT_SMALL, Colors::WHITE);
  90. }
  91. }
  92. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyGuiAction(LobbyGuiAction & pack)
  93. {
  94. if(!lobby || !handler.isGuest())
  95. return;
  96. switch(pack.action)
  97. {
  98. case LobbyGuiAction::NO_TAB:
  99. lobby->toggleTab(lobby->curTab);
  100. break;
  101. case LobbyGuiAction::OPEN_OPTIONS:
  102. lobby->toggleTab(lobby->tabOpt);
  103. break;
  104. case LobbyGuiAction::OPEN_SCENARIO_LIST:
  105. lobby->toggleTab(lobby->tabSel);
  106. break;
  107. case LobbyGuiAction::OPEN_RANDOM_MAP_OPTIONS:
  108. lobby->toggleTab(lobby->tabRand);
  109. break;
  110. case LobbyGuiAction::OPEN_TURN_OPTIONS:
  111. lobby->toggleTab(lobby->tabTurnOptions);
  112. break;
  113. case LobbyGuiAction::OPEN_EXTRA_OPTIONS:
  114. lobby->toggleTab(lobby->tabExtraOptions);
  115. break;
  116. }
  117. }
  118. void ApplyOnLobbyHandlerNetPackVisitor::visitLobbyEndGame(LobbyEndGame & pack)
  119. {
  120. if(handler.state == EClientState::GAMEPLAY)
  121. {
  122. handler.endGameplay(pack.closeConnection, pack.restart);
  123. }
  124. if(pack.restart)
  125. {
  126. if (handler.validateGameStart())
  127. handler.sendStartGame();
  128. }
  129. }
  130. void ApplyOnLobbyHandlerNetPackVisitor::visitLobbyStartGame(LobbyStartGame & pack)
  131. {
  132. if(pack.clientId != -1 && pack.clientId != handler.c->connectionID)
  133. {
  134. result = false;
  135. return;
  136. }
  137. handler.state = EClientState::STARTING;
  138. if(handler.si->mode != EStartMode::LOAD_GAME || pack.clientId == handler.c->connectionID)
  139. {
  140. auto modeBackup = handler.si->mode;
  141. handler.si = pack.initializedStartInfo;
  142. handler.si->mode = modeBackup;
  143. }
  144. handler.startGameplay(pack.initializedGameState);
  145. }
  146. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyStartGame(LobbyStartGame & pack)
  147. {
  148. if(auto w = GH.windows().topWindow<CLoadingScreen>())
  149. {
  150. w->finish();
  151. w->tick(0);
  152. w->redraw();
  153. }
  154. }
  155. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyLoadProgress(LobbyLoadProgress & pack)
  156. {
  157. if(auto w = GH.windows().topWindow<CLoadingScreen>())
  158. {
  159. w->set(pack.progress);
  160. w->tick(0);
  161. w->redraw();
  162. }
  163. }
  164. void ApplyOnLobbyHandlerNetPackVisitor::visitLobbyUpdateState(LobbyUpdateState & pack)
  165. {
  166. pack.hostChanged = pack.state.hostClientId != handler.hostClientId;
  167. static_cast<LobbyState &>(handler) = pack.state;
  168. if(handler.mapToStart && handler.mi)
  169. {
  170. handler.startMapAfterConnection(nullptr);
  171. handler.sendStartGame();
  172. }
  173. }
  174. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyUpdateState(LobbyUpdateState & pack)
  175. {
  176. if(!lobby) //stub: ignore message for game mode
  177. return;
  178. if(!lobby->bonusSel && handler.si->campState && handler.state == EClientState::LOBBY_CAMPAIGN)
  179. {
  180. lobby->bonusSel = std::make_shared<CBonusSelection>();
  181. GH.windows().pushWindow(lobby->bonusSel);
  182. }
  183. if(lobby->bonusSel)
  184. lobby->bonusSel->updateAfterStateChange();
  185. else
  186. lobby->updateAfterStateChange();
  187. if(pack.hostChanged)
  188. lobby->toggleMode(handler.isHost());
  189. }
  190. void ApplyOnLobbyScreenNetPackVisitor::visitLobbyShowMessage(LobbyShowMessage & pack)
  191. {
  192. if(!lobby) //stub: ignore message for game mode
  193. return;
  194. lobby->buttonStart->block(false);
  195. handler.showServerError(pack.message);
  196. }