Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/world_entities/player.cc @ 9177

Last change on this file since 9177 was 9062, checked in by patrick, 18 years ago

merged branche single_player_map back to trunk

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
[6440]37  PRINTF(4)("PLAYER INIT\n");
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.