Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/orxonox/trunk/src/story_entities/world.h @ 4977

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

orxonox/trunk: removed the WorldInterface, as its job is already been taken by state.h
also removed some totally obsolete but very cool functions of NPC

File size: 3.6 KB
Line 
1/*!
2    \file world.h
3  *  Holds and manages all game data
4*/
5
6#ifndef _WORLD_H
7#define _WORLD_H
8
9#include "stdincl.h"
10#include "comincl.h"
11#include "story_entity.h"
12#include "p_node.h"
13
14class World;
15class WorldEntity;
16class Camera;
17class Player;
18class PNode;
19class GLMenuImageScreen;
20class Terrain;
21class GarbageCollector;
22class Text;
23class TiXmlElement;
24class PilotNode;
25
26class OggPlayer;
27
28//! The game world
29/**
30   this class initializes everything that should be displayed inside of the current level.
31   it is the main driving factor during gameplay.
32*/
33class World : public StoryEntity {
34
35 public:
36  World (char* name);
37  World (int worldID);
38  World (const TiXmlElement* root = NULL);
39  virtual ~World ();
40
41  void loadParams(const TiXmlElement* root);
42
43  double getGameTime();
44
45  /* classes from story-entity */
46  virtual ErrorMessage preLoad();
47  virtual ErrorMessage load ();
48  virtual ErrorMessage init ();
49  virtual ErrorMessage start ();
50  virtual ErrorMessage stop ();
51  virtual ErrorMessage pause ();
52  virtual ErrorMessage resume ();
53  virtual ErrorMessage destroy ();
54
55  void loadDebugWorld(int worldID);
56
57  virtual void displayLoadScreen();
58  virtual void releaseLoadScreen();
59
60  /* command node functions */
61  bool command (Command* cmd);
62
63  tList<WorldEntity>* getEntities();
64
65  /* interface to world */
66  void spawn (WorldEntity* entity);
67  void spawn (WorldEntity* entity, Vector* absCoor, Quaternion* absDir);
68  void spawn(WorldEntity* entity, PNode* parentNode, Vector* relCoor, Quaternion* relDir);
69
70  const char* getPath();
71  void setPath( const char* name);
72
73  inline Camera* getLocalCamera() {return this->localCamera;}
74
75 private:
76  void constuctorInit(char* name, int worldID);
77
78  Uint32 lastFrame;                   //!< last time of frame
79  Uint32 cycle;                       //!< The cycle we are in (starts with 0 and rises with every frame)
80  Uint32 dt;                          //!< time needed to calculate this frame (in milliSeconds)
81  float dtS;                          //!< The time needed for caluculations in seconds
82  double gameTime;                    //!< this is where the game time is saved
83  bool bQuitOrxonox;                  //!< quit this application
84  bool bQuitCurrentGame;              //!< quit only the current game and return to menu
85  bool bPause;                        //!< pause mode
86
87  GLMenuImageScreen* glmis;           //!< The Level-Loader Display
88
89  char* worldName;                    //!< The name of this World
90  int debugWorldNr;                   //!< The Debug Nr. needed, if something goes wrong
91  char* path;                         //!< The file from which this world is loaded
92
93
94  OggPlayer* music;
95
96  // IMPORTANT WORLD-ENTITIES
97  PNode* nullParent;                  //!< The zero-point, that everything has as its parent.
98  Camera* localCamera;                //!< The current Camera
99  WorldEntity* sky;                   //!< The Environmental Heaven of orxonox @todo insert this to environment insted
100  Terrain* terrain;                   //!< The Terrain of the World.
101
102  GLuint objectList;                  //!< temporary: @todo this will be ereased soon
103  tList<WorldEntity>* entities;       //!< A template List of all entities. Every moving thing should be included here, and world automatically updates them.
104  Player* localPlayer;                //!< The Player, you fly through the level.
105  PilotNode* pilotNode;               //!< THe pilot node to fly with the mouse
106
107  /* function for main-loop */
108  void mainLoop ();
109  void synchronize ();
110  void handleInput ();
111  void tick ();
112  void update ();
113  void collide ();
114  void draw ();
115  void display ();
116  void debug ();
117
118};
119
120#endif /* _WORLD_H */
Note: See TracBrowser for help on using the repository browser.