Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/story_entities/game_world_data.cc @ 9240

Last change on this file since 9240 was 9235, checked in by bensch, 18 years ago

merged the presentation back

File size: 10.5 KB
Line 
1/*
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:
12   main-programmer: Patrick Boenzli
13*/
14
15
16#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_WORLD
17
18#include <fstream>
19#include <iostream>
20
21#include "game_world_data.h"
22
23#include "util/loading/resource_manager.h"
24#include "state.h"
25#include "class_list.h"
26#include "substring.h"
27
28#include "util/loading/game_loader.h"
29
30#include "world_entity.h"
31#include "player.h"
32#include "camera.h"
33#include "terrain.h"
34#include "skybox.h"
35#include "md2/md2Model.h"
36#include "world_entities/projectiles/projectile.h"
37#include "npcs/npc_test1.h"
38#include "playable.h"
39
40#include "light.h"
41
42#include "util/loading/factory.h"
43#include "fast_factory.h"
44#include "util/loading/load_param.h"
45
46#include "graphics_engine.h"
47#include "effects/atmospheric_engine.h"
48#include "event_handler.h"
49#include "sound_engine.h"
50#include "cd_engine.h"
51#include "network_manager.h"
52#include "physics_engine.h"
53#include "fields.h"
54
55#include "glmenu_imagescreen.h"
56
57#include "game_rules.h"
58
59#include "ogg_player.h"
60#include "shader.h"
61
62
63using namespace std;
64
65
66/**
67 * constructor of the GameWorldData
68 */
69GameWorldData::GameWorldData()
70{
71  this->setClassID(CL_GAME_WORLD_DATA, "GameWorldData");
72
73  this->glmis = NULL;
74
75  this->localCamera = NULL;
76  this->localPlayer = NULL;
77  this->sky = NULL;
78  this->terrain = NULL;
79
80  this->music = NULL;
81  this->objectManager = NULL;
82  this->gameRule = NULL;
83}
84
85
86/**
87 * destructor for the GameWorldData
88 */
89GameWorldData::~GameWorldData()
90{}
91
92
93
94/**
95 *  initialize the GameWorldData
96 */
97ErrorMessage GameWorldData::init()
98{
99  this->objectManager = new ObjectManager();
100  State::setObjectManager(this->objectManager);
101
102  PNode::getNullParent();
103  this->localCamera = new Camera();
104  this->localCamera->setName ("GameWorld-Camera");
105  State::setCamera(this->localCamera, this->localCamera->getTarget());
106
107  LightManager::getInstance();
108
109//  GraphicsEngine::getInstance()->displayFPS(true);
110
111  return ErrorMessage();
112}
113
114
115/**
116 *  loads the data from the xml file
117 * @param root reference to the xml root element
118 */
119ErrorMessage GameWorldData::loadData(const TiXmlElement* root)
120{
121  // load the parameters
122  // name
123  std::string string = grabParameter( root, "name");
124  if( string.empty() )
125  {
126    PRINTF(2)("GameWorld is missing a proper 'name'\n");
127    this->setName("Unknown");
128  }
129  else
130    this->setName(string.c_str());
131
132  this->loadGUI(root);
133  this->loadWorldEntities(root);
134  this->loadScene(root);
135
136  return ErrorMessage();
137}
138
139
140/**
141 *  unloads the data from the xml file
142 */
143ErrorMessage GameWorldData::unloadData()
144{
145  this->unloadGUI();
146  this->unloadWorldEntities();
147  this->unloadScene();
148
149  return ErrorMessage();
150}
151
152
153/**
154 * @brief loads the GUI data
155 * @param root reference to the xml root element
156 */
157ErrorMessage GameWorldData::loadGUI(const TiXmlElement* root)
158{
159  const TiXmlElement* element = root->FirstChildElement("LoadScreen");
160  if( element == NULL)
161  {
162    PRINTF(2)("no LoadScreen specified, loading default\n");
163
164    glmis->setBackgroundImage("pictures/load_screen.jpg");
165    this->glmis->setMaximum(8);
166    //     this->glmis->draw();
167  }
168  else
169  {
170    this->glmis->loadParams(element);
171    //     this->glmis->draw();
172  }
173  this->glmis->draw();
174
175  return ErrorMessage();
176}
177
178
179/**
180 * @brief unloads the GUI data
181 */
182ErrorMessage GameWorldData::unloadGUI()
183{
184  delete this->glmis;
185
186  return ErrorMessage();
187}
188
189
190/**
191 * @brief loads the world entities from the xml file
192 * @param root reference to the xml root parameter
193 */
194ErrorMessage GameWorldData::loadWorldEntities(const TiXmlElement* root)
195{
196  const TiXmlElement* element = root->FirstChildElement("WorldEntities");
197
198  if( element == NULL)
199  {
200    PRINTF(1)("GameWorld is missing 'WorldEntities'\n");
201  }
202  else
203  {
204    element = element->FirstChildElement();
205    // load Players/Objects/Whatever
206    PRINTF(4)("Loading WorldEntities\n");
207    while( element != NULL)
208    {
209      BaseObject* created = Factory::fabricate(element);
210      if( created != NULL )
211        PRINTF(4)("Created a %s: %s\n", created->getClassName(), created->getName());
212
213      //todo do this more elegant
214      if( element->Value() == "SkyBox" && created->isA(CL_SKYBOX))
215      {
216        this->sky = dynamic_cast<WorldEntity*>(created);
217        State::setSkyBox(dynamic_cast<SkyBox*>(this->sky));
218      }
219      if( element->Value() == "Terrain" && created->isA(CL_TERRAIN))
220      {
221        this->terrain = dynamic_cast<Terrain*>(created);
222        CDEngine::getInstance()->setTerrain(terrain);
223      }
224      element = element->NextSiblingElement();
225      this->glmis->step(); //! @todo temporary
226    }
227    PRINTF(4)("Done loading WorldEntities\n");
228  }
229
230  // Create a Player
231  this->localPlayer = new Player();
232  State::setPlayer(this->localPlayer);
233
234  Playable* playable;
235  const list<BaseObject*>* playableList = ClassList::getList(CL_PLAYABLE);
236  if (playableList != NULL && !playableList->empty())
237  {
238    /// TODO Make this also loadable
239    playable = dynamic_cast<Playable*>(playableList->front());
240    this->localPlayer->setPlayable(playable);
241  }
242
243  // Fill the EntityLists. Tick then Draw:
244  this->tickLists.push_back(OM_DEAD_TICK);
245  this->tickLists.push_back(OM_ENVIRON);
246  this->tickLists.push_back(OM_COMMON);
247  this->tickLists.push_back(OM_GROUP_00);
248  this->tickLists.push_back(OM_GROUP_00_PROJ);
249  this->tickLists.push_back(OM_GROUP_01);
250  this->tickLists.push_back(OM_GROUP_01_PROJ);
251  this->tickLists.push_back(OM_GROUP_02);
252
253  this->drawLists.push_back(OM_ENVIRON_NOTICK);
254  this->drawLists.push_back(OM_ENVIRON);
255  this->drawLists.push_back(OM_GROUP_00);
256  this->drawLists.push_back(OM_GROUP_00_PROJ);
257  this->drawLists.push_back(OM_GROUP_01);
258  this->drawLists.push_back(OM_GROUP_01_PROJ);
259  this->drawLists.push_back(OM_GROUP_02);
260  this->drawLists.push_back(OM_COMMON);
261
262  /* init the pnode tree */
263  PNode::getNullParent()->init();
264
265  return ErrorMessage();
266}
267
268
269/**
270 *  unloads the world entities
271 */
272ErrorMessage GameWorldData::unloadWorldEntities()
273{
274  FastFactory::flushAll(true);
275  GraphicsEngine::getInstance()->displayFPS(false);
276  // erease everything that is left.
277  // delete PNode::getNullParent(); // not needed as this is also done in the next step (and also much cleaner)
278  const std::list<BaseObject*>* nodeList;
279  //secondary cleanup of PNodes;
280  nodeList = ClassList::getList(CL_PARENT_NODE);
281  if (nodeList != NULL)
282    while (!nodeList->empty())
283    {
284      //    ClassList::debug( 3, CL_PARENT_NODE);
285      //    PNode::getNullParent()->debugNode(0);
286      //    printf("%s::%s\n", nodeList->front()->getClassName(), nodeList->front()->getName());
287      delete nodeList->front();
288    }
289  /* remove the player object */
290  if( this->localPlayer)
291    delete this->localPlayer;
292  State::setPlayer(NULL);
293  this->localPlayer = NULL;
294  this->localCamera = NULL;
295  State::setCamera(NULL, NULL);
296  this->sky = NULL;
297  this->terrain = NULL;
298
299  nodeList = ClassList::getList(CL_GRAPHICS_EFFECT);
300  if (nodeList != NULL)
301    while (!nodeList->empty())
302      delete nodeList->front();
303
304
305  nodeList = ClassList::getList(CL_ELEMENT_2D);
306  if (nodeList != NULL)
307    while (!nodeList->empty())
308      delete nodeList->front();
309
310  // At this Point all the WorldEntites should be unloaded.
311  this->tickLists.clear();
312  this->drawLists.clear();
313
314  // unload the resources loaded in this Level !!
315  ResourceManager::getInstance()->unloadAllByPriority(RP_LEVEL);
316
317  if (State::getObjectManager() == this->objectManager)
318  {
319    State::setObjectManager(NULL);
320    delete this->objectManager;
321  }
322  this->objectManager = NULL;
323
324  if(State::getSkyBox())
325    State::setSkyBox(NULL);
326
327  this->glmis = NULL;
328
329  return ErrorMessage();
330}
331
332
333/**
334 * @brief loads the scene data
335 * @param root reference to the xml root element
336 */
337ErrorMessage GameWorldData::loadScene(const TiXmlElement* root)
338{
339  LoadParamXML(root, "LightManager", LightManager::getInstance(), LightManager, loadParams);
340  LoadParamXML(root, "GraphicsEngine", GraphicsEngine::getInstance(), GraphicsEngine, loadParams);
341  LoadParamXML(root, "AtmosphericEngine", AtmosphericEngine::getInstance(), AtmosphericEngine, loadParams);
342
343  LoadParam(root, "Music", this, GameWorldData, setSoundTrack);
344
345  LoadParamXML(root, "GameRule", this, GameWorldData, loadGameRule);
346
347  LoadParam(root, "clip-region", this->localCamera, Camera, setClipRegion);
348
349
350  //LoadParamXML(root, "ParticleEngine", ParticleEngine::getInstance(), ParticleEngine, loadParams);
351  //LoadParamXML(root, "PhysicsEngine", PhysicsEngine::getInstance(), PhysicsEngine, loadParams);
352
353  if( this->sky != NULL)
354    this->localCamera->addChild(this->sky);
355  OrxSound::SoundEngine::getInstance()->setListener(this->localCamera);
356
357  return ErrorMessage();
358}
359
360
361
362/**
363 *  unloads the scene data
364 */
365ErrorMessage GameWorldData::unloadScene()
366{
367  /* delete some garphics and scene eingines */
368  delete LightManager::getInstance();
369  delete AtmosphericEngine::getInstance();
370
371  if (this->music != NULL)
372    this->setSoundTrack("");
373
374  /* unload the shaders */
375  Shader::suspendShader();
376
377  State::setGameRules(NULL);
378
379  return ErrorMessage();
380}
381
382
383void GameWorldData::setSoundTrack(const std::string& name)
384{
385  if (this->music != NULL)
386    delete this->music;
387  this->music = NULL;
388
389  if (!name.empty())
390  {
391    PRINTF(3)("Setting Sound Track to %s\n", name.c_str());
392    std::string oggFile = ResourceManager::getFullName(name);
393    this->music = new OrxSound::OggPlayer(oggFile);
394    if (this->localPlayer != NULL)
395      this->localPlayer->hud().notifyUser(std::string("Playing SoundTrack: ") + this->music->artist() + " - " + this->music->title());
396
397    //(OggPlayer*)ResourceManager::getInstance()->load(name, OGG, RP_LEVEL);
398    //assert(this->music->isA(CL_SOUND_OGG_PLAYER));
399  }
400}
401
402
403void GameWorldData::loadGameRule(const TiXmlElement* root)
404{
405  const TiXmlElement* element = root->FirstChildElement();
406  while( element != NULL)
407  {
408    PRINTF(2)("============ GameRules ==\n");
409    PRINTF(2)("creating %s\n", element->Value());
410    BaseObject* created = Factory::fabricate(element);
411    if (created != NULL && created->isA(CL_GAME_RULES))
412    {
413      this->gameRule = dynamic_cast<GameRules*>(created);
414      State::setGameRules(this->gameRule);
415      // if there is a valid game rule loaded, return because it is not thought to load multiple game rules
416      return;
417    }
418    else
419    {
420      PRINTF(1)("Could not create a %s\n", element->Value());
421      delete created;
422    }
423    element = element->NextSiblingElement();
424  }
425}
426
427
428
Note: See TracBrowser for help on using the repository browser.