File indexing completed on 2024-09-15 06:38:51
0001 /* This file is part of KsirK. 0002 Copyright (C) 2001-2007 Gael de Chalendar <kleag@free.fr> 0003 0004 KsirK is free software; you can redistribute it and/or 0005 modify it under the terms of the GNU General Public 0006 License as published by the Free Software Foundation, either version 2 0007 of the License, or (at your option) any later version. 0008 0009 This program is distributed in the hope that it will be useful, 0010 but WITHOUT ANY WARRANTY; without even the implied warranty of 0011 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 0012 General Public License for more details. 0013 0014 You should have received a copy of the GNU General Public License 0015 along with this program; if not, write to the Free Software 0016 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 0017 02110-1301, USA 0018 */ 0019 0020 #ifndef KGAMEWIN_H 0021 #define KGAMEWIN_H 0022 0023 #include "config-ksirk.h" 0024 #include "krightdialog.h" 0025 #include "KsirkGlobalDefinitions.h" 0026 #include "decoratedgameframe.h" 0027 #include "fightArena.h" 0028 #include "mainMenu.h" 0029 #include "GameLogic/onu.h" 0030 #include "GameLogic/gameautomaton.h" 0031 #include "GameLogic/player.h" 0032 #include "GameLogic/country.h" 0033 #include "Dialogs/InvasionSlider.h" 0034 #include "Sprites/animspriteslist.h" 0035 #if HAVE_JABBER_SUPPORT 0036 #include "Jabber/jabberclient.h" 0037 #include "qca.h" 0038 #endif 0039 0040 0041 // include files for Qt 0042 #include <QPointF> 0043 #include <QPixmap> 0044 #include <QLabel> 0045 #include <QPushButton> 0046 #include <QStackedWidget> 0047 #include <QGroupBox> 0048 #include <QSplitter> 0049 #include <QSlider> 0050 #include <QHBoxLayout> 0051 #include <QVBoxLayout> 0052 // include files for KDE 0053 #include <KSharedConfig> 0054 #include <KXmlGuiWindow> 0055 #include <QStandardPaths> 0056 0057 // #include <kdialogbase.h> 0058 0059 class KsirkJabberGameWidget; 0060 class mainMenu; 0061 class NewGameSetup; 0062 0063 class QAction; 0064 class KGameChat; 0065 class KGamePopupItem; 0066 class QDialog; 0067 class QAction; 0068 0069 class QEvent; 0070 class QDockWidget; 0071 class QGraphicsScene; 0072 0073 class QMediaPlayer; 0074 0075 namespace Ksirk 0076 { 0077 0078 // forward declaration of the KsirK classes 0079 class DecoratedGameFrame; 0080 class FightArena; 0081 class AnimSpritesGroup; 0082 class KRightDialog; 0083 class NewGameWidget; 0084 class KPlayerSetupWidget; 0085 class NewGameSummaryWidget; 0086 class TcpConnectWidget; 0087 0088 namespace Sprites 0089 { 0090 class ArrowSprite; 0091 } 0092 0093 namespace GameLogic 0094 { 0095 class ONU; 0096 class KMessageParts; 0097 class Player; 0098 } 0099 0100 /** 0101 * This is the main window. Due to the history of KsirK, this GUI class 0102 * contain really too much code about game logics. This will change in the 0103 * future. 0104 * 0105 * @author Gael de Chalendar (aka Kleag) 0106 * @version $Id: kgamewin.h 243 2007-02-24 00:22:58Z kleag $ 0107 */ 0108 class KGameWindow: public KXmlGuiWindow 0109 { 0110 Q_OBJECT 0111 0112 public: 0113 enum MessageShowingType {OnConfig, ForceShowing}; 0114 enum FightType {Attack, Defense}; 0115 enum TabbedWidgetsIndexesType 0116 { 0117 MAINMENU_INDEX /*0*/, 0118 NEWGAME_INDEX /*1*/, 0119 #if HAVE_JABBER_SUPPORT 0120 JABBERGAME_INDEX /*2*/, 0121 #endif 0122 NEWPLAYER_INDEX /*3*/, 0123 NEWGAMESUMMARY_INDEX /*4*/, 0124 TCPCONNECT_INDEX /*5*/, 0125 MAP_INDEX /*6*/, 0126 ARENA_INDEX /*7*/ 0127 }; 0128 /** 0129 * Create the window and initializes its members 0130 */ 0131 explicit KGameWindow(QWidget* parent=nullptr); 0132 0133 /** 0134 * Deletes the background and the pool 0135 */ 0136 ~KGameWindow() override; 0137 0138 /** Returns the game graphics view */ 0139 DecoratedGameFrame* frame() {return m_frame;} 0140 /** Returns the game graphics scene*/ 0141 // QGraphicsScene* graphicsscene() {return m_ 0142 0143 /** Returns the arena graphics view */ 0144 FightArena* arena() {return m_arena;} 0145 0146 /** Returns the menu graphics view */ 0147 mainMenu* mMenu() {return m_mainMenu;} 0148 0149 NewGameSetup* newGameSetup() {return m_newGameSetup;} 0150 0151 /** 0152 * Ask all the sprites to repaint themselves 0153 */ 0154 // void paint(); 0155 0156 /** 0157 * Returns the country inside which the argument point is. 0 if none. 0158 */ 0159 GameLogic::Country* clickIn(const QPointF& Point); 0160 0161 /** 0162 * Loads a new skin. 0163 */ 0164 void newSkin(const QString& onuDefinitionFileName = ""); 0165 0166 void setStateBeforeNewGame(GameLogic::GameAutomaton::GameState state) {m_stateBeforeNewGame = state;} 0167 0168 /************** METHODS BELOW ARE DEFINED IN gestionSprites.cpp **************/ 0169 /** 0170 * Prepares the sprites to be moved : removes the nb necessary sprites from 0171 * source, creates the moving sprites and gives them their destination, etc 0172 */ 0173 bool initArmiesMovement(unsigned int nb, GameLogic::Country* src, GameLogic::Country* dest); 0174 0175 AnimSprite* initArmiesMultipleCombat(unsigned int nb, 0176 GameLogic::Country* src, 0177 GameLogic::Country* dest, QPointF); 0178 0179 QPointF determinePointDepartArena(GameLogic::Country *pays, int relativePos); 0180 0181 void determinePointArrivee( 0182 QPointF& pointArriveeAttaquant, 0183 QPointF& pointArriveeDefenseur); 0184 0185 void determinePointArriveeForArena( 0186 int relative, 0187 QPointF& pointArriveeAttaquant, 0188 QPointF& pointArriveeDefenseur); 0189 0190 0191 /** 0192 * Initializes the sprites that will fight for the attacker and the 0193 * defender. Prepares them for moving 0194 */ 0195 void initCombatMovement(); 0196 0197 /** 0198 * Prepare the fighting animation : replace the sprites sequence by the 0199 * sequence of explosion 0200 */ 0201 0202 void animCombat(); 0203 /** 0204 * Center the map on the fight so that the user can see what's happening 0205 */ 0206 void centerOnFight(); 0207 0208 /** 0209 * Replaces the animated fighters by the simple cannon image 0210 */ 0211 void stopCombat(); 0212 0213 /** 0214 * Replaces the sequence of destroyed cannon(s) by the explosion sequence. 0215 */ 0216 void animExplosion(int who); 0217 0218 void animExplosionForArena(); 0219 0220 /** 0221 * When all the explosion sequence has been shown for all explosing 0222 * devices, removes these sprites 0223 */ 0224 void stopExplosion(); 0225 0226 /** 0227 * Set up the eventual survivor(s) to come back home 0228 */ 0229 void initCombatBringBackForArena(GameLogic::Country *, GameLogic::Country *); 0230 0231 /** 0232 * Tests if there is currently moving armies (infantrymen, cavalrymen, 0233 * cannons or fighters) 0234 * @return true if there is moving armies; false otherwise 0235 */ 0236 bool haveMovingArmies() const {return !m_animSpritesGroups.empty();} 0237 0238 /************** END OF METHODS DEFINED IN gestionSprites.cpp *****************/ 0239 0240 bool setupOnePlayer(); 0241 bool setupOneWaitedPlayer(); 0242 bool createWaitedPlayer(quint32 waitedPlayerId); 0243 0244 /** 0245 * Do the distribution of armies for all players in function of their 0246 * number of countries 0247 */ 0248 void distributeArmies(); 0249 0250 /** 0251 * Computes the number of armies to be distributed to p at the beginning of 0252 * the turn, function of the number of countries he owns 0253 * @todo : this method should be a method of Player 0254 */ 0255 int nbNewArmies(GameLogic::Player *p); 0256 0257 /** 0258 * Changes the owner of the attacked country if its number of armies 0259 * becomes negative or null. Handle the end of the game of the 0260 * winning conditions are fulfilled. 0261 */ 0262 bool attackEnd(); 0263 0264 /** 0265 * Computes the results of the fight 0266 */ 0267 void resolveAttack(); 0268 0269 //@{ 0270 /** 0271 * Display and removes various toolbar buttons in function of the state 0272 * of the game. 0273 */ 0274 void displayRecyclingButtons(); 0275 void clearHighlighting(); 0276 void startLocalCurrentAI(); 0277 void displayDefenseWindow(); 0278 0279 //@} 0280 0281 /** 0282 * Updates the flag in the statusbar with the one of the current player 0283 */ 0284 void setBarFlagButton(const GameLogic::Player* player = nullptr); 0285 0286 /** 0287 * @brief Shortcut for "statusBar()-> changeItem(text, id)" 0288 */ 0289 void changeItem ( const QString& text, int id = ID_NO_STATUS_MSG, bool log = true); 0290 0291 /** 0292 * @brief Receives pixmaps and strings to internationalize and display in a 0293 * collection with stream API. 0294 * 0295 * When encountering a serie of strings, the first one is the pattern and 0296 * those following are the fillers. The end of the collection or a pixmap 0297 * signals that all fillers have been given. 0298 * @note No check is made (e.g. on the number of fillers) 0299 * 0300 * @param strings @b IN/OUT <I>KsirK::GameLogic::KMessageParts&</I> 0301 * the collection holding strings to display. 0302 * @param id @b IN <I>int</I> 0303 * The id of the status bar where to display the internationalized message. 0304 */ 0305 void changeItem(Ksirk::GameLogic::KMessageParts& strings, 0306 int id = ID_NO_STATUS_MSG, bool log = true); 0307 0308 /** 0309 * @brief Receives strings to internationalize and display in a collection 0310 * with stream API and broadcasts the message to all clients. 0311 * @param strings @b IN/OUT <I>KsirK::GameLogic::KMessageParts&</I> 0312 * the collection holding strings to display. 0313 * @param id @b IN <I>int</I> 0314 * The id of the status bar where to display the internationalized message. 0315 */ 0316 void broadcastChangeItem(Ksirk::GameLogic::KMessageParts& strings, 0317 int id = ID_NO_STATUS_MSG, bool log = true ); 0318 0319 /** 0320 * @brief Reconnect the mouse events signals to their slots to allow human players 0321 * to play 0322 */ 0323 void reconnectMouse(); 0324 0325 /** 0326 * Disconnects the mouse events signals from their slots to avoid human 0327 * player actions when it is the turn of the AI 0328 */ 0329 void disconnectMouse(); 0330 0331 /** Returns the current state of the game */ 0332 GameLogic::GameAutomaton::GameState getState() const; 0333 0334 /** Return true if the state of the game is the argument; false otherwise */ 0335 bool isMyState(GameLogic::GameAutomaton::GameState state) const; 0336 0337 /** @brief sets the current player to be the one pointed by the argument. 0338 * Makes associated actions: 0339 * 0340 * Changes the flag in the status bar. 0341 * @return Returns true in case of success; false otherwise. 0342 */ 0343 // bool setCurrentPlayer(const GameLogic::Player* player); 0344 0345 /** sets the current player to be the first one. Makes associated actions. */ 0346 int setCurrentPlayerToFirst(); 0347 0348 /** 0349 * Sets the current player to be the next one in the list. Makes the 0350 * associated actions : 0351 * Changes the flag in the status bar,... 0352 * @return 0 in case of success; non-zero otherwise. For example, it returns 0353 * 1 the current player was the last one 0354 */ 0355 int setCurrentPlayerToNext(bool restartRunningAIs = true); 0356 0357 0358 bool playerPutsArmy(const QPointF& point, bool removable); 0359 bool playerPutsInitialArmy(const QPointF& point); 0360 bool playerRemovesArmy(const QPointF& point); 0361 0362 /** Sets the attacker country to be the one at the given point */ 0363 bool attacker(const QPointF& point); 0364 0365 /** Sets the attacked country to be the one at the given point */ 0366 unsigned int attacked(const QPointF& point); 0367 0368 /** Sets the first country in a fight to be the one at the given point. */ 0369 bool firstCountryAt(const QPointF& point); 0370 0371 /** Sets the second country in a fight to be the one at the given point. */ 0372 bool secondCountryAt(const QPointF& point); 0373 0374 /** 0375 * @brief setups window for recycling 0376 */ 0377 void initRecycling(); 0378 0379 /** Test if there is some sprites animated for a fight */ 0380 bool haveAnimFighters() const; 0381 0382 /** Clears all animated sprites lists and shows the post-fight buttons */ 0383 bool terminateAttackSequence(); 0384 0385 /** Called whenever a player choses to end the recycling. */ 0386 bool nextPlayerRecycling(); 0387 0388 /** 0389 * @return if true next state will be NEWARMIES else it will be WAIT 0390 */ 0391 bool nextPlayerNormal(); 0392 0393 /** Called whenever a player choses to attack with nb armies. */ 0394 void attack(unsigned int nb); 0395 0396 /** Called whenever a player choses to defend with nb armies. */ 0397 void defense(unsigned int nb); 0398 0399 /** Called whenever a player choses the cancel button. */ 0400 void cancelAction(); 0401 0402 /** 0403 * Called whenever a player choses to cancel the started end of turn move of 0404 * armies. 0405 */ 0406 void cancelShiftSource(); 0407 0408 /** Called when the user clicks the new game button. */ 0409 bool actionNewGame(GameLogic::GameAutomaton::NetworkGameType socket); 0410 0411 /** Called when the user clicks the open game button. */ 0412 bool actionOpenGame(); 0413 0414 /** Called when the user clicks the recycling button. */ 0415 void actionRecycling(); 0416 0417 /** */ 0418 void postActionRecycling(); 0419 0420 /** Called when the user clicks the recycling finished button. */ 0421 void actionRecyclingFinished(); 0422 0423 /** 0424 * Tests if the move finishing at the given point is valid. 0425 * @return true if the move is valid; false otherwise. 0426 */ 0427 bool isMoveValid(const QPointF& point); 0428 0429 /** 0430 * Tests if the fight finishing at the given point is valid. 0431 * @return true if the fight is valid; false otherwise. 0432 */ 0433 bool isFightValid(const QPointF& point); 0434 0435 /** 0436 * @brief Accessor to the world 0437 * @return A pointer to the world 0438 */ 0439 GameLogic::ONU* theWorld(); 0440 0441 /** 0442 * @brief Adds a player 0443 */ 0444 GameLogic::Player* addPlayer(const QString& playerName, 0445 unsigned int nbAvailArmies, 0446 unsigned int nbCountries, 0447 const QString& nationName, 0448 bool isAI, 0449 const QString& password = "", 0450 unsigned int nbAttack = 0, 0451 unsigned int nbDefense = 0); 0452 0453 //@{ 0454 /** 0455 * accessors and manipulators of the number of armies moved during an invasion 0456 * or an end of turn move 0457 */ 0458 int nbMovedArmies(); 0459 void incrNbMovedArmies(unsigned int nb = 1); 0460 void decrNbMovedArmies(unsigned int nb = 1); 0461 //@} 0462 0463 //@{ 0464 /** 0465 * causes the move to/from the first country stored from/to the second one 0466 * during an invasion or an end of turn move 0467 */ 0468 bool invade(unsigned int nb = 1); 0469 AnimSprite* simultaneousAttack(int nbArmies, FightType type); 0470 bool retreat(unsigned int nb = 1); 0471 //@} 0472 0473 //@{ 0474 /** 0475 * causes the end of an invasion or an end of turn move 0476 */ 0477 void invasionFinished(); 0478 void shiftFinished(); 0479 //@} 0480 0481 /** @return true if the given player is the last one ; false otherwise */ 0482 bool isLastPlayer(const GameLogic::Player& player); 0483 0484 inline GameLogic::GameAutomaton* automaton() {return m_automaton;} 0485 0486 /** 0487 * Gets the background world map sprite. Gives access to the scene and, furthermore, 0488 * the background size, thus giving hints for positioning and annimation. 0489 */ 0490 inline BackGnd* backGndWorld() {return m_backGnd_world;} 0491 inline const BackGnd* backGndWorld() const {return m_backGnd_world;} 0492 0493 /** 0494 * Gets the background arena sprite. Gives access to the scene and, furthermore, 0495 * the background size, thus giving hints for positioning and annimation. 0496 */ 0497 inline BackGnd* backGndArena() {return m_backGnd_arena;} 0498 inline const BackGnd* backGndArena() const {return m_backGnd_arena;} 0499 0500 /** 0501 * Gets the current background sprite. Gives access to the scene and, furthermore, 0502 * the background size, thus giving hints for positioning and annimation. 0503 */ 0504 BackGnd* backGnd(); 0505 0506 //@{ 0507 /** 0508 * Accessors to the number of available armies. This one is inherited from a 0509 * long time ago and should probably be replaced by available armies local 0510 * to players. 0511 */ 0512 /* inline void availArmies(unsigned int nb) {m_nbAvailArmies = nb;} 0513 inline unsigned int availArmies() {return m_nbAvailArmies;}*/ 0514 //@} 0515 0516 //@{ 0517 /** 0518 * Accessors to the firstly and secondly clicked countries that will become 0519 * the attacker and the defender countries (or the source and the target) if 0520 * the move is valid 0521 */ 0522 void firstCountry(GameLogic::Country* country); 0523 void secondCountry(GameLogic::Country* country); 0524 GameLogic::Country* firstCountry(); 0525 GameLogic::Country* secondCountry(); 0526 //@} 0527 0528 /** 0529 * Forces all moving sprites to finish their move be clearing moving 0530 * sprites collections. 0531 */ 0532 void finishMoves(); 0533 0534 /** 0535 * Returns the list of players definitions whose connection from the network 0536 * is waited after loading a saved game. 0537 */ 0538 inline QList<GameLogic::PlayerMatrix>& waitedPlayers() {return m_waitedPlayers;} 0539 0540 /** Displays the buttons associated to the given game state. */ 0541 void displayButtonsForState(GameLogic::GameAutomaton::GameState state); 0542 0543 /** 0544 * The game is over. The given player is the winner. Displays the dialog 0545 * stating this fact, depending on if this player is local or distant. 0546 */ 0547 void winner(const GameLogic::Player* player); 0548 0549 /** Returns a list of the nations names associated to their flag's file name. */ 0550 QMap< QString, QString > nationsList(); 0551 0552 /** Returns a pointer to the chat widget used to chat and to display messages. */ 0553 inline KGameChat* chatWidget() {return m_chatDlg;} 0554 0555 /** Returns a pointer to the title chat message label used to display messages. */ 0556 inline QLabel* titleChatMessage() {return m_titleChatMsg;} 0557 0558 void showMessage(const QString& message, quint32 delay=5, MessageShowingType forcing=OnConfig); 0559 0560 /** 0561 * Replace the map widget by the arena widget. 0562 */ 0563 void showArena(); 0564 0565 /** 0566 * Replace the arena widget by the map widget. 0567 */ 0568 void showMap(); 0569 0570 /** 0571 * Replace the mainMenu widget by the map widget. 0572 */ 0573 void showMainMenu(); 0574 0575 /** 0576 * The three types of possible central widget. This enum is used to know which 0577 * one is currently displayed (see m_currentDisplayedWidget member below). 0578 */ 0579 enum WidgetType {MainMenu, Map, Arena}; 0580 0581 /** 0582 * Give type of the central widget currently displayed. 0583 * @return current widget type 0584 */ 0585 WidgetType currentWidgetType(); 0586 0587 /** 0588 * Give the central widget currently displayed. 0589 * @return current widget 0590 */ 0591 QGraphicsView* currentWidget(); 0592 /** 0593 * Return the right dialog 0594 */ 0595 KRightDialog * getRightDialog(); 0596 0597 /** Arena state */ 0598 bool isArena(); 0599 0600 enum DiceColor {Blue,Red}; 0601 0602 QPixmap getDice(DiceColor color, int num); 0603 0604 /** 0605 * Returns the current player 0606 */ 0607 GameLogic::Player* currentPlayer(); 0608 0609 void slideInvade(GameLogic::Country *,GameLogic::Country *, Ksirk::InvasionSlider::InvasionType invasionType = Ksirk::InvasionSlider::Invasion); 0610 0611 void setNextPlayerActionEnabled(bool value); 0612 void setSaveGameActionEnabled(bool value); 0613 void setContextualHelpActionEnabled(GameLogic::GameAutomaton::GameState gameState, bool isPlayerAI); 0614 0615 void updateScrollArrows(); 0616 0617 bool newGameDialog(const QString& skin, GameLogic::GameAutomaton::NetworkGameType netGameType); 0618 0619 bool finishSetupPlayers(); 0620 0621 #if HAVE_JABBER_SUPPORT 0622 inline JabberClient* jabberClient() {return m_jabberClient;} 0623 void askForJabberGames(); 0624 void sendGameInfoToJabber(); 0625 0626 inline XMPP::Jid& serverJid() {return m_serverJid;} 0627 inline void setServerJid(const XMPP::Jid& jid) {m_serverJid = jid;} 0628 0629 /** 0630 * Sets our own presence. Updates our resource in the 0631 * resource pool and sends a presence packet to the server. 0632 */ 0633 void setPresence ( const XMPP::Status &status ); 0634 0635 inline void setGroupchatHost(const QString& str) {m_groupchatHost = str;} 0636 inline void setGroupchatRoom(const QString& str) {m_groupchatRoom = str;} 0637 inline void setGroupchatNick(const QString& str) {m_groupchatNick = str;} 0638 inline void setGroupchatPassword(const QString& str) {m_groupchatPassword = str;} 0639 0640 const QString& groupchatHost() const {return m_groupchatHost;} 0641 const QString& groupchatRoom() const {return m_groupchatRoom;} 0642 const QString& groupchatNick() const {return m_groupchatNick;} 0643 const QString& groupchatPassword() const {return m_groupchatPassword;} 0644 #endif 0645 0646 void joinNetworkGame(); 0647 0648 void updateNewGameSummary(); 0649 void showNewGameSummary(); 0650 0651 protected: 0652 0653 /** 0654 * Connected to the frame timer, it manages the behavior of the game in 0655 * function of the value of the state. 0656 * 0657 * Fundamental method !!! 0658 */ 0659 // void slotTimerEvent(); 0660 0661 // void resizeEvent ( QResizeEvent * event ); 0662 0663 /** 0664 * Add the main toolbar buttons 0665 */ 0666 void initActions(); 0667 0668 /** 0669 * Prepares the status bar 0670 */ 0671 void initStatusBar(); 0672 0673 /** 0674 * creates and display the main frame with the background 0675 */ 0676 void initView(); 0677 0678 /** 0679 * Reimplementation of the inherited function : starts the timer. 0680 */ 0681 void enterEvent(QEnterEvent* ev) override; 0682 0683 /** 0684 * Reimplementation of the inherited function : stops the timer. 0685 */ 0686 void leaveEvent(QEvent* ev) override; 0687 0688 void clear(); 0689 0690 /** 0691 * Reimplementation of the inherited function called when a window close event arise 0692 */ 0693 bool queryClose() override; 0694 0695 /** Shows some explanations on how to start playing */ 0696 void explain(); 0697 0698 void reduceChat(); 0699 void unreduceChat(); 0700 0701 #if HAVE_JABBER_SUPPORT 0702 Q_SIGNALS: 0703 void newJabberGame(const QString&, int, const QString&); 0704 #endif 0705 0706 public Q_SLOTS: 0707 0708 void mouseMoveEvent ( QMouseEvent * event ) override; 0709 0710 //@{ 0711 /** 0712 * The slots associated to the buttons 0713 */ 0714 #if HAVE_JABBER_SUPPORT 0715 void slotJabberGame(); 0716 void slotNewJabberGame(); 0717 #endif 0718 void slotNewGame(); 0719 void slotNewSocketGame(); 0720 void slotJoinNetworkGame(); 0721 void slotOpenGame(); 0722 void slotSaveGame(); 0723 void slotRecycling(); 0724 void slotRecyclingFinished(); 0725 void slotNextPlayer(); 0726 void slotAttack1(); 0727 void slotAttack2(); 0728 void slotAttack3(); 0729 void slotDefense1(); 0730 void slotDefense2(); 0731 void slotDefAuto(); 0732 void slotWindowDef1(); 0733 void slotWindowDef2(); 0734 void slotInvade1(); 0735 0736 void slotInvade5(); 0737 void slotInvade10(); 0738 void slotInvasionFinished(); 0739 void slotRetreat1(); 0740 void slotRetreat5(); 0741 void slotRetreat10(); 0742 void slotMove(); 0743 void slotCancel(); 0744 void slotDumpGameInformations(); 0745 void slotFinishMoves(); 0746 void slotArena(bool); 0747 void slotContextualHelp(); 0748 //@} 0749 0750 /** 0751 * The standard slotShowAboutApplication slot 0752 */ 0753 void slotShowAboutApplication(); 0754 0755 //@{ 0756 /** 0757 * Connected to the frame mouse buttons signals, they manages the reaction 0758 * of the game to user interaction inside its main widget in function of 0759 * the state of the game. 0760 * 0761 * Fundamental methods !!! 0762 */ 0763 void slotLeftButtonDown(const QPointF&); 0764 void slotLeftButtonUp(const QPointF&); 0765 void slotRightButtonDown(const QPointF&); 0766 void slotRightButtonUp(const QPointF&); 0767 //@} 0768 0769 /** 0770 * This slot displays a dialog explaining the goal of the current player and 0771 * describing her progress in this way. 0772 */ 0773 void slotShowGoal(); 0774 0775 /** 0776 * Connected to the chat signals. 0777 */ 0778 void slotChatMessage(); 0779 void slotChatReduceButton(); 0780 void slotChatFloatButtonPressed(); 0781 void slotChatFloatChanged(bool value = true); 0782 0783 void slotMovingFightersArrived(AnimSpritesGroup* sprites); 0784 void slotFiringFinished(AnimSpritesGroup*); 0785 void slotExplosionFinished(AnimSpritesGroup*); 0786 void slotMovingArmiesArrived(AnimSpritesGroup*); 0787 void slotBring(AnimSprite*); 0788 void slotMovingArmyArrived(AnimSprite*); 0789 0790 void slotZoomIn(); 0791 void slotZoomOut(); 0792 0793 void slotNewGameNext(); 0794 // void slotNewGameOK(unsigned int nbPlayers, const QString& skin, unsigned int nbNetworkPlayers, bool useGoals); 0795 void slotNewGameKO(); 0796 0797 #if HAVE_JABBER_SUPPORT 0798 void slotJabberGameCanceled(int previousIndex); 0799 #endif 0800 0801 void slotNewPlayerNext(); 0802 void slotNewPlayerPrevious(); 0803 void slotNewPlayerCancel(); 0804 0805 void slotStartNewGame(); 0806 void slotTcpConnectCancel(); 0807 void slotTcpConnectPrevious(); 0808 0809 private Q_SLOTS: 0810 void optionsConfigure(); 0811 0812 /** 0813 * Called every 50ms, it causes the scrolling of the world if necessary the 0814 * movement of the moving sprites. After it call the paint method to do the 0815 * animation of the sprites and it asks the pool to update 0816 */ 0817 void evenementTimer(); 0818 0819 void slotRemoveMessage(); 0820 0821 void slotDisableHelp(const QString &); 0822 0823 void slotArmiesNumberChanged(int); 0824 0825 /* Connects to the server. */ 0826 // void slotConnect (); 0827 0828 /* Disconnects from the server. */ 0829 // void slotDisconnect (); 0830 0831 #if HAVE_JABBER_SUPPORT 0832 // handle a TLS warning 0833 void slotHandleTLSWarning ( QCA::TLS::IdentityResult identityResult, QCA::Validity validityResult ); 0834 0835 // handle client errors 0836 void slotClientError ( JabberClient::ErrorCode errorCode ); 0837 0838 // we are connected to the server 0839 void slotConnected (); 0840 0841 /* Called from Psi: tells us when we've been disconnected from the server. */ 0842 void slotCSDisconnected (); 0843 0844 /* Called from Psi: alerts us to a protocol error. */ 0845 void slotCSError (int); 0846 0847 /* Called from Psi: roster request finished */ 0848 void slotRosterRequestFinished ( bool success ); 0849 0850 /* Called from Psi: incoming file transfer */ 0851 // void slotIncomingFileTransfer (); 0852 0853 /* Called from Psi: debug messages from the backend. */ 0854 void slotClientDebugMessage (const QString &msg); 0855 0856 /* XMPP console dialog */ 0857 // void slotXMPPConsole (); 0858 0859 /* Slots for handling groupchats. */ 0860 // void slotJoinNewChat (); 0861 void slotGroupChatJoined ( const XMPP::Jid &jid ); 0862 void slotGroupChatLeft ( const XMPP::Jid &jid ); 0863 void slotGroupChatPresence ( const XMPP::Jid &jid, const XMPP::Status &status ); 0864 void slotGroupChatError ( const XMPP::Jid &jid, int error, const QString &reason ); 0865 0866 /* Incoming subscription request. */ 0867 // void slotSubscription ( const XMPP::Jid &jid, const QString &type ); 0868 0869 /* the dialog that asked to add the contact was closed (that dialog is shown in slotSubscription) */ 0870 // void slotAddedInfoEventActionActivated ( uint actionId ); 0871 0872 /** 0873 * A new item appeared in our roster, synch it with the 0874 * contact list. 0875 * (or the contact has been updated 0876 */ 0877 // void slotContactUpdated ( const XMPP::RosterItem & ); 0878 0879 /** 0880 * An item has been deleted from our roster, 0881 * delete it from our contact pool. 0882 */ 0883 // void slotContactDeleted ( const XMPP::RosterItem & ); 0884 0885 0886 /* Someone on our contact list had (another) resource come online. */ 0887 // void slotResourceAvailable ( const XMPP::Jid &, const XMPP::Resource & ); 0888 0889 /* Someone on our contact list had (another) resource go offline. */ 0890 // void slotResourceUnavailable ( const XMPP::Jid &, const XMPP::Resource & ); 0891 0892 /* Displays a new message. */ 0893 void slotReceivedMessage ( const XMPP::Message & ); 0894 0895 /* Gets the user's vCard from the server for editing. */ 0896 // void slotEditVCard (); 0897 0898 /* Get the services list from the server for management. */ 0899 // void slotGetServices (); 0900 0901 /* we received a voice invitation */ 0902 // void slotIncomingVoiceCall(const Jid&); 0903 0904 /* the unregister task finished */ 0905 // void slotUnregisterFinished(); 0906 #endif 0907 void slotExit(); 0908 0909 void slotConnectToServer(); 0910 0911 private: // Private methods 0912 void createDefenseDialog(); 0913 void moveArmies(GameLogic::Country& src, GameLogic::Country& dest, unsigned int nb); 0914 void saveXml(QTextStream& xmlStream); 0915 void loadDices(); 0916 QPixmap buildDice(const QString& id); 0917 void setupPopupMessage(); 0918 QString defenseLabel(); 0919 0920 0921 private: // Private members 0922 QDockWidget * m_rightDock; 0923 0924 KRightDialog * m_rightDialog; 0925 0926 QStackedWidget *m_centralWidget; 0927 0928 GameLogic::GameAutomaton* m_automaton; 0929 0930 InvasionSlider * m_wSlide; 0931 0932 /** 0933 * State that say the widget that is currently displayed between the map and the arena. 0934 */ 0935 WidgetType m_currentDisplayedWidget; 0936 0937 /** 0938 * The widget initialy docked at bottom where is displayed the events history 0939 */ 0940 QDockWidget* m_bottomDock; 0941 0942 //@{ 0943 /** 0944 * NKD = Numberof Killed Defenders 0945 * NKA = Numberof Killed Attackers 0946 * These numbers are set up by resolveAttack() and are used to compute 0947 * in various methods 0948 * @todo: this solution is ugly. Change that. 0949 */ 0950 int NKD, NKA; 0951 //@} 0952 0953 bool m_useArena; 0954 0955 int nbSpriteAttacking; 0956 int nbSpriteDefending; 0957 0958 int relativePosInArenaAttack; 0959 int relativePosInArenaDefense; 0960 0961 /** 0962 * the countries, continents, etc. 0963 */ 0964 GameLogic::ONU* m_theWorld; 0965 0966 /** 0967 * The main canvas of the world map 0968 */ 0969 QGraphicsScene* m_scene_world; 0970 0971 /** 0972 * The main canvas of the arena 0973 */ 0974 QGraphicsScene* m_scene_arena; 0975 0976 /** 0977 * The background sprite of the world map. Gives access to the scene and, furthermore, 0978 * the background size, thus giving hints for positioning and annimation. 0979 */ 0980 BackGnd* m_backGnd_world; 0981 0982 /** 0983 * The background sprite of the arena. Gives access to the scene and, furthermore, 0984 * the background size, thus giving hints for positioning and animation. 0985 */ 0986 BackGnd* m_backGnd_arena; 0987 0988 /** 0989 * The fighting fighters (represented by firing cannons) 0990 */ 0991 AnimSpritesGroup* m_animFighters; 0992 0993 /** 0994 * The number of armies to move/moving/moved from one country to another 0995 */ 0996 int m_nbMovedArmies; 0997 0998 //@{ 0999 /** 1000 * The 2 countries involved in a fight or in a armies move 1001 */ 1002 GameLogic::Country* m_firstCountry; 1003 GameLogic::Country* m_secondCountry; 1004 //@} 1005 1006 /** 1007 * 1008 */ 1009 // QDialog *dialog; 1010 1011 /** 1012 * The map frame of the game, its visual component ; the main widget 1013 */ 1014 DecoratedGameFrame* m_frame; 1015 1016 /** 1017 * The arena frame of the game, its visual component ; the main widget 1018 */ 1019 FightArena* m_arena; 1020 1021 /** 1022 * The menu frame of the game, its visual component ; the main widget 1023 */ 1024 mainMenu* m_mainMenu; 1025 1026 /** 1027 * This button is used to display the flag of the currently active player 1028 * in the status bar. 1029 */ 1030 QAction * m_goalAction; 1031 #if HAVE_JABBER_SUPPORT 1032 QAction* m_jabberAction; 1033 #endif 1034 QLabel* m_barFlag; 1035 1036 // KAccel m_accels; 1037 1038 QList<QString> m_temporaryAccelerators; 1039 1040 /** Used during countries distribution to handle network lags on the player member */ 1041 // unsigned int m_nbAvailArmies; 1042 1043 /** 1044 * The list of players description whose connection is waited after loading 1045 * a saved game. 1046 */ 1047 QList<GameLogic::PlayerMatrix> m_waitedPlayers; 1048 1049 /** 1050 * The prompter where the game events and chat between network players are 1051 * displayed 1052 */ 1053 KGameChat *m_chatDlg; 1054 1055 /** 1056 * Show the beginning of the last message received. 1057 */ 1058 QLabel* m_titleChatMsg; 1059 1060 /** 1061 * Reduced state of the chat widget. 1062 */ 1063 bool m_chatIsReduced; 1064 1065 /** 1066 * Contains all dices of the game. 1067 */ 1068 QMap< DiceColor, QList<QPixmap> > m_dices; 1069 1070 /** 1071 * Audio player object: play all the sounds of the game. 1072 */ 1073 QMediaPlayer* m_audioPlayer; 1074 1075 /** 1076 * This timer is used to scroll the window if the mouse stay unmoving near 1077 * the window border. 1078 */ 1079 QTimer m_timer; 1080 1081 QList<AnimSpritesGroup*> m_animSpritesGroups; 1082 1083 KGamePopupItem * m_message; 1084 1085 GameLogic::Country* m_mouseLocalisation; 1086 1087 QDialog * m_defenseDialog; 1088 1089 // components that will be re-used of the chat 1090 QPixmap m_upChatFloatPix; 1091 QPixmap m_downChatFloatPix; 1092 1093 // last width of the floating chat not reduced 1094 int m_lastWidthChat; 1095 1096 QPushButton* m_reduceChatButton; 1097 QPushButton* m_floatChatButton; 1098 1099 // the current saved game file name 1100 QString m_fileName; 1101 1102 QAction* m_nextPlayerAction; 1103 QAction * m_saveGameAction; 1104 QAction * m_zoomInAction; 1105 QAction * m_zoomOutAction; 1106 QAction * m_contextualHelpAction; 1107 1108 Sprites::ArrowSprite* m_uparrow; 1109 Sprites::ArrowSprite* m_downarrow; 1110 Sprites::ArrowSprite* m_leftarrow; 1111 Sprites::ArrowSprite* m_rightarrow; 1112 1113 int m_port; 1114 bool m_reinitializingGame; 1115 1116 NewGameWidget* m_newGameDialog; 1117 KPlayerSetupWidget* m_newPlayerWidget; 1118 1119 GameLogic::GameAutomaton::GameState m_stateBeforeNewGame; 1120 int m_stackWidgetBeforeNewGame; 1121 1122 #if HAVE_JABBER_SUPPORT 1123 JabberClient* m_jabberClient; 1124 XMPP::Jid m_serverJid; 1125 1126 /* Initial presence to set after connecting. */ 1127 XMPP::Status m_initialPresence; 1128 1129 QString m_groupchatHost; 1130 QString m_groupchatRoom; 1131 QString m_groupchatNick; 1132 QString m_groupchatPassword; 1133 1134 QString m_advertizedHostName; 1135 1136 KsirkJabberGameWidget* m_jabberGameWidget; 1137 1138 QSet<QString> m_presents; 1139 #endif 1140 1141 NewGameSetup* m_newGameSetup; 1142 NewGameSummaryWidget* m_newGameSummaryWidget; 1143 TcpConnectWidget* m_tcpConnectWidget; 1144 1145 QLabel* m_labDef; 1146 }; 1147 1148 } // closing namespace Ksirk 1149 1150 #endif // KGAMEWINDOW_H 1151