Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/world_entities/playable.h @ 7398

Last change on this file since 7398 was 7351, checked in by bensch, 19 years ago

orxonox/trunk: the cheat is now a Static function

File size: 3.8 KB
Line 
1
2/*!
3 * @file playable.h
4 * Interface for a basic controllable WorldEntity
5 */
6#ifndef _PLAYABLE_H
7#define _PLAYABLE_H
8
9#include "world_entity.h"
10#include "extendable.h"
11#include "event.h"
12#include <vector>
13
14#include "world_entities/weapons/weapon_manager.h"
15
16class Weapon;
17class DotEmitter;
18class Player;
19class SpriteParticles;
20class Explosion;
21
22//! Basic controllable WorldEntity
23/**
24 *
25 */
26class Playable : public WorldEntity, public Extendable
27{
28public:
29  //! Defines the Playmode of an Entity.
30  typedef enum {
31    Vertical         = 1,       //!< Vertical (seen from left or right/move in x-z)
32    Horizontal       = 2,       //!< Horizontal (seet from the top/move in x-y)
33    FromBehind       = 4,       //!< Seen from behind (move in z-y)
34    Full3D           = 8,       //!< Full featured 3D-mode. (move in all directions x-y-z)
35  } Playmode;
36
37
38public:
39  virtual ~Playable();
40
41  virtual void loadParams(const TiXmlElement* root);
42
43  // Weapon and Pickups
44  virtual bool pickup(PowerUp* powerUp);
45  bool addWeapon(Weapon* weapon, int configID = -1, int slotID = -1);
46  void removeWeapon(Weapon* weapon);
47  void nextWeaponConfig();
48  void previousWeaponConfig();
49  inline WeaponManager& getWeaponManager() { return this->weaponMan; };
50  void weaponConfigChanged();
51  static void addSomeWeapons_CHEAT();
52
53
54  // Player Settup
55  bool setPlayer(Player* player);
56  Player* getCurrentPlayer() const { return this->currentPlayer; };
57  /** @return a List of Events in PEV_* sytle */
58  inline const std::vector<int>& getEventList() { return this->events; };
59
60  // Camera and Playmode
61  void attachCamera();
62  void detachCamera();
63  void setCameraMode(unsigned int cameraMode = 0);
64  bool playmodeSupported(Playable::Playmode playmode) const { return this->supportedPlaymodes & playmode; };
65  bool setPlaymode(Playable::Playmode playmode);
66  Playable::Playmode getPlaymode() const { return this->playmode; };
67  virtual void setPlayDirection(const Quaternion& rot, float speed = 0.0f) = 0;
68  void setPlayDirection(float angle, float dirX, float dirY, float dirZ, float speed = 0.0f);
69
70  inline void setScore( int score ) { this->score = score; }
71  inline int  getScore() { return this->score; }
72
73
74  // WorldEntity Extensions
75  virtual void die();
76  virtual void respawn();
77  virtual void collidesWith(WorldEntity* entity, const Vector& location);
78  virtual void process(const Event &event);
79  virtual void tick(float dt);
80
81  // NETWORK
82  int       writeSync(const byte* data, int length, int sender);
83  int       readSync(byte* data, int maxLength );
84  bool      needsReadSync();
85
86
87  // Transformations:
88  static Playable::Playmode stringToPlaymode(const std::string& playmode);
89  static const char* playmodeToString(Playable::Playmode playmode);
90protected:
91  Playable();
92
93  // Player Setup
94  virtual void enter() = 0;
95  virtual void leave() = 0;
96  // Playmode
97  void setSupportedPlaymodes(short playmodes) { this->supportedPlaymodes = playmodes; };
98  virtual void enterPlaymode(Playable::Playmode playmode);
99
100  // Events.
101  void registerEvent(int eventType);
102  void unregisterEvent(int eventType);
103
104private:
105  WeaponManager         weaponMan;          //!< the weapon manager: managing a list of weapon to wepaon-slot mapping
106  std::vector<int>      events;             //!< A list of Events, that are captured for this playable
107
108  Player*               currentPlayer;      //!< The Player currently connected to this Playable (the one that has controll) otherwise NULL
109
110  bool                  bFire;              //!< If the Ship is firing.
111  int                   oldFlags;           //!< Used for synchronisation
112
113  int                   score;
114  int                   oldScore;
115
116  bool                  bDead;
117  short                 supportedPlaymodes; //!< What Playmodes are Supported in this Playable.
118  Playable::Playmode    playmode;           //!< The current playmode.
119
120  WorldEntity* collider;
121};
122
123#endif /* _PLAYABLE_H */
Note: See TracBrowser for help on using the repository browser.