Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/spaceshipcontrol/src/world_entities/playable.h @ 6694

Last change on this file since 6694 was 6568, checked in by bensch, 19 years ago

trunk: weaponManager is now reporting the change of Weapons to the (if a ) Playable

File size: 1.7 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 <list>
13
14#include "world_entities/weapons/weapon_manager.h"
15
16class Weapon;
17
18class Player;
19
20//! Basic controllable WorldEntity
21/**
22 *
23 */
24class Playable : public WorldEntity, public Extendable
25{
26  public:
27    Playable();
28    virtual ~Playable();
29
30    virtual void enter()=0;
31    virtual void leave()=0;
32
33    virtual bool pickup(PowerUp* powerUp);
34
35    void addWeapon(Weapon* weapon, int configID = -1, int slotID = -1);
36    void removeWeapon(Weapon* weapon);
37    void nextWeaponConfig();
38    void previousWeaponConfig();
39
40    inline WeaponManager* getWeaponManager() const { return this->weaponMan; };
41    void weaponConfigChanged();
42
43
44    bool subscribePlayer(Player* player);
45    bool unsubscribePlayer(Player* player);
46
47    void attachCamera();
48    void detachCamera();
49
50    virtual void collidesWith(WorldEntity* entity, const Vector& location);
51    virtual void process(const Event &event) = 0;
52
53
54
55    /** @return a List of Events in PEV_* sytle */
56    inline const std::list<int>& getEventList() { return this->events; };
57
58  protected:
59    void registerEvent(int eventType);
60    void unregisterEvent(int eventType);
61
62  private:
63    WeaponManager*        weaponMan;          //!< the weapon manager: managing a list of weapon to wepaon-slot mapping
64    std::list<int>        events;             //!< A list of Events, that are captured for this playable
65
66    Player*               currentPlayer;      //!< The Player currently connected to this Playable (the one that has controll) otherwise NULL
67
68};
69
70#endif /* _PLAYABLE_H */
Note: See TracBrowser for help on using the repository browser.