12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481 |
- #include "SpielKlasse.h"
- #include <time.h>
- #include <Schrift.h>
- #include <MausEreignis.h>
- #include <TastaturEreignis.h>
- #include <M2Datei.h>
- #include <DateiSystem.h>
- #include "SpielerGUI/SpielerGUI.h"
- #include "Define.h"
- #include <Animation.h>
- #include <Textur2D.h>
- SpielKlasse::SpielKlasse()
- {
- shieldBoost = 0;
- speedBoost = 0;
- spielZeit = -1;
- rZeit = 0;
- rendern = 0;
- stkn = new RCArray< STKNachricht >();
- stkna = 0;
- schrift = 0;
- time_t t;
- time( &t );
- srand( (unsigned int)t );
- infoKlient = 0;
- spielKlient = 0;
- spieler = new RCArray< Spieler >();
- asteroids = new RCArray< Asteroid >();
- teams = new RCArray< Team >();
- objekte = new RCArray< SpielObjekt >();
- deads = new RCArray< DeadPlayer >();
- screen = 0;
- welt = new Welt2D();
- welt->setCircular( 1 );
- welt->setAirResistance( 0.001f );
- kam = new Kamera2D();
- kam->setWelt( welt->getThis(), 1 );
- minimap = new Kamera2D();
- minimap->setSize( 200, 200 );
- minimap->setWelt( welt->getThis(), 0 );
- minimap->setStyle( ZeichnungHintergrund::Style::Sichtbar | ZeichnungHintergrund::Style::Rahmen );
- minimap->setRahmenFarbe( 0xFFFFFFFF );
- minimap->setName( "minimap" );
- spielerAnzahl = 0;
- karteId = 0;
- ladenProzent = 0;
- spielerNummer = 0;
- map = 0;
- end = 0;
- chat = new SpielChat();
- tasten = new char[ 256 ];
- for( int i = 0; i < 256; i++ )
- tasten[ i ] = 0;
- bestenliste = 0;
- schüsse = new RCArray< Laser >();
- shipGUI = 0;
- spielPause = 1;
- setKam = 0;
- asteroidModels = new RCArray< Model2DData >();
- asteroidTextures = new RCArray< Textur2D >();
- pixel = new RCArray< Pixel >();
- ref = 1;
- save();
- }
- SpielKlasse::~SpielKlasse()
- {
- for( int i = 0; i < map->getMaxTeamAnzahl(); i++ )
- {
- if( teams->z( i ) )
- teams->z( i )->reset();
- }
- map->release();
- minimap->release();
- welt->release();
- deads->release();
- stkn->release();
- if( schrift )
- schrift->release();
- if( infoKlient )
- infoKlient->release();
- if( spielKlient )
- spielKlient->release();
- if( kam )
- kam->release();
- if( end )
- end->release();
- if( bestenliste )
- bestenliste->release();
- if( shipGUI )
- shipGUI->release();
- chat->relese();
- spieler->release();
- asteroids->release();
- asteroidModels->release();
- asteroidTextures->release();
- teams->release();
- objekte->release();
- schüsse->release();
- pixel->release();
- delete[] tasten;
- if( speedBoost )
- speedBoost->release();
- if( shieldBoost )
- shieldBoost->release();
- }
- bool SpielKlasse::istAmLeben() const
- {
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- return spieler->z( i )->istAmLeben();
- }
- return 0;
- }
- void SpielKlasse::goBackInTime( int zeit )
- {
- if( zeit < last.spielZeit )
- chat->addNachricht( "Fehler: Es wurde versucht das Spiel auf einen Zeitpunkt zurückzusetzen, welcher nicht mehr erreicht werden kann.", 0xFFFF0000 );
- load();
- while( spielZeit < zeit )
- tick();
- }
- void SpielKlasse::goToPresence( int zeit )
- {
- save();
- while( spielZeit < zeit )
- tick();
- }
- void SpielKlasse::load()
- {
- spielZeit = last.spielZeit;
- for( auto i = spieler->getIterator(); i; i++ )
- i->load();
- for( auto i = objekte->getIterator(); i; i++ )
- i->load();
- for( auto i = schüsse->getIterator(); i; i++ )
- i->load();
- for( auto i = asteroids->getIterator(); i; i++ )
- i->load();
- for( auto i = pixel->getIterator(); i; i++ )
- i->load();
- for( auto i = deads->getIterator(); i; i++ )
- i->load();
- }
- void SpielKlasse::save()
- {
- last.spielZeit = spielZeit;
- for( auto i = spieler->getIterator(); i; i++ )
- i->save();
- for( auto i = objekte->getIterator(); i; i++ )
- i->save();
- for( auto i = schüsse->getIterator(); i; i++ )
- i->save();
- for( auto i = asteroids->getIterator(); i; i++ )
- i->save();
- for( auto i = pixel->getIterator(); i; i++ )
- i->save();
- for( auto i = deads->getIterator(); i; i++ )
- i->save();
- }
- void SpielKlasse::tick()
- {
- spielZeit++;
- kam->tick( TICK );
- int asteroidAnz = asteroids->getEintragAnzahl();
- for( int i = 0; i < asteroidAnz; i++ )
- {
- Asteroid *p = asteroids->z( i );
- if( p->isDead() )
- {
- welt->removeObject( p );
- asteroids->remove( i-- );
- asteroidAnz--;
- }
- }
- }
- void SpielKlasse::lock()
- {
- if( screen )
- screen->lock();
- }
- void SpielKlasse::unlock()
- {
- if( screen )
- screen->unlock();
- }
- void SpielKlasse::setSchrift( Schrift * schrift )
- {
- if( this->schrift )
- this->schrift->release();
- this->schrift = schrift;
- chat->setSchrift( schrift );
- if( !bestenliste )
- bestenliste = new Bestenliste( schrift->getThis() );
- if( !shipGUI )
- shipGUI = new SpielerGUI( schrift );
- }
- void SpielKlasse::setBildschirm( Bildschirm * zScreen )
- {
- screen = zScreen;
- }
- void SpielKlasse::nachricht( int län, char *bytes )
- {
- if( !län )
- return;
- lock();
- stkn->add( new STKNachricht( län, bytes ), stkna );
- stkna++;
- unlock();
- }
- void SpielKlasse::setKlients( KSGClient::InformationServerClient * infoKlient, KSGClient::SpielServerClient * spielKlient )
- {
- if( this->infoKlient )
- this->infoKlient->release();
- this->infoKlient = infoKlient;
- if( this->spielKlient )
- this->spielKlient->release();
- this->spielKlient = spielKlient;
- }
- void SpielKlasse::setKarteId( int karteId )
- {
- this->karteId = karteId;
- }
- void SpielKlasse::ladeDaten()
- {
- Text path = "data/log/0.csv";
- for( int i = 1; DateiExistiert( path ); i++ )
- {
- path = "data/log/";
- path += i;
- path += ".csv";
- }
- csv.setDatei( path );
- csv.erstellen();
- csv.open( Datei::Style::schreiben );
- csv.schreibe( "Spielernummer;Skill ID\n", 23 );
-
- Text *gamePath = infoKlient->getDateiGruppePfad( infoKlient->getDateiGruppeIdVonSpiel( infoKlient->getSpielId( karteId ) ) );
- LTDBDatei flammenStartLTDB;
- Text *f_start = new Text( gamePath->getText() );
- f_start->append( "/bilder/f_start.ltdb" );
- flammenStartLTDB.setDatei( f_start );
- flammenStartLTDB.leseDaten( 0 );
- Animation2DData *flammenStart = new Animation2DData();
- flammenStart->ladeAnimation( flammenStartLTDB.getThis() );
- flammenStart->setFPS( 75 );
- flammenStart->setWiederhohlend( 0 );
- spielKlient->setLadenProzent( 7 );
- LTDBDatei flammenLTDB;
- Text *f_burn = new Text( gamePath->getText() );
- f_burn->append( "/bilder/f_burn.ltdb" );
- flammenLTDB.setDatei( f_burn );
- Animation2DData *flammenBurn = new Animation2DData();
- flammenBurn->ladeAnimation( flammenLTDB.getThis() );
- flammenBurn->setFPS( 60 );
- flammenBurn->setWiederhohlend( 1 );
- map = new Karte();
- Text *mapPf = new Text( "data/tmp/Karten/" );
- mapPf->append( karteId );
- mapPf->append( "/spiel/data/data.sts" );
- Datei *stsD = new Datei();
- stsD->setDatei( mapPf->getText() );
- stsD->open( Datei::Style::lesen );
- map->ladeSts( stsD );
- stsD->close();
- stsD->release();
- spielKlient->setLadenProzent( 15 );
- mapPf->ersetzen( mapPf->getLength() - 3, mapPf->getLength(), "map" );
- Datei *mapD = new Datei();
- mapD->setDatei( mapPf->getText() );
- mapD->open( Datei::Style::lesen );
- map->ladeMap( mapD, karteId, spielKlient, gamePath );
- mapD->close();
- mapD->release();
- mapPf->release();
- for( int i = 0; i < map->getMaxSpielerAnzahl(); i++ )
- {
- Spieler *s = map->createSpieler( i, schrift, infoKlient, flammenStart, flammenBurn );
- spieler->set( s, i );
- }
- flammenStart->release();
- flammenBurn->release();
- spielKlient->setLadenProzent( 75 );
- for( auto o = map->getObjekte(); o; o++ )
- {
- SpielObjekt *obj = map->createObjekt( o->id, schrift );
- obj->setTeam( teams->get( o->team - 1 ) );
- welt->addObject( obj->getThis() );
- objekte->add( obj );
- }
- bestenliste->setTeamAnzahl( map->getMaxTeamAnzahl() );
- welt->setSize( map->getSize().x, map->getSize().y );
- welt->setSize( 1 );
- spielKlient->setLadenProzent( 80 );
- M2Datei astroidModels;
- Text aModelPath = gamePath->getText();
- aModelPath += "/models/asteroids.m2";
- astroidModels.setPfad( aModelPath );
- astroidModels.leseDaten();
- int anz = astroidModels.getModelAnzahl();
- for( int i = 0; i < anz; i++ )
- {
- this->asteroidModels->add( astroidModels.ladeModel( astroidModels.zModelName( i )->getText() ) );
- }
- spielKlient->setLadenProzent( 85 );
- LTDBDatei asteroidTexturD;
- Text aTexturPfad = gamePath->getText();
- aTexturPfad += "/bilder/asteroids.ltdb";
- asteroidTexturD.setDatei( aTexturPfad.getThis() );
- asteroidTexturD.leseDaten( 0 );
- for( int i = 0; i < anz; i++ )
- {
- Text *name = new Text( astroidModels.zModelName( i )->getText() );
- name->append( ".png" );
- Textur2D *txt = new Textur2D();
- txt->setTexturZ( asteroidTexturD.laden( 0, name ) );
- asteroidTextures->add( txt );
- }
- spielKlient->setLadenProzent( 98 );
- LTDBDatei skillLTDB;
- Text *skillLTDBPfad = new Text( gamePath->getText() );
- skillLTDBPfad->append( "/bilder/skills.ltdb" );
- skillLTDB.setDatei( skillLTDBPfad );
- skillLTDB.leseDaten( 0 );
- speedBoost = skillLTDB.laden( 0, new Text( "speedboost.png" ) );
- spielKlient->setLadenProzent( 99 );
- shieldBoost = skillLTDB.laden( 0, new Text( "shieldboost.png" ) );
- spielKlient->setLadenProzent( 100 );
- gamePath->release();
- }
- void SpielKlasse::doMausEreignis( MausEreignis & me )
- {
- if( end )
- {
- end->doMausEreignis( me );
- return;
- }
- if( !istAmLeben() )
- me.verarbeitet = 1;
- int skill = shipGUI->doMausEreignis( me );
- if( skill >= 0 )
- {
- char bytes[ 2 ];
- bytes[ 0 ] = 9;
- bytes[ 1 ] = (char)skill;
- spielKlient->spielNachricht( 2, bytes );
- }
- chat->doMausEreignis( me );
- if( bestenliste )
- bestenliste->doMausEreignis( me );
- }
- void SpielKlasse::doTastaturEreignis( TastaturEreignis & te )
- {
- bestenliste->doTastaturEreignis( te );
- if( end )
- {
- end->doTastaturEreignis( te );
- return;
- }
- if( !chat->istAktiv() )
- {
- if( istAmLeben() )
- {
- if( te.id == TE_Press )
- {
- switch( te.taste )
- {
- case 'w':
- case 'W':
- case T_Oben:
- if( !tasten[ T_Oben ] )
- {
- tasten[ T_Oben ] = 1;
- char byte = 0;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case 'a':
- case 'A':
- case T_Links:
- if( !tasten[ T_Links ] )
- {
- tasten[ T_Links ] = 1;
- char byte = 2;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case 'd':
- case 'D':
- case T_Rechts:
- if( !tasten[ T_Rechts ] )
- {
- tasten[ T_Rechts ] = 1;
- char byte = 4;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case T_Space:
- if( !tasten[ T_Space ] )
- {
- tasten[ T_Space ] = 1;
- char byte = 6;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- }
- }
- if( te.id == TE_Release )
- {
- switch( te.taste )
- {
- case 'w':
- case 'W':
- case T_Oben:
- if( tasten[ T_Oben ] )
- {
- tasten[ T_Oben ] = 0;
- char byte = 1;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case 'a':
- case 'A':
- case T_Links:
- if( tasten[ T_Links ] )
- {
- tasten[ T_Links ] = 0;
- char byte = 3;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case 'd':
- case 'D':
- case T_Rechts:
- if( tasten[ T_Rechts ] )
- {
- tasten[ T_Rechts ] = 0;
- char byte = 5;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case T_Space:
- if( tasten[ T_Space ] )
- {
- tasten[ T_Space ] = 0;
- char byte = 7;
- spielKlient->spielNachricht( 1, &byte );
- te.verarbeitet = 1;
- }
- break;
- case '1':
- {
- char byte[ 2 ] = { 0xA, 0 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '2':
- {
- char byte[ 2 ] = { 0xA, 1 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '3':
- {
- char byte[ 2 ] = { 0xA, 2 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '4':
- {
- char byte[ 2 ] = { 0xA, 3 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '5':
- {
- char byte[ 2 ] = { 0xA, 4 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '6':
- {
- char byte[ 2 ] = { 0xA, 5 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '7':
- {
- char byte[ 2 ] = { 0xA, 6 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '8':
- {
- char byte[ 2 ] = { 0xA, 7 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '9':
- {
- char byte[ 2 ] = { 0xA, 8 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- case '0':
- {
- char byte[ 2 ] = { 0xA, 9 };
- spielKlient->spielNachricht( 2, byte );
- te.verarbeitet = 1;
- break;
- }
- }
- }
- }
- else
- {
- if( te.id == TE_Press )
- {
- switch( te.taste )
- {
- case T_Links:
- kam->setPosition( kam->getPosition() + Vertex( -2, 0 ) );
- te.verarbeitet = 1;
- break;
- case T_Oben:
- kam->setPosition( kam->getPosition() + Vertex( 0, -2 ) );
- te.verarbeitet = 1;
- break;
- case T_Rechts:
- kam->setPosition( kam->getPosition() + Vertex( 2, 0 ) );
- te.verarbeitet = 1;
- break;
- case T_Unten:
- kam->setPosition( kam->getPosition() + Vertex( 0, 2 ) );
- te.verarbeitet = 1;
- break;
- }
- }
- }
- }
- if( !te.verarbeitet )
- chat->doTastaturEreignis( te, spielKlient );
- }
- void SpielKlasse::stknVerarbeitung()
- {
- lock();
- for( int i = 0; i < stkna; i++ )
- {
- STKNachricht *n = stkn->z( i );
- int zeit = n->getSpielZeit();
- while( zeit > spielZeit )
- tick();
- int län = n->getLength();
- char *bytes = n->getNachricht();
- län--;
- int sNum = 0;
- int presence = spielZeit;
- if( presence > zeit + 10 )
- presence = zeit + 10;
- switch( bytes[ 0 ] )
- {
- case 0:
- bytes++;
- sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto i = spieler->getIterator(); i; i++ )
- {
- if( i->getSpielerNummer() == sNum )
- {
- i->setTastataturStatus( T_GAS, 1 );
- }
- }
- goToPresence( presence );
- break;
- case 1:
- bytes++;
- sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto i = spieler->getIterator(); i; i++ )
- {
- if( i->getSpielerNummer() == sNum )
- {
- i->setTastataturStatus( T_GAS, 0 );
- }
- }
- goToPresence( presence );
- break;
- case 2:
- bytes++;
- sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto i = spieler->getIterator(); i; i++ )
- {
- if( i->getSpielerNummer() == sNum )
- {
- i->setTastataturStatus( T_ROT_L, 1 );
- }
- }
- goToPresence( presence );
- break;
- case 3:
- bytes++;
- sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto i = spieler->getIterator(); i; i++ )
- {
- if( i->getSpielerNummer() == sNum )
- {
- i->setTastataturStatus( T_ROT_L, 0 );
- }
- }
- goToPresence( presence );
- break;
- case 4:
- bytes++;
- sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto i = spieler->getIterator(); i; i++ )
- {
- if( i->getSpielerNummer() == sNum )
- {
- i->setTastataturStatus( T_ROT_R, 1 );
- }
- }
- goToPresence( presence );
- break;
- case 5:
- bytes++;
- sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto i = spieler->getIterator(); i; i++ )
- {
- if( i->getSpielerNummer() == sNum )
- {
- i->setTastataturStatus( T_ROT_R, 0 );
- }
- }
- goToPresence( presence );
- break;
- case 6:
- if( 1 )
- {
- bytes++;
- spielerAnzahl = (int)* bytes;
- bytes++;
- län--;
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- int sNum = *(int *)bytes;
- Spieler *tmp = spieler->z( sNum - 1 );
- tmp->addSkill( new ShieldBoost( shieldBoost->getThis() ) );
- tmp->addSkill( new SpeedBoost( speedBoost->getThis() ) );
- bytes += 4;
- län -= 4;
- tmp->setAccountId( *(int *)bytes );
- bytes += 4;
- län -= 4;
- if( !teams->z( map->getTeamNummer( sNum ) ) )
- teams->set( map->createTeam( map->getTeamNummer( sNum ) ), map->getTeamNummer( sNum ) );
- tmp->setTeam( teams->z( map->getTeamNummer( sNum ) ) );
- tmp->zTeam()->spieler->add( (Spieler *)tmp->getThis() );
- bestenliste->addSpieler( tmp );
- bestenliste->updateSpieler( tmp );
- bestenliste->updateTeam( tmp->zTeam() );
- welt->addObject( tmp->getThis() );
- }
- int max = map->getMaxSpielerAnzahl();
- for( int i = 0; i < max; i++ )
- {
- if( !spieler->z( i )->zTeam() )
- {
- spieler->remove( i );
- i--;
- max--;
- }
- }
- }
- break;
- case 0x8:
- if( 1 )
- {
- bytes++;
- Text *txt = new Text( "" );
- txt->append( bytes, län );
- chat->addNachricht( txt->getText() );
- txt->release();
- län = 0;
- }
- break;
- case 0x9:
- bytes++;
- spielerNummer = *(int *)bytes;
- län -= 4;
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( spieler->z( i ) );
- break;
- }
- }
- break;
- case 0xA:
- spielPause = 0;
- rendern = 1;
- break;
- case 0xB:
-
- csv.schreibe( "\n\nSpielernummer;Kills;Tode;Schaden gemacht;Schaden bekommen;Schüsse;Treffer\n", 2 );
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- Spieler *s = spieler->z( i );
- Text line = s->getSpielerNummer();
- line += ";";
- line += s->getKills();
- line += ";";
- line += s->getTode();
- line += ";";
- line += s->getSchadenGemacht();
- line += ";";
- line += s->getSchadenBekommen();
- line += ";";
- line += s->getSchüsse();
- line += ";";
- line += s->getTreffer();
- line += "\n";
- csv.schreibe( line, line.getLength() );
- }
- csv.close();
- end = new Ende( schrift );
- bytes++;
- län--;
- end->setGewonnen( *bytes );
- break;
- case 0xC:
- if( 1 )
- {
- bytes++;
- sNum = *(int *)bytes;
- bytes += 4;
- län -= 4;
- char art = *bytes;
- län--;
- Text line = sNum;
- line += ";";
- line += art;
- line += "\n";
- csv.schreibe( line, line.getLength() );
- goBackInTime( zeit );
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == sNum )
- {
- Team *tmp = spieler->z( i )->zTeam();
- spieler->z( i )->setSkill( art );
- tmp->akkuLeistung = tmp->getAkkuLeistungBonus();
- tmp->beschleunigung = tmp->getBeschleunigungBonus();
- tmp->laserEffizienz = tmp->getLaserEffizienzBonus();
- tmp->laserIntensität = tmp->getLaserIntensitätBonus();
- tmp->laserTempo = tmp->getLaserTempoBonus();
- tmp->maxEnergie = tmp->getMaxEnergieBonus();
- tmp->maxStabilität = tmp->getMaxStabilitätBonus();
- tmp->reparatur = tmp->getReperaturBonus();
- tmp->wendigkeit = tmp->getWendigkeitBonus();
- tmp->antriebEffizienz = tmp->getAntriebEffizienzBonus();
- tmp->energieSchild = tmp->getEnergieSchildBonus();
- tmp->energieSchildEffizienz = tmp->getEnergieSchildEffizienzBonus();
- break;
- }
- }
- goToPresence( presence );
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( spieler->z( i ) );
- break;
- }
- }
- }
- break;
- case 0xD:
- if( 1 )
- {
- bytes++;
- int id = *(int *)bytes;
- bytes += 4;
- län -= 4;
- sNum = *(int *)bytes;
- bytes += 4;
- län -= 4;
- float xPos = *(float *)bytes;
- bytes += 4;
- län -= 4;
- float yPos = *(float *)bytes;
- bytes += 4;
- län -= 4;
- float xSpeed = *(float *)bytes;
- bytes += 4;
- län -= 4;
- float ySpeed = *(float *)bytes;
- bytes += 4;
- län -= 4;
- double intensität = *(double *)bytes;
- län -= 8;
- int farbe = 0;
- goBackInTime( zeit );
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == sNum )
- {
- if( spieler->z( i )->getPosition() != Vertex( xPos, yPos ) )
- chat->addNachricht( Text( "asynchrony detected difference: " ) += ( spieler->z( i )->getPosition() - Vertex( xPos, yPos ) ).getLength(), 0xFFFF0000 );
- spieler->z( i )->setPosition( Vertex( xPos, yPos ) );
- spieler->z( i )->hatGeschossen();
- farbe = spieler->z( i )->zTeam()->farbe;
- break;
- }
- }
- Laser *l = new Laser( id, Vertex( xPos, yPos ), Vertex( xSpeed, ySpeed ), sNum, intensität, farbe );
- welt->addObject( l->getThis() );
- schüsse->add( l );
- goToPresence( presence );
- if( sNum == spielerNummer )
- {
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( spieler->z( i ) );
- bestenliste->updateSpieler( spieler->z( i ) );
- break;
- }
- }
- }
- }
- break;
- case 0xE:
- if( 1 )
- {
- bytes++;
- int schuss = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int sNum = *(int *)bytes;
- bytes += 4;
- län -= 4;
- float erf = *(float *)bytes;
- bytes += 4;
- län -= 4;
- int skillP = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- int sAnz = schüsse->getEintragAnzahl();
- for( int i = 0; i < sAnz; i++ )
- {
- Laser *tmp = schüsse->z( i );
- if( tmp && tmp->getId() == schuss )
- {
- if( sNum >= 0 )
- {
- double intens = 0;
- Spieler *attacker = 0;
- Spieler *attacked = 0;
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == tmp->getSpieler() )
- attacker = s;
- if( s->getSpielerNummer() == sNum )
- attacked = s;
- }
- if( attacked && attacker )
- {
- intens = tmp->getIntensität( attacked->getSpeed() );
- attacked->nimmSchaden( intens, attacker ? attacker->getLevel() : 1 );
- if( tmp->getSpeed().getLengthSq() > 0 )
- attacked->impuls( tmp->getPosition() - tmp->getSpeed(), tmp->getSpeed() * 0.3f );
- attacked->calcDeadPlayerObject( schüsse->z( i ) );
- bestenliste->updateSpieler( attacked );
- attacker->machSchaden( intens, attacked->getLevel() );
- if( attacker->getEp() != erf )
- chat->addNachricht( Text( "asynchrony detected ep difference: " ) += ( erf - attacker->getEp() ), 0xFFFF0000 );
- if( attacker->getSkillP() != skillP )
- chat->addNachricht( Text( "asynchrony detected skillPunkte difference: " ) += ( skillP - attacker->getSkillP() ), 0xFFFF0000 );
- bestenliste->updateSpieler( attacker );
- }
- }
- welt->removeObject( tmp );
- schüsse->remove( i );
- break;
- }
- }
- goToPresence( presence );
- if( sNum == spielerNummer )
- {
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( s );
- break;
- }
- }
- }
- }
- break;
- case 0xF:
- if( 1 )
- {
- bytes++;
- int sNum = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == sNum )
- {
- s->wiederbelebung();
- break;
- }
- }
- goToPresence( presence );
- if( sNum == spielerNummer )
- {
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( s );
- break;
- }
- }
- }
- }
- break;
- case 0x10:
- if( 1 )
- {
- bytes++;
- sNum = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int killer = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- Spieler *dead = 0;
- Spieler *kill = 0;
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == sNum )
- dead = s;
- if( s->getSpielerNummer() == killer )
- kill = s;
- }
- if( dead )
- {
- DeadPlayer *dp = dead->sterben();
- if( dp )
- {
- welt->addObject( dp->getThis() );
- deads->add( dp );
- }
- bestenliste->updateSpieler( dead );
- }
- if( kill )
- {
- kill->addKill( dead->getLevel() );
- kill->zTeam()->punkte++;
- bestenliste->updateTeam( kill->zTeam() );
- bestenliste->updateSpieler( kill );
- }
- goToPresence( presence );
- if( sNum == spielerNummer )
- {
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( spieler->z( i ) );
- break;
- }
- }
- }
- }
- break;
- case 0x11:
- {
- Vertex pos, speed;
- float rot, rotS;
- bytes++;
- int id = *(int *)bytes;
- bytes += 4;
- län -= 4;
- pos.x = *(float *)bytes;
- bytes += 4;
- län -= 4;
- pos.y = *(float *)bytes;
- bytes += 4;
- län -= 4;
- speed.x = *(float *)bytes;
- bytes += 4;
- län -= 4;
- speed.y = *(float *)bytes;
- bytes += 4;
- län -= 4;
- rot = *(float *)bytes;
- bytes += 4;
- län -= 4;
- rotS = *(float *)bytes;
- bytes += 4;
- län -= 4;
- int index = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- Asteroid *na = new Asteroid( id, pos, speed, rot, rotS, asteroidModels->get( index ), asteroidTextures->get( index ) );
- welt->addObject( na->getThis() );
- asteroids->add( na );
- goToPresence( presence );
- break;
- }
- case 0x12:
- {
- Vertex pos;
- bytes++;
- int schuss = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int asteroid = *(int *)bytes;
- bytes += 4;
- län -= 4;
- pos.x = *(float *)bytes;
- bytes += 4;
- län -= 4;
- pos.y = *(float *)bytes;
- bytes += 4;
- län -= 4;
- __int64 seed = *(__int64 *)bytes;
- bytes += 8;
- län -= 8;
- int newAsteroid = *(int *)bytes;
- bytes += 4;
- län -= 4;
- float erf = *(float *)bytes;
- bytes += 4;
- län -= 4;
- int skillP = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- int aAnz = asteroids->getEintragAnzahl();
- for( int i = 0; i < aAnz; i++ )
- {
- Asteroid *a = asteroids->z( i );
- if( a->getId() == asteroid )
- {
- int sAnz = schüsse->getEintragAnzahl();
- for( int j = 0; j < sAnz; j++ )
- {
- Laser *tmp = schüsse->z( j );
- if( tmp && tmp->getId() == schuss )
- {
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == tmp->getSpieler() )
- {
- s->addTreffer( (float)tmp->getIntensität( a->getSpeed() ), 0 );
- if( s->getEp() != erf )
- chat->addNachricht( Text( "asynchrony detected ep difference: " ) += ( erf - s->getEp() ), 0xFFFF0000 );
- if( s->getSkillP() != skillP )
- chat->addNachricht( Text( "asynchrony detected skillPunkte difference: " ) += ( skillP - s->getSkillP() ), 0xFFFF0000 );
- break;
- }
- }
- Asteroid * na = a->split( pos, tmp->getSpeed(), seed, newAsteroid );
- welt->addObject( na->getThis() );
- asteroids->add( na );
- welt->removeObject( tmp );
- schüsse->remove( j );
- }
- }
- break;
- }
- }
- goToPresence( presence );
- break;
- }
- case 0x13:
- {
- bytes++;
- int asteroid = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int pixelId = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- for( auto a = asteroids->getIterator(); a; a++ )
- {
- if( a->getId() == asteroid )
- {
- Pixel *p = new Pixel( a->getPosition(), a->getSpeed(), a->getMasse() / 50, pixelId );
- welt->addObject( p->getThis() );
- pixel->add( p );
- a->setDead();
- break;
- }
- }
- goToPresence( presence );
- break;
- }
- case 0x14:
- {
- bytes++;
- int pixelId = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int spielerId = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- int pixelAnz = pixel->getEintragAnzahl();
- for( int i = 0; i < pixelAnz; i++ )
- {
- Pixel *p = pixel->z( i );
- if( p->getId() == pixelId )
- {
- if( spielerId >= 0 )
- {
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == spielerId )
- {
- s->addEp( p->getEp() );
- if( s->getSpielerNummer() == spielerNummer )
- shipGUI->update( s );
- break;
- }
- }
- }
- welt->removeObject( p );
- pixel->remove( i );
- break;
- }
- }
- goToPresence( presence );
- break;
- }
- case 0x15:
- {
- bytes++;
- int sNum = *(int *)bytes;
- bytes += 4;
- län -= 4;
- char skillId = *bytes;
- län--;
- goBackInTime( zeit );
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == sNum )
- s->useSkill( skillId );
- }
- goToPresence( presence );
- break;
- }
- case 0x16:
- {
- bytes++;
- int schuss = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int oId = *(int *)bytes;
- bytes += 4;
- län -= 4;
- float erf = *(float *)bytes;
- bytes += 4;
- län -= 4;
- int skillP = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- int sAnz = schüsse->getEintragAnzahl();
- for( int i = 0; i < sAnz; i++ )
- {
- Laser *tmp = schüsse->z( i );
- if( tmp && tmp->getId() == schuss )
- {
- if( sNum >= 0 )
- {
- double intens = 0;
- Spieler *attacker = 0;
- SpielObjekt *attacked = 0;
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == tmp->getSpieler() )
- attacker = s;
- }
- for( auto o = objekte->getIterator(); o; o++ )
- {
- if( o->getObjektId() == oId )
- attacked = o;
- }
- if( attacked && attacker )
- {
- intens = tmp->getIntensität( attacked->getSpeed() );
- attacked->nimmSchaden( intens, attacker ? attacker->getLevel() : 1 );
- if( tmp->getSpeed().getLengthSq() > 0 )
- attacked->impuls( tmp->getPosition() - tmp->getSpeed(), tmp->getSpeed() * 0.3f );
- attacked->calcDeadPlayerObject( schüsse->z( i ) );
- attacker->machSchaden( intens, attacked->getLevel(), attacked->doesShotAddEp() );
- if( attacker->getEp() != erf )
- chat->addNachricht( Text( "asynchrony detected ep difference: " ) += ( erf - attacker->getEp() ), 0xFFFF0000 );
- if( attacker->getSkillP() != skillP )
- chat->addNachricht( Text( "asynchrony detected skillPunkte difference: " ) += ( skillP - attacker->getSkillP() ), 0xFFFF0000 );
- bestenliste->updateSpieler( attacker );
- }
- }
- welt->removeObject( tmp );
- schüsse->remove( i );
- break;
- }
- }
- goToPresence( presence );
- if( sNum == spielerNummer )
- {
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( s );
- break;
- }
- }
- }
- break;
- }
- case 0x17:
- {
- bytes++;
- int oId = *(int *)bytes;
- bytes += 4;
- län -= 4;
- int killer = *(int *)bytes;
- län -= 4;
- goBackInTime( zeit );
- SpielObjekt *dead = 0;
- Spieler *kill = 0;
- for( auto s = spieler->getIterator(); s; s++ )
- {
- if( s->getSpielerNummer() == killer )
- kill = s;
- }
- for( auto o = objekte->getIterator(); o; o++ )
- {
- if( o->getObjektId() == oId )
- dead = o;
- }
- if( dead )
- {
- DeadPlayer *dp = dead->sterben();
- if( dp )
- {
- welt->addObject( dp->getThis() );
- deads->add( dp );
- }
- }
- if( kill )
- {
- kill->addKill( dead ? dead->getLevel() : 1, dead ? dead->doesShotAddEp() : 1 );
- kill->zTeam()->punkte++;
- bestenliste->updateTeam( kill->zTeam() );
- bestenliste->updateSpieler( kill );
- }
- goToPresence( presence );
- if( sNum == spielerNummer )
- {
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- {
- shipGUI->update( spieler->z( i ) );
- break;
- }
- }
- }
- break;
- }
- default:
-
- break;
- }
- if( län != 0 )
- {
-
- chat->addNachricht( "Es ist ein Fehler beim verarbeiten einer Nachricht aufgetreten.", 0xFFFF0000 );
- }
- n->setVerarbeitet();
- }
- for( int i = stkna; i > 0; i-- )
- {
- if( !stkn->z( 0 ) || !stkn->z( 0 )->istVerarbeitet() )
- break;
- stkna--;
- stkn->remove( 0 );
- }
- unlock();
- }
- bool SpielKlasse::tick( double zeit )
- {
- stknVerarbeitung();
- if( spielPause )
- {
- zeit = 0;
- return 1;
- }
- rZeit += zeit;
- while( TICK <= rZeit )
- {
- rZeit -= TICK;
- if( end )
- return 1;
- lock();
- if( spielZeit == -1 )
- save();
-
- int deadsCount = deads->getEintragAnzahl();
- for( int i = 0; i < deadsCount; i++ )
- {
- if( deads->z( i )->isFinished() )
- {
- welt->removeObject( deads->z( i ) );
- deads->remove( i-- );
- deadsCount--;
- }
- }
-
- tick();
- minimap->tick( TICK );
-
- Vertex tPos;
- Vertex speed;
- bool setKam = 0;
- for( int i = 0; i < spielerAnzahl; i++ )
- {
- if( spieler->z( i )->getSpielerNummer() == spielerNummer )
- shipGUI->update( spieler->z( i ) );
- if( spielerNummer == spieler->z( i )->getSpielerNummer() )
- {
- tPos = spieler->z( i )->getPosition();
- speed = spieler->z( i )->getSpeed();
- setKam = spieler->z( i )->istAmLeben();
- }
- }
- unlock();
- if( setKam )
- {
- if( !this->setKam || isnan( kam->getWorldPosition().x ) || isnan( kam->getWorldPosition().y ) )
- kam->lookAtWorldPos( tPos );
- Vertex str = ( tPos - kam->getWorldPosition() );
- if( ( tPos + welt->getWorldInfo().size - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + welt->getWorldInfo().size - kam->getWorldPosition() );
- if( ( tPos - welt->getWorldInfo().size - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos - welt->getWorldInfo().size - kam->getWorldPosition() );
- if( ( tPos + Punkt( welt->getWorldInfo().size.x, 0 ) - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + Punkt( welt->getWorldInfo().size.x, 0 ) - kam->getWorldPosition() );
- if( ( tPos + Punkt( -welt->getWorldInfo().size.x, 0 ) - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + Punkt( -welt->getWorldInfo().size.x, 0 ) - kam->getWorldPosition() );
- if( ( tPos + Punkt( 0, welt->getWorldInfo().size.y ) - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + Punkt( 0, welt->getWorldInfo().size.y ) - kam->getWorldPosition() );
- if( ( tPos + Punkt( 0, -welt->getWorldInfo().size.y ) - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + Punkt( 0, -welt->getWorldInfo().size.y ) - kam->getWorldPosition() );
- if( ( tPos + Punkt( welt->getWorldInfo().size.x, -welt->getWorldInfo().size.y ) - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + Punkt( welt->getWorldInfo().size.x, -welt->getWorldInfo().size.y ) - kam->getWorldPosition() );
- if( ( tPos + Punkt( -welt->getWorldInfo().size.x, welt->getWorldInfo().size.y ) - kam->getWorldPosition() ).getLengthSq() < str.getLengthSq() )
- str = ( tPos + Punkt( -welt->getWorldInfo().size.x, welt->getWorldInfo().size.y ) - kam->getWorldPosition() );
- float faktor = str.getLength() / 200.f;
- if( faktor > 1.f )
- faktor = 1.f;
- kam->lookAtWorldPos( kam->getWorldPosition() + speed * faktor * (float)TICK );
- kam->lookAtWorldPos( kam->getWorldPosition() + str * faktor * 0.1f * (float)TICK );
- }
- this->setKam = setKam;
- chat->tick( !zeit ? 0.05 : zeit );
- if( shipGUI )
- shipGUI->tick( !zeit ? 0.05 : zeit );
- }
- return 1;
- }
- void SpielKlasse::render( Bild & zRObj )
- {
- if( !rendern )
- return;
- lock();
- kam->lookAtWorldArea( zRObj.getBreite(), zRObj.getHeight() );
- kam->setSize( zRObj.getSize() );
- kam->render( zRObj );
- minimap->setPosition( zRObj.getSize() - Punkt( 210, 210 ) );
- minimap->lookAtWorldPos( welt->getWorldInfo().size.x / 2, welt->getWorldInfo().size.y / 2 );
- minimap->lookAtWorldArea( welt->getWorldInfo().size.x, welt->getWorldInfo().size.y );
- minimap->render( zRObj );
- chat->render( zRObj );
- if( bestenliste )
- bestenliste->render( zRObj );
- if( shipGUI )
- shipGUI->render( zRObj );
- if( end )
- end->render( zRObj );
- unlock();
- }
- int SpielKlasse::läuft() const
- {
- if( !rendern )
- return 3;
- if( !end )
- return 2;
- if( end && !end->getWeiter() )
- return 1;
- if( end && end->getWeiter() )
- return 0;
- return 0;
- }
- SpielV *SpielKlasse::getThis()
- {
- ref++;
- return this;
- }
- SpielV *SpielKlasse::release()
- {
- ref--;
- if( !ref )
- delete this;
- return 0;
- }
|