Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/atmospheric_engine/src/lib/graphics/effects/atmospheric_engine.cc @ 7514

Last change on this file since 7514 was 7514, checked in by hdavid, 18 years ago

branches/atmospheric_engine: AtmosphericEngine ticks and draws the different weather effects

File size: 3.0 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: Andreas Maechler, David Hasenfratz
13   co-programmer: ...
14*/
15
16#include "atmospheric_engine.h"
17
18#include "util/loading/resource_manager.h"
19
20#include "effects/fog_effect.h"
21
22#include "util/loading/load_param.h"
23#include "util/loading/factory.h"
24#include "class_list.h"
25
26
27using namespace std;
28
29/**
30 * @param root The XML-element to load the AtmosphericEngine from
31 */
32AtmosphericEngine::AtmosphericEngine()
33{
34  this->setClassID(CL_ATMOSPHERIC_ENGINE, "AtmosphericEngine");
35}
36
37/**
38 *  The Pointer to this AtmosphericEngine
39*/
40AtmosphericEngine* AtmosphericEngine::singletonRef = NULL;
41
42
43/**
44 *  destroys a AtmosphericEngine
45 */
46AtmosphericEngine::~AtmosphericEngine()
47{
48  AtmosphericEngine::singletonRef = NULL;
49
50  const std::list<BaseObject*>* weatherEffects = ClassList::getList( CL_WEATHER_EFFECT);
51
52  if (weatherEffects != NULL)
53  {
54      while(!weatherEffects->empty())
55        delete weatherEffects->front();
56  }
57}
58
59/**
60 * @param root The XML-element to load the AtmosphericEngine from
61 */
62void AtmosphericEngine::loadParams(const TiXmlElement* root)
63{
64  LoadParamXML(root, "WeatherEffect", this, AtmosphericEngine, loadWeatherEffect);
65  LoadParamXML(root, "SunEffect", this, AtmosphericEngine, loadSunEffect);
66}
67
68/**
69 * @param root The XML-element to load WeatherEffects from
70 */
71void AtmosphericEngine::loadWeatherEffect(const TiXmlElement* root)
72{
73  LOAD_PARAM_START_CYCLE(root, element);
74  {
75    PRINTF(4)("element is: %s\n", element->Value());
76    Factory::fabricate(element);
77  }
78  LOAD_PARAM_END_CYCLE(element);
79}
80
81/**
82 * @param root The XML-element to load SunEffects from
83 */
84void AtmosphericEngine::loadSunEffect(const TiXmlElement* root)
85{
86  LOAD_PARAM_START_CYCLE(root, element);
87  {
88    PRINTF(4)("element is: %s\n", element->Value());
89    Factory::fabricate(element);
90  }
91  LOAD_PARAM_END_CYCLE(element);
92}
93
94
95/**
96 * draws the effect, if needed
97 */
98void AtmosphericEngine::draw() const
99{
100  const std::list<BaseObject*>* weatherEffects = ClassList::getList( CL_WEATHER_EFFECT);
101
102  // draw the weather effects
103  if (weatherEffects != NULL)
104  {
105    std::list<BaseObject*>::const_iterator it;
106    for (it = weatherEffects->begin(); it != weatherEffects->end(); it++)
107      dynamic_cast<WeatherEffect*>(*it)->draw();
108  }
109}
110
111
112
113/**
114 * ticks the effect if there is any time dependancy
115 */
116void AtmosphericEngine::tick(float dt)
117{
118  const std::list<BaseObject*>* weatherEffects = ClassList::getList( CL_WEATHER_EFFECT);
119
120  // tick the weather effects
121  if (weatherEffects != NULL)
122  {
123    std::list<BaseObject*>::const_iterator it;
124    for (it = weatherEffects->begin(); it != weatherEffects->end(); it++)
125      dynamic_cast<WeatherEffect*>(*it)->tick(dt);
126  }
127}
Note: See TracBrowser for help on using the repository browser.