MinigameClient.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. #pragma once
  2. #include "../Include/KSGNetwork.h"
  3. #include <Critical.h>
  4. namespace KSGClient
  5. {
  6. // Wird verwendet um Minigame Bestscores abzufragen und Minigame Spielaufzeichnungen zu laden
  7. // Kann nur von eingeloggten Clients verwendet werden
  8. class MinigameClient : public MinigameServerClient
  9. {
  10. private:
  11. int ref;
  12. Framework::Text ip;
  13. unsigned short port;
  14. int cId;
  15. Network::Klient *k;
  16. char *key;
  17. unsigned char keyLen;
  18. Framework::Critical cs;
  19. Framework::Text err;
  20. public:
  21. // Konstruktor
  22. MinigameClient( int klientId, unsigned short port, char *ip, char *key, unsigned char keyLen );
  23. // Destruktor
  24. ~MinigameClient();
  25. // verbindet sich mit dem zugewiesenen Minigame Server
  26. // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
  27. bool verbinde() override;
  28. // Gibt die Id des aktuell spielenden Accounts zurück
  29. int getAccountId() override;
  30. // Gibt den Anzeigenamen eines bestimmten Accounts zurück
  31. // id: Die id des Accounts
  32. Text *getAccountName( int id ) override;
  33. // Ermittelt die liste mit allen Optionen zu einem Minigame zurück, zu denen es Welt beste Scores gibt
  34. // mName: Der Name des Minigames
  35. // zOptionList: Enthält nach erfolgreichem Aufruf eine Liste mit Optionen
  36. // Gibt die Anzahl der Optionen zurück
  37. int getMinigameOptionList( char *mName, Framework::RCArray< Framework::Text > *zOptionList ) override;
  38. // Ermittelt eine Liste mit den Weltbesten Scores zurück
  39. // mName: Der Name des Minigames
  40. // zScore: Enthält nach erfolgreichem Aufruf eine Liste mit Scores
  41. // zPlayerList: Enthält nach erfolgreichem Aufruf eine Liste mit angezeigten Account Namen, die die Scores erreicht haben.
  42. // zOptionList: Enthält nach erfolgreichem Aufruf eine Liste mit Optionen, die beim erreichen der Scores aktiv waren.
  43. // Gibt die Anzahl der Bestscores zurück
  44. int getMinigameBestscoreList( char *mName, Framework::Array< int > *zScore, Framework::RCArray< Framework::Text > *zPlayerList, Framework::RCArray< Framework::Text > *zOptionList ) override;
  45. // Gibt den Welt bestscore zu einem Bestimmten Minigame mit bestimmten Optionen zurück.
  46. // mName: Der Name des Minigames
  47. // oName: Die Optionen
  48. // zPlayer: Enthält nach erfolgreichem Aufruf den Angezeigten Namen des Accounts, der den Score erreicht hat
  49. int getMinigameOptionBestscore( char *mName, char *oName, Framework::Text *zPlayer ) override;
  50. // Meldet die Beendigung eines Minigames
  51. // mName: Der Name des Minigames
  52. // oName: Die Optionen mit denen gespielt wurde
  53. // score: Der Erreichte Score
  54. // zCapture: Ein Zeiger auf eine Datei mit der Spielaufzeichnung
  55. // Gibt 0 zurück wenn eines Fehler aufgetreten ist, 1 wenn der Forgang erfolgreich war
  56. bool reportEndOfGame( char *mName, char *oName, int score, Framework::Datei *zCapture ) override;
  57. // Lädt ein Game Capture herunter und speichert sie unter data/tmp/minigames/wb.mgc
  58. // mName: Der Name des Minigames
  59. // oName: Die Optionen
  60. // Gibt die Datei mit dem Capture zurück
  61. Framework::Datei *downloadGameCapture( char *mName, char *oName ) override;
  62. // Erhält die Verbindung aufrecht
  63. // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
  64. // Sollte während einer bestehenden Verbindung etwa einmal alle 60 Sekunden aufgerufen werden, da sonst der Router die Verbindung automatisch trennt
  65. bool keepAlive() override;
  66. // Trennt die Verbindung zum Server
  67. // Gibt 1 zurück, falls der Vorgang erfolgreich ist, 0 sonnst
  68. // Sollte erst nach einem erfolgreichen Aufruf von verbinde aufgerufen werden
  69. bool trenne( bool abmelden ) override;
  70. // Gibt 1 zurück, falls der Client verbunden ist, 0 sonst
  71. bool istVerbunden() const override;
  72. // gibt den Letzten Fehlertext zuück
  73. // sollte erst aufgerufen werden, nachdem eine andere aufgerufene Methode fehlgeschlagen ist
  74. char *getLetzterFehler() const override;
  75. // Erhöht den Reference Counter um 1 un gibt this zurück
  76. MinigameServerClient *getThis() override;
  77. // Verringert den Reference Counter um 1 und gibt 0 zurück.
  78. // Falls der Reference Counter nach dem Aufruf auf 0 ist löscht sich das Objekt selbst
  79. MinigameServerClient *release() override;
  80. };
  81. }