瀏覽代碼

removed some rounding errors and added debug info

Kolja Strohm 6 年之前
父節點
當前提交
8dc817e204
共有 4 個文件被更改,包括 12 次插入5 次删除
  1. 8 2
      Asteroids/Klient.cpp
  2. 1 1
      Asteroids/SSKlient.h
  3. 2 1
      Asteroids/Spiel.cpp
  4. 1 1
      Asteroids/Spieler.cpp

+ 8 - 2
Asteroids/Klient.cpp

@@ -73,15 +73,21 @@ void Klient::sendeStart( int spielZeit )
 	delete[] bytes;
 }
 
-void Klient::sendeTastaturStatus( int spielerId, TastaturStatus ts, bool aktiv, int spielZeit )
+void Klient::sendeTastaturStatus( int spielerId, TastaturStatus ts, bool aktiv, int spielZeit, Vertex pos, Vertex speed, float rot, float rotS )
 {
 	if( !klient )
 		return;
-	short len = 9;
+	short len = 33;
 	char *bytes = new char[ len ];
 	*(int*)bytes = spielZeit;
 	*(char*)( bytes + 4 ) = (char)( (char)ts * 2 + (char)!aktiv );
 	*(int*)( bytes + 5 ) = spielerId;
+    *(float*)( bytes + 9 ) = pos.x;
+    *(float*)( bytes + 13 ) = pos.y;
+    *(float*)( bytes + 17 ) = speed.x;
+    *(float*)( bytes + 21 ) = speed.y;
+    *(float*)( bytes + 25 ) = rot;
+    *(float*)( bytes + 29 ) = rotS;
 	klient->spielNachricht( len, bytes );
 	delete[] bytes;
 }

+ 1 - 1
Asteroids/SSKlient.h

@@ -29,7 +29,7 @@ public:
 	void sendeInit( RCArray< Spieler > *zSpieler, int spielZeit );
 	void sendeSpielerNummer( int sNum, int spielZeit );
 	void sendeStart( int spielZeit );
-	void sendeTastaturStatus( int spielerId, TastaturStatus ts, bool aktiv, int spielZeit );
+	void sendeTastaturStatus( int spielerId, TastaturStatus ts, bool aktiv, int spielZeit, Vertex pos, Vertex speed, float rot, float rotS );
 	void sendeSkillNachricht( int sNum, char art, int spielZeit );
 	void sendeSchuss( int id, int sNum, Vertex pos, Vertex speed, double intensity, int spielZeit );
 	void sendeTreffer( int id, int sNum, int spielZeit );

+ 2 - 1
Asteroids/Spiel.cpp

@@ -243,7 +243,7 @@ void Spiel::nachricht( int accountId, int len, char *bytes )
 					{
 						Spieler *s = spieler->z( j );
 						if( s && s->zKlient() )
-							s->zKlient()->sendeTastaturStatus( tmp->getSpielerNummer(), (TastaturStatus)( (int)( *bytes ) / 2 ), ( (int)( *bytes ) % 2 ) == 0, spielZeit );
+							s->zKlient()->sendeTastaturStatus( tmp->getSpielerNummer(), (TastaturStatus)( (int)( *bytes ) / 2 ), ( (int)( *bytes ) % 2 ) == 0, spielZeit, tmp->getPosition(), tmp->getSpeed(), tmp->getDrehung(), tmp->getDrehungSpeed() );
 					}
 				}
 				break;
@@ -379,6 +379,7 @@ void Spiel::tick( double zeit )
 					{ // Treffer
                         double intens = tmp->getIntensity() * ( ( tmp->getSpeed() - s->getSpeed() ).getLength() / 200 );
 						bool kill = s->nimmSchaden( intens );
+                        s->impuls( tmp->getPosition() - tmp->getSpeed(), tmp->getSpeed() * 0.3f );
 						for( int k = 0; k < spielerAnzahl; k++ )
 						{
 							Spieler *sp = spieler->z( k );

+ 1 - 1
Asteroids/Spieler.cpp

@@ -334,7 +334,7 @@ Laser *Spieler::getLaser( int sId )
     schussAbk = 1;
     energieAbk = 1.5;
     shots++;
-    Vertex sSpeed = ( Vertex( (float)cos( rotation ), (float)sin( rotation ) ) * (float)( laserTempo + team->laserTempo ) );
+    Vertex sSpeed = ( Vertex( lowPrecisionSin( rotation ), lowPrecisionCos( rotation ) ) * (float)( laserTempo + team->laserTempo ) );
     sSpeed += speed;
     return new Laser( sId, getPosition(), sSpeed, sNum, laserIntensity + team->laserIntensity );
 }