Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/proxy/src/world_entities/player.cc @ 9569

Last change on this file since 9569 was 9537, checked in by patrick, 18 years ago

found the bug. there is need for another control center for proxies to signal new clients and leavings. This is a central part of the proxy synchronization process

File size: 2.7 KB
RevLine 
[4592]1/*
[3471]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:
[5915]12   main-programmer: Silvan Nellen
13   co-programmer: Benjamin Knecht
[3471]14*/
15
16#include "player.h"
[5915]17#include "playable.h"
[3596]18
[4404]19#include "event_handler.h"
[4389]20
[6222]21
22#include "class_list.h"
23#include "state.h"
[6438]24#include "util/hud.h"
[6222]25
[8362]26#include "debug.h"
[3471]27
[4010]28
[3471]29/**
[4885]30 * creates a new Player
[3471]31*/
[4762]32Player::Player()
[3471]33{
[9061]34  //  this->setRelDir(Quaternion(M_PI, Vector(1,0,0)));
[6440]35  this->setClassID(CL_PLAYER, "Player");
[6222]36
[9537]37  PRINTF(4)("PLAYER INIT\n");
[6440]38
[6985]39  this->playable = NULL;
[9019]40  this->_hud.setVisibility(true);
[6440]41
[7868]42  this->subscribeEvent(ES_GAME, KeyMapper::PEV_CHANGE_SHIP);
[3471]43}
44
[4975]45
[4010]46/**
[4975]47 *  destructs the player, deletes alocated memory
48 */
49Player::~Player ()
50{
[6986]51  this->setPlayable(NULL);
[4780]52}
53
54
[6985]55bool Player::setPlayable(Playable* playable)
[4780]56{
[6986]57  if (this->playable == playable)
58    return false;
59
60  // get out of the current Playable
61  if (this->playable != NULL)
[5435]62  {
[6987]63    PRINTF(4)("Player gets ejected from Playable\n");
[9019]64    this->_hud.setEnergyWidget(NULL);
65    this->_hud.setWeaponManager(NULL);
[6986]66
67    Playable* ejectedPlayable = this->playable;
68
69    this->playable = NULL;
70    ejectedPlayable->setPlayer(NULL);
71  }
72
73  if (playable != NULL)
74  {
[6987]75    PRINTF(4)("Enter new Playable\n");
[9061]76    this->playable = playable;
[9062]77    this->_hud.setEnergyWidget(this->playable->getHealthWidget());
78    this->_hud.setWeaponManager(&this->playable->getWeaponManager());
[6986]79
[9061]80    this->playable->setPlayer(this);
81    return true;
[5751]82  }
[8316]83
[8147]84  if ( playable == NULL )
85    this->playable = NULL;
[6986]86
87  return true;
[3471]88}
[3584]89
[6986]90bool Player::eject()
[9061]91{
92  return this->setPlayable(NULL);
93}
[3584]94
[6986]95
[6443]96 void Player::weaponConfigChanged()
97 {
[9019]98   this->_hud.updateWeaponManager();
[6443]99 }
100
[6438]101
[9061]102void Player::enterNewPlayable()
103{
104  /// FIXME this should be in the ObjectManager
105  const std::list<BaseObject*>* objectList = ClassList::getList(CL_PLAYABLE);
106  if (objectList != NULL)
107  {
108    std::list<BaseObject*>::const_iterator node;
109    for (node = objectList->begin(); node != objectList->end(); node++)
110      if (this->playable != (*node) &&
111          (dynamic_cast<PNode*>(*node)->getAbsCoor() - this->playable->getAbsCoor()).len() < (dynamic_cast<Playable*>(*node)->getEnterRadius()))
112      {
[6222]113
[9061]114        this->setPlayable(dynamic_cast<Playable*>(*node));
[6222]115
[9061]116        break;
117      }
118  }
119}
[5751]120
[9061]121
122void Player::process(const Event &event)
123{
124  if (event.type == KeyMapper::PEV_CHANGE_SHIP && event.bPressed)
125  {
126    this->enterNewPlayable();
127  }
128
129  if (likely(this->playable != NULL))
130    this->playable->process(event);
131}
132
Note: See TracBrowser for help on using the repository browser.