Changeset 6959 in orxonox.OLD for trunk/src/world_entities
- Timestamp:
- Feb 1, 2006, 4:40:34 PM (19 years ago)
- Location:
- trunk/src/world_entities
- Files:
-
- 7 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/world_entities/planet.h
r6634 r6959 22 22 virtual ~Planet(); 23 23 24 v oid loadParams(const TiXmlElement* root);24 virtual void loadParams(const TiXmlElement* root); 25 25 26 26 void setSize(float size); -
trunk/src/world_entities/playable.cc
r6871 r6959 28 28 29 29 30 #include "dot_emitter.h" 31 #include "sprite_particles.h" 32 33 30 34 Playable::Playable() 31 35 { … … 43 47 44 48 this->setSynchronized(true); 49 50 this->score = 0; 51 this->oldScore = 0; 52 53 54 this->emitter = new DotEmitter(100, 5, M_2_PI); 55 this->emitter->setParent(this); 56 this->emitter->setSpread(M_PI, M_PI); 57 this->emitter->setEmissionRate(300.0); 58 this->emitter->setEmissionVelocity(50.0); 59 60 this->explosionParticles = new SpriteParticles(1000); 61 this->explosionParticles->setName("LaserExplosionParticles"); 62 this->explosionParticles->setLifeSpan(.5, .3); 63 this->explosionParticles->setRadius(0.0, 10.0); 64 this->explosionParticles->setRadius(.5, 6.0); 65 this->explosionParticles->setRadius(1.0, 3.0); 66 this->explosionParticles->setColor(0.0, 1,1,0,.9); 67 this->explosionParticles->setColor(0.5, .8,.8,0,.5); 68 this->explosionParticles->setColor(1.0, .8,.8,.7,.0); 45 69 } 46 70 … … 101 125 void Playable::collidesWith(WorldEntity* entity, const Vector& location) 102 126 { 103 if (entity->isA(CL_PROJECTILE) )127 if (entity->isA(CL_PROJECTILE) && !State::isOnline() ) 104 128 this->decreaseHealth(entity->getHealth()); 105 129 106 130 // EXTREME HACK 107 131 if (this->getHealth() == 0.0f) 108 this->deactivateNode(); 132 { 133 //this->deactivateNode(); 134 this->emitter->setSystem(explosionParticles); 135 this->setAbsCoor(0, 0, 0); 136 //this->setAbsDir(Vector(1,0,0), 0); 137 this->emitter->setSystem(NULL); 138 } 109 139 } 110 140 … … 248 278 } 249 279 280 #define DATA_FLAGS 1 281 #define DATA_SCORE 2 282 250 283 #define FLAGS_bFire 1 251 284 … … 281 314 bool Playable::needsReadSync( ) 282 315 { 316 //if ( score != oldScore ) 317 // return true; 318 283 319 byte flags = 0; 284 320 -
trunk/src/world_entities/playable.h
r6871 r6959 15 15 16 16 class Weapon; 17 17 class DotEmitter; 18 18 class Player; 19 class SpriteParticles; 19 20 20 21 //! Basic controllable WorldEntity … … 58 59 int readSync(byte* data, int maxLength ); 59 60 bool needsReadSync(); 61 62 inline void setScore( int score ) { this->score = score; } 63 inline int getScore() { return this->score; } 60 64 61 65 protected: … … 73 77 bool bFire; //!< If the Ship is firing. 74 78 int oldFlags; //!< Used for synchronisation 79 80 int score; 81 int oldScore; 75 82 83 //HACK: explosion emitter 84 DotEmitter* emitter; 85 SpriteParticles* explosionParticles; 76 86 }; 77 87 -
trunk/src/world_entities/space_ships/space_ship.cc
r6947 r6959 96 96 { 97 97 //this->loadModel("models/ships/reap_#.obj"); 98 this->loadModel( "models/ships/fighter.obj" ); 98 ///HACK this is only for network multiplayer games. 99 if( this->getOwner()%2 == 0) 100 { 101 this->loadModel("models/ships/reap_#.obj"); 102 this->toList(OM_GROUP_00); 103 } 104 else 105 { 106 this->loadModel( "models/ships/fighter.obj" ); 107 this->toList(OM_GROUP_01); 108 } 99 109 } 100 110 … … 275 285 { 276 286 Playable::collidesWith(entity, location); 287 288 277 289 if (entity->isA(CL_TURRET_POWER_UP) && entity != ref) 278 290 { 279 291 this->ADDWEAPON(); 280 292 ref = entity; 281 } 293 } 294 295 if( entity->isA(CL_PROJECTILE) && entity != ref) 296 { 297 if ( isServer() ) 298 { 299 networkCollisionList.push_back( entity->getHealth() ); 300 doCollideNetwork( entity->getHealth() ); 301 } 302 } 282 303 // PRINTF(3)("collision %s vs %s @ (%f,%f,%f)\n", this->getClassName(), entity->getClassName(), location.x, location.y, location.z); 283 304 } … … 320 341 321 342 // spaceship controlled movement 322 this->calculateVelocity(time); 343 if (this->getOwner() == this->getHostID()) 344 this->calculateVelocity(time); 345 323 346 324 347 Vector move = velocity*time; … … 450 473 } 451 474 452 velocity += accel ;475 velocity += accel*time*10; 453 476 //rot.normalize(); 454 477 //this->setRelDirSoft(Quaternion(rotVal, rot), 5); … … 526 549 #define DATA_velocity 5 527 550 #define DATA_playables 6 551 #define DATA_collision 7 528 552 529 553 int SpaceShip::writeBytes( const byte * data, int length, int sender ) … … 561 585 bRollL = (flags & MASK_bRollL) != 0; 562 586 bRollR = (flags & MASK_bRollR) != 0; 563 587 564 588 } 565 589 else … … 603 627 SYNCHELP_READ_FLOAT( velocity.y, NWT_SS_VELY ); 604 628 SYNCHELP_READ_FLOAT( velocity.z, NWT_SS_VELZ ); 605 } 629 } 606 630 else 607 631 assert(false); 608 632 609 633 continue; 610 634 } 611 635 612 636 if ( b == DATA_playables ) 613 637 { … … 619 643 assert(false); 620 644 } 645 646 if ( b == DATA_collision ) 647 { 648 int n; 649 float energy; 650 SYNCHELP_READ_INT( n, NWT_SS_CO_N ); 651 652 for ( int i = 0; i<n; i++ ) 653 { 654 SYNCHELP_READ_FLOAT( energy, NWT_SS_CO_CLID ); 655 doCollideNetwork( energy ); 656 } 657 } 621 658 } 622 659 … … 651 688 } 652 689 653 *reciever = -this->getOwner(); 690 *reciever = 0 - this->getOwner(); 691 //TODO: implement with SYNCHELP_WRITE_SENT() 654 692 bool sentSomething = false; 655 693 656 if ( ( this->getHostID()==0 || this->getOwner() == this->getHostID() ) && PNode::needsReadSync() ) 657 { 694 if ( PNode::needsReadSync() && ( this->getHostID()==0 || this->getOwner() == this->getHostID() ) ) 695 { 696 PRINTF(0)("sending PNode::readSync\n"); 658 697 SYNCHELP_WRITE_BYTE( DATA_sync, NWT_SS_B ); 659 698 SYNCHELP_WRITE_FKT( PNode::readSync, NWT_SS_PN_SYNC ); 699 sentSomething = true; 660 700 } 661 701 … … 683 723 { 684 724 oldMask = mask; 725 PRINTF(0)("sending mask\n"); 685 726 sentSomething = true; 686 727 SYNCHELP_WRITE_BYTE( DATA_flags, NWT_SS_B ); … … 705 746 } 706 747 #define __OFFSET_VEL 0.05 707 if ( fabs( oldVelocity.x - velocity.x ) > __OFFSET_VEL*velocity.x || 708 fabs( oldVelocity.y - velocity.y ) > __OFFSET_VEL*velocity.y || 709 fabs( oldVelocity.z - velocity.z ) > __OFFSET_VEL*velocity.z ) 710 { 711 oldVelocity = velocity; 712 //PRINTF(0)("SENDING velocity\n"); 713 //SYNCHELP_WRITE_BYTE( DATA_velocity, NWT_SS_B ); 714 //SYNCHELP_WRITE_FLOAT( velocity.x, NWT_SS_VELX ); 715 //SYNCHELP_WRITE_FLOAT( velocity.y, NWT_SS_VELY ); 716 //SYNCHELP_WRITE_FLOAT( velocity.z, NWT_SS_VELZ ); 717 } 718 748 if ( fabs( oldVelocity.x - velocity.x ) > __OFFSET_VEL*fabs(oldVelocity.x)+0.1 || 749 fabs( oldVelocity.y - velocity.y ) > __OFFSET_VEL*fabs(oldVelocity.y)+0.1 || 750 fabs( oldVelocity.z - velocity.z ) > __OFFSET_VEL*fabs(oldVelocity.z)+0.1 ) 751 { 752 oldVelocity.x = velocity.x; 753 oldVelocity.y = velocity.y; 754 oldVelocity.z = velocity.z; 755 PRINTF(0)("SENDING velocity\n"); 756 sentSomething = true; 757 SYNCHELP_WRITE_BYTE( DATA_velocity, NWT_SS_B ); 758 SYNCHELP_WRITE_FLOAT( velocity.x, NWT_SS_VELX ); 759 SYNCHELP_WRITE_FLOAT( velocity.y, NWT_SS_VELY ); 760 SYNCHELP_WRITE_FLOAT( velocity.z, NWT_SS_VELZ ); 761 } 762 719 763 if ( Playable::needsReadSync() ) 720 764 { 721 765 sentSomething = true; 766 PRINTF(0)("SYNCHELP_WRITE_FKT( Playable::readSync, NWT_SS_PL_SYNC )\n"); 722 767 SYNCHELP_WRITE_BYTE( DATA_playables, NWT_SS_B ); 723 768 SYNCHELP_WRITE_FKT( Playable::readSync, NWT_SS_PL_SYNC ); … … 725 770 726 771 } 727 772 728 773 if ( !sentSomething ) 729 reciever = 0; 774 { 775 *reciever = 0; 776 777 if ( networkCollisionList.size()>0 ) 778 { 779 SYNCHELP_WRITE_BYTE( DATA_collision, NWT_SS_B ); 780 781 SYNCHELP_WRITE_INT( networkCollisionList.size(), NWT_SS_CO_N ); 782 783 for ( std::list<float>::iterator it = networkCollisionList.begin(); it!=networkCollisionList.end(); it++ ) 784 { 785 SYNCHELP_WRITE_FLOAT( *it, NWT_SS_CO_CLID ); 786 } 787 788 networkCollisionList.clear(); 789 } 790 } 730 791 731 792 return SYNCHELP_WRITE_N; 732 793 } 733 794 734 795 void SpaceShip::doCollideNetwork( float energy ) 796 { 797 this->decreaseHealth( energy ); 798 } 799 800 801 -
trunk/src/world_entities/space_ships/space_ship.h
r6868 r6959 47 47 void calculateVelocity(float time); 48 48 49 void doCollideNetwork( float energy ); 50 49 51 // !! temporary !! 50 52 void ADDWEAPON(); … … 84 86 ParticleEmitter* burstEmitter; 85 87 ParticleSystem* burstSystem; 88 89 std::list<float> networkCollisionList; 86 90 }; 87 91 -
trunk/src/world_entities/world_entity.cc
r6815 r6959 280 280 281 281 /** 282 * this method is called by the world if the WorldEntity leaves valid gamespace 283 * 284 * For free entities this means it left the Track boundaries. With bound entities it means its Location adresses a 285 * place that is not in the world anymore. In both cases you might have to take extreme measures (a.k.a. call destroy). 286 * 287 * NOT YET IMPLEMENTED 288 */ 289 void WorldEntity::leftWorld () 282 * this method is called by the world if the WorldEntity leaves the game 283 */ 284 void WorldEntity::leaveWorld () 290 285 {} 291 286 -
trunk/src/world_entities/world_entity.h
r6700 r6959 54 54 55 55 virtual void postSpawn (); 56 virtual void le ftWorld ();56 virtual void leaveWorld (); 57 57 58 58 virtual void tick (float time);
Note: See TracChangeset
for help on using the changeset viewer.