Karte.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. #include "Karte.h"
  2. #include <Text.h>
  3. // Inhalt der Karte Klasse aus Karte.h
  4. // Konstruktor
  5. Karte::Karte()
  6. {
  7. größe = Vec2< int >( 0, 0 );
  8. spielerAnzahl = 0;
  9. teamAnzahl = 0;
  10. spielerFarbe = new Array< int >();
  11. teamFarbe = new Array< int >();
  12. teamName = new RCArray< Text >();
  13. teamGröße = new Array< int >();
  14. ressources = new RCArray< RessourceStr >();
  15. objekte = new RCArray< ZeichnungStr >();
  16. spieler = new RCArray< SpielerStr >();
  17. teams = new RCArray< TeamStr >();
  18. ref = 1;
  19. }
  20. // Destruktor
  21. Karte::~Karte()
  22. {
  23. spielerFarbe->release();
  24. teamFarbe->release();
  25. teamName->release();
  26. teamGröße->release();
  27. ressources->release();
  28. objekte->release();
  29. spieler->release();
  30. teams->release();
  31. }
  32. // nicht constant
  33. void Karte::ladeSts( Datei *zDatei )
  34. {
  35. zDatei->lese( (char*)&spielerAnzahl, 4 );
  36. zDatei->lese( (char*)&teamAnzahl, 4 );
  37. spielerFarbe->leeren();
  38. for( int i = 0; i < spielerAnzahl; i++ )
  39. {
  40. int farbe = 0;
  41. zDatei->lese( (char*)&farbe, 4 );
  42. spielerFarbe->set( farbe, i );
  43. }
  44. teamFarbe->leeren();
  45. for( int i = 0; i < teamAnzahl; i++ )
  46. {
  47. int farbe = 0;
  48. zDatei->lese( (char*)&farbe, 4 );
  49. teamFarbe->set( farbe, i );
  50. }
  51. teamName->leeren();
  52. for( int i = 0; i < teamAnzahl; i++ )
  53. {
  54. char län = 0;
  55. zDatei->lese( &län, 1 );
  56. char *txt = new char[ län + 1 ];
  57. txt[ (int)län ] = 0;
  58. zDatei->lese( txt, län );
  59. Text *name = new Text( txt );
  60. delete[] txt;
  61. teamName->set( name, i );
  62. }
  63. teamGröße->leeren();
  64. for( int i = 0; i < teamAnzahl; i++ )
  65. {
  66. int größe = 0;
  67. zDatei->lese( (char*)&größe, 4 );
  68. teamGröße->set( größe, i );
  69. }
  70. }
  71. void Karte::ladeMap( Datei *zDatei, InformationKlientV *infoK, int mapId, SpielKlientV *zSpielKlient )
  72. {
  73. int ressourceAnz = 0;
  74. zDatei->lese( (char*)&ressourceAnz, 4 );
  75. for( int i = 0; i < ressourceAnz; i++ )
  76. {
  77. ressources->add( new RessourceStr( zDatei, infoK, mapId ) );
  78. zSpielKlient->setLadenProzent( 5 + (int)( 65 * ( (double)( i + 1 ) / ressourceAnz ) + 0.5 ) );
  79. }
  80. zDatei->lese( (char*)&größe.x, 4 );
  81. zDatei->lese( (char*)&größe.y, 4 );
  82. int objektAnzahl = 0;
  83. zDatei->lese( (char*)&objektAnzahl, 4 );
  84. for( int i = 0; i < objektAnzahl; i++ )
  85. {
  86. objekte->add( new ZeichnungStr( zDatei ) );
  87. zSpielKlient->setLadenProzent( 70 + (int)( 10 * ( (double)( i + 1 ) / objektAnzahl ) + 0.5 ) );
  88. }
  89. for( int i = 0; i < spielerAnzahl; i++ )
  90. {
  91. spieler->add( new SpielerStr( zDatei ) );
  92. zSpielKlient->setLadenProzent( 80 + (int)( 5 * ( (double)( i + 1 ) / spielerAnzahl ) + 0.5 ) );
  93. }
  94. for( int i = 0; i < teamAnzahl; i++ )
  95. {
  96. teams->add( new TeamStr( zDatei ) );
  97. zSpielKlient->setLadenProzent( 85 + (int)( 5 * ( (double)( i + 1 ) / teamAnzahl ) + 0.5 ) );
  98. }
  99. }
  100. // constant
  101. Vec2< int > Karte::getSize() const
  102. {
  103. return größe;
  104. }
  105. Spieler *Karte::createSpieler( int sNum, Schrift *zSchrift, InformationKlientV *zInfoK ) const
  106. {
  107. if( sNum < 0 || sNum >= spielerAnzahl )
  108. return 0;
  109. Spieler *ret = new Spieler( zInfoK, zSchrift, spieler->z( sNum ) );
  110. int m2d = spieler->z( sNum )->m2d;
  111. int bild = spieler->z( sNum )->bild;
  112. for( auto i = &ressources->getArray(); i && i->set && i->var; i = i->next )
  113. {
  114. if( i->var->getId() == m2d )
  115. ret->setModelData( i->var->zReccourceM2()->getThis() );
  116. if( i->var->getId() == bild )
  117. ret->setSpielerFarbe( spielerFarbe->hat( sNum ) ? spielerFarbe->get( sNum ) : 0, i->var->zReccourceTxt() );
  118. }
  119. return ret;
  120. }
  121. Team *Karte::createTeam( int tNum ) const
  122. {
  123. if( tNum < 0 || tNum >= teamAnzahl )
  124. return 0;
  125. Team *ret = new Team( teamFarbe->get( tNum ), teamName->z( tNum )->getText(), teams->z( tNum ) );
  126. return ret;
  127. }
  128. SpielObjekt *Karte::createZeichnung( int oNum, Schrift *zSchrift ) const
  129. {
  130. if( oNum < 0 || oNum > objekte->getEintragAnzahl() )
  131. return 0;
  132. SpielObjekt *ret = new SpielObjekt( objekte->z( oNum ), zSchrift );
  133. int m2d = objekte->z( oNum )->m2d;
  134. int bild = objekte->z( oNum )->bild;
  135. for( auto i = &ressources->getArray(); i && i->set && i->var; i = i->next )
  136. {
  137. if( i->var->getId() == m2d )
  138. ret->setModelData( i->var->zReccourceM2()->getThis() );
  139. if( i->var->getId() == bild )
  140. ret->setTextur( i->var->zReccourceTxt()->getThis() );
  141. }
  142. return ret;
  143. }
  144. int Karte::getMaxTeamAnzahl() const
  145. {
  146. return teamAnzahl;
  147. }
  148. int Karte::getMaxSpielerAnzahl() const
  149. {
  150. return spielerAnzahl;
  151. }
  152. int Karte::getZeichnungAnzahl() const
  153. {
  154. return objekte->getEintragAnzahl();
  155. }
  156. int Karte::getTeamNummer( int sNum ) const
  157. {
  158. int min = teamGröße->get( 0 );
  159. for( int i = 1; i <= teamAnzahl; i++ )
  160. {
  161. if( sNum < min )
  162. return i - 1;
  163. min += teamGröße->hat( i ) ? teamGröße->get( i ) : 0;
  164. }
  165. return -1;
  166. }
  167. // Reference Counting
  168. Karte *Karte::getThis()
  169. {
  170. ref++;
  171. return this;
  172. }
  173. Karte *Karte::release()
  174. {
  175. ref--;
  176. if( !ref )
  177. delete this;
  178. return 0;
  179. }