Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/world_entities/creatures/fps_player_minimal.cc @ 10528

Last change on this file since 10528 was 10340, checked in by patrick, 18 years ago

got gravity and no banking anymore

File size: 11.4 KB
Line 
1/*
2   orxonox - the future of 3D-vertical-scrollers
3
4   Copyright (C) 2004 orx
5
6   This program is free software; you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation; either version 2, or (at your option)
9   any later version.
10
11### File Specific:
12   main-programmer: Patrick Boenzli
13   co-programmer: ...
14
15*/
16
17#include "fps_player.h"
18
19#include "interactive_model.h"
20#include "state.h"
21
22#include "src/lib/util/loading/factory.h"
23
24#include "md2/md2Model.h"
25
26#include "weapons/weapon_manager.h"
27#include "weapons/test_gun.h"
28#include "weapons/turret.h"
29#include "weapons/cannon.h"
30#include "weapons/fps_sniper_rifle.h"
31#include "weapons/aiming_system.h"
32
33#include "aabb.h"
34#include "bsp_entity.h"
35
36#include "key_mapper.h"
37
38#include "debug.h"
39
40#include "shared_network_data.h"
41
42
43
44ObjectListDefinition(FPSPlayerMinimal);
45CREATE_FACTORY(FPSPlayerMinimal);
46
47#include "script_class.h"
48CREATE_SCRIPTABLE_CLASS(FPSPlayerMinimal,
49                        addMethod("setAbsCoor", Executor3<PNode, lua_State*,float,float,float>(&PNode::setAbsCoor))
50                            ->addMethod("getAbsCoorX", Executor0ret<PNode, lua_State*, float>(&PNode::getAbsCoorX))
51                            ->addMethod("getAbsCoorY", Executor0ret<PNode, lua_State*, float>(&PNode::getAbsCoorY))
52                            ->addMethod("getAbsCoorZ", Executor0ret<PNode, lua_State*, float>(&PNode::getAbsCoorZ))
53                       );
54
55
56/**
57 *  destructs the FPSPlayerMinimal, deletes alocated memory
58 */
59FPSPlayerMinimal::~FPSPlayerMinimal ()
60{
61  this->setPlayer(NULL);
62
63  if( this->aimingSystem)
64    delete this->aimingSystem;
65}
66
67
68/**
69 *  creates a new FPSPlayerMinimal from Xml Data
70 * @param root the xml element containing FPSPlayerMinimal data
71 *
72 */
73FPSPlayerMinimal::FPSPlayerMinimal(const TiXmlElement* root)
74{
75  this->init();
76
77  if (root != NULL)
78    this->loadParams(root);
79
80}
81
82
83/**
84 * initializes a FPSPlayerMinimal
85 */
86void FPSPlayerMinimal::init()
87{
88  this->registerObject(this, FPSPlayerMinimal::_objectList);
89
90  this->bLeft = false;
91  this->bRight = false;
92  this->bForward = false;
93  this->bBackward = false;
94  this->bJump = false;
95  this->bPosBut = false;
96  this->bFire = false;
97
98  this->xMouse = 0.0f;
99  this->yMouse = 0.0f;
100
101  this->setHealthMax(100);
102  this->setHealth(80);
103
104  this->fallVelocity = 0.0f;
105  this->jumpForce = 0.0f;
106
107  this->cameraNode.setParent(this);
108
109  this->attitude = this->getAbsDir().getAttitude();
110  this->heading = this->getAbsDir().getHeading();
111
112  //add events to the eventlist
113  registerEvent(KeyMapper::PEV_FORWARD);
114  registerEvent(KeyMapper::PEV_BACKWARD);
115  registerEvent(KeyMapper::PEV_LEFT);
116  registerEvent(KeyMapper::PEV_RIGHT);
117  registerEvent(KeyMapper::PEV_FIRE1);
118  registerEvent(KeyMapper::PEV_JUMP);
119  registerEvent(EV_MOUSE_MOTION);
120
121  this->aimingSystem = NULL;
122
123  // weapon manager for the fps
124  dynamic_cast<Element2D*>(this->getWeaponManager().getFixedTarget())->setVisibility( false);
125
126  if( State::isOnline())
127  {
128    Weapon* wpRight = new FPSSniperRifle(0);
129    wpRight->setName("testGun Right");
130    this->addWeapon(wpRight,1, 0);
131
132    this->aimingSystem = new AimingSystem(this);
133    wpRight->addChild(this->aimingSystem);
134
135    this->toList( OM_PLAYERS );
136  }
137
138
139  this->getWeaponManager().changeWeaponConfig(1);
140  this->getWeaponManager().setSlotCount(2);
141  this->getWeaponManager().setSlotDirection(0, Quaternion(M_PI_4*-0.55f, Vector(0,0,1)));
142  this->getWeaponManager().setSlotCapability(0, WTYPE_ALLDIRS | WTYPE_DIRECTIONAL);
143  this->getWeaponManager().setSlotDirection(1, Quaternion(M_PI_4*.5, Vector(1,0,0)));
144  this->getWeaponManager().setSlotPosition(0, Vector(1.5, -0.7, 1.1));
145  this->getWeaponManager().setSlotPosition(1, Vector(5.0, 0.0, 0.0));
146
147  this->getWeaponManager().setParentNode(&this->cameraNode);
148  this->cameraNode.addNodeFlags(PNODE_PROHIBIT_CHILD_DELETE);
149
150  this->getWeaponManager().getFixedTarget()->setParent(&this->cameraNode);
151  this->getWeaponManager().getFixedTarget()->setRelCoor(1000,0,0);
152
153
154  // network registration
155  registerVar( new SynchronizeableBool( &bLeft, &bLeft, "bLeft", PERMISSION_OWNER ) );
156  registerVar( new SynchronizeableBool( &bRight, &bRight, "bRight", PERMISSION_OWNER ) );
157  registerVar( new SynchronizeableBool( &bForward, &bForward, "bForward", PERMISSION_OWNER ) );
158  registerVar( new SynchronizeableBool( &bBackward, &bBackward, "bBackward", PERMISSION_OWNER ) );
159  registerVar( new SynchronizeableBool( &bJump, &bJump, "bJump", PERMISSION_OWNER ) );
160  registerVar( new SynchronizeableFloat( &heading, &heading, "heading", PERMISSION_OWNER ) );
161  registerVar( new SynchronizeableFloat( &attitude, &attitude, "attitude", PERMISSION_OWNER ) );
162
163    //subscribe to collision reaction
164  this->subscribeReaction(CoRe::CREngine::CR_PHYSICS_FULL_WALK, BspEntity::staticClassID());
165
166  this->initWeapon = false;
167  this->damageTicker = 0.0f;
168
169}
170
171
172/**
173 * loads the Settings of a FPSPlayerMinimal from an XML-element.
174 * @param root the XML-element to load the Spaceship's properties from
175 */
176void FPSPlayerMinimal::loadParams(const TiXmlElement* root)
177{
178  Playable::loadParams(root);
179}
180
181
182void FPSPlayerMinimal::setPlayDirection(const Quaternion& quat, float speed)
183{
184  this->attitude = this->getAbsDir().getAttitude();
185  this->heading = this->getAbsDir().getHeading();
186}
187
188
189void FPSPlayerMinimal::reset()
190{
191  this->bLeft = false;
192  this->bRight = false;
193  this->bForward = false;
194  this->bBackward = false;
195  this->xMouse = 0.0f;
196  this->yMouse = 0.0f;
197
198  this->setHealth(80);
199}
200
201
202void FPSPlayerMinimal::enter()
203{
204  dynamic_cast<Element2D*>(this->getWeaponManager().getFixedTarget())->setVisibility( true );
205
206  State::getCameraNode()->setParentSoft(&this->cameraNode);
207  State::getCameraTargetNode()->setParentSoft(&this->cameraNode);
208
209  this->getWeaponManager().getFixedTarget()->setParent(State::getCameraTargetNode());
210  this->getWeaponManager().getFixedTarget()->setRelCoor(0,0,0);
211
212  if ( !State::isOnline() )
213  {
214    this->respawn();
215  }
216}
217
218void FPSPlayerMinimal::leave()
219{
220  dynamic_cast<Element2D*>(this->getWeaponManager().getFixedTarget())->setVisibility( false);
221  this->detachCamera();
222}
223
224
225
226/**
227 *  the function called for each passing timeSnap
228 * @param time The timespan passed since last update
229 */
230void FPSPlayerMinimal::tick (float time)
231{
232
233  if ( !this->initWeapon )
234  {
235    this->initWeapon = true;
236
237    this->cameraNode.setParentMode(PNODE_ROTATE_AND_MOVE);
238
239    this->getWeaponManager().getParentNode()->setParentMode(PNODE_ROTATE_AND_MOVE);
240    this->getWeaponManager().getFixedTarget()->setParent(&this->cameraNode);
241    this->getWeaponManager().getFixedTarget()->setParentMode(PNODE_ROTATE_AND_MOVE);
242
243
244//     if( this->aimingSystem != NULL)
245//     {
246//       this->aimingSystem->toList(OM_GROUP_01);
247//       this->aimingSystem->setParent(&this->cameraNode);
248//   //     this->aimingSystem->setParentMode(PNODE_ROTATE_AND_MOVE);
249//       this->aimingSystem->setRelDir(Quaternion(M_PI_4*-0.58f, Vector(0,0,1)));
250//       this->aimingSystem->setRelCoor(0, -1, -1);
251//     }
252
253
254    AABB* box = this->getModelAABB();
255    if( box != NULL)
256    {
257      float f = 1.0;
258      this->cameraNode.setRelCoor(0, box->halfLength[1] * f, 0);
259//       this->cameraNode.setRelCoor(10, box->halfLength[1] * f, 0);
260
261      float v = 0.1f;
262      this->getWeaponManager().setSlotPosition(0, Vector(-8.0, box->halfLength[1] * v, 1.1));
263      this->getWeaponManager().setSlotPosition(1, Vector(5.0, box->halfLength[1] * v, 0.0));
264    }
265  }
266
267
268  this->getWeaponManager().tick(time);
269  if( this->bFire)
270  {
271    this->getWeaponManager().fire();
272  }
273
274
275  //dealing damage
276  if ( State::isOnline() && (SharedNetworkData::getInstance()->isMasterServer() /*|| SharedNetworkData::getInstance()->isProxyServerActive()*/))
277  {
278    this->damageTicker -= time;
279
280    if ( this->damageTicker <= 0.0f && this->beFire() )
281    {
282      this->damageTicker = 0.25;
283
284      WorldEntity * victim = aimingSystem->getNearestTarget();
285
286      if ( victim )
287      {
288        PRINTF(0)("FIRE: hit %s\n", victim->getClassCName());
289        victim->hit( 20, this );
290      }
291      else
292      {
293        PRINTF(0)("FIRE: nothing hit\n");
294      }
295    }
296  }
297
298
299  if( ( xMouse != 0 || yMouse != 0 ) && (this->getOwner() == SharedNetworkData::getInstance()->getHostID() || !State::isOnline() ) )
300  {
301    xMouse *= time ;
302    yMouse *= time ;
303
304    heading -= xMouse;
305    attitude-= yMouse;
306
307
308    if ( attitude > 1.95 )
309      attitude = 1.95;
310    else if ( attitude < -1.07 )
311      attitude = -1.07;
312
313    xMouse = yMouse = 0;
314  }
315
316  this->setAbsDir(Quaternion(heading, Vector(0,1,0)));
317  this->cameraNode.setRelDir(Quaternion( attitude, Vector( 0, 0, 1 ) ));
318
319  Vector velocity;
320
321  if ( this->bForward )
322  {
323    velocity += this->getAbsDirX();
324  }
325
326  if ( this->bBackward )
327  {
328    velocity -= this->getAbsDirX();
329  }
330
331  if ( this->bRight )
332  {
333    velocity += this->getAbsDirZ();
334  }
335
336  if ( this->bLeft )
337  {
338    velocity -= this->getAbsDirZ();
339  }
340
341
342  velocity *= 100;
343
344  if( this->getModel( 0) != NULL && this->getModel(0)->isA(InteractiveModel::staticClassID()))
345  {
346    if( this->bJump)
347    {
348      if( this->jumpForce < 1.0f)
349      {
350        this->jumpForce = 300.0f;
351
352        if( ((InteractiveModel*)this->getModel(0))->getAnimation() != JUMP)
353          ((InteractiveModel*)this->getModel(0))->setAnimation(JUMP);
354      }
355    }
356    else if(velocity.len() != 0.0f)
357    {
358      if( ((InteractiveModel*)this->getModel(0))->getAnimation() != RUN)
359        ((InteractiveModel*)this->getModel(0))->setAnimation(RUN);
360    }
361    else
362    {
363      if( ((InteractiveModel*)this->getModel(0))->getAnimation() != STAND)
364        ((InteractiveModel*)this->getModel(0))->setAnimation(STAND);
365    }
366  }
367
368
369  velocity.y += this->jumpForce;
370  if( this->jumpForce > 1.0f)
371    this->jumpForce *= 0.9f;
372
373
374  // physical falling of the player
375  if( /*FIXME for testing*/ false && !this->isOnGround())
376  {
377    this->fallVelocity += 300.0f * time;
378    velocity -= Vector(0.0, 1.0, 0.0) * this->fallVelocity;
379
380//     PRINTF(0)("vel %f\n", this->fallVelocity);
381  }
382  else
383  {
384    this->fallVelocity = 0.0f;
385  }
386
387  this->shiftCoor( velocity*time );
388
389
390
391
392
393
394
395  if( likely(this->getModel(0) != NULL) && this->getModel(0)->isA(InteractiveModel::staticClassID()))
396  {
397    ((InteractiveModel*)this->getModel(0))->tick(time);
398  }
399
400  this->setOnGround(false);
401  if( this->aimingSystem != NULL)
402    this->aimingSystem->flushList();
403}
404
405
406
407/**
408 *  draws the MD2Creature after transforming it.
409 */
410void FPSPlayerMinimal::draw () const
411{
412  // only draw if this entity is not the player since the player nevers sees himself
413  if( this->getCurrentPlayer() == NULL)
414    WorldEntity::draw();
415}
416
417
418
419/**
420 * process
421 */
422void FPSPlayerMinimal::process(const Event &event)
423{
424  Playable::process(event);
425
426  if( event.type == KeyMapper::PEV_LEFT)
427    this->bLeft = event.bPressed;
428  else if( event.type == KeyMapper::PEV_RIGHT)
429    this->bRight = event.bPressed;
430  else if( event.type == KeyMapper::PEV_FORWARD)
431    this->bForward = event.bPressed; //this->shiftCoor(0,.1,0);
432  else if( event.type == KeyMapper::PEV_BACKWARD)
433    this->bBackward = event.bPressed; //this->shiftCoor(0,-.1,0);
434  else if( event.type == EV_MOUSE_MOTION)
435  {
436    this->xMouse += event.xRel;
437    this->yMouse += event.yRel;
438  }
439  else if( event.type == KeyMapper::PEV_JUMP)
440  {
441    this->bJump = event.bPressed;
442  }
443  else if( event.type == KeyMapper::PEV_FIRE1)
444  {
445    this->bFire = event.bPressed;
446  }
447}
448
449
450void FPSPlayerMinimal::respawn( )
451{
452  if( State::isOnline())
453    toList( OM_PLAYERS );
454
455  this->damageTicker = 0.0f;
456
457  Playable::respawn();
458}
459
460
461void FPSPlayerMinimal::destroy( WorldEntity* killer )
462{
463  Playable::destroy( killer );
464
465  toList( OM_DEAD );
466}
467
Note: See TracBrowser for help on using the repository browser.