Orxonox  0.0.5 Codename: Arcturus
ParticleInterface.h
Go to the documentation of this file.
1 /*
2  * ORXONOX - the hottest 3D action shooter ever to exist
3  * > www.orxonox.net <
4  *
5  *
6  * License notice:
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License
10  * as published by the Free Software Foundation; either version 2
11  * of the License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
21  *
22  * Author:
23  * Fabian 'x3n' Landau
24  * Co-authors:
25  * ...
26  *
27  */
28 
29 #ifndef _ParticleInterface_H__
30 #define _ParticleInterface_H__
31 
32 #include "tools/ToolsPrereqs.h"
33 
34 #include "util/OgreForwardRefs.h"
36 
37 namespace orxonox
38 {
40  {
41  public:
42  ParticleInterface(Ogre::SceneManager* scenemanager, const std::string& templateName, LODParticle::Value detaillevel);
43  virtual ~ParticleInterface();
44  void setConfigValues();
45 
46  inline Ogre::ParticleSystem* getParticleSystem()
47  { return this->particleSystem_; }
48 
49  Ogre::ParticleEmitter* createNewEmitter();
50  Ogre::ParticleEmitter* getEmitter(unsigned int emitterNr) const;
51  void removeEmitter(unsigned int emitterNr);
52  void removeAllEmitters();
53  unsigned int getNumEmitters() const;
54 
55  Ogre::ParticleAffector* addAffector(const std::string& name);
56  Ogre::ParticleAffector* getAffector(unsigned int affectorNr);
57  void removeAffector(unsigned int affectorNr);
58  void removeAllAffectors();
59  unsigned int getNumAffectors() const;
60 
61  inline float getSpeedFactor() const
62  { return this->speedFactor_; }
63  void setSpeedFactor(float factor);
64  bool getKeepParticlesInLocalSpace() const;
65  void setKeepParticlesInLocalSpace(bool keep);
66 
67  void setEnabled(bool enable);
68  inline bool isEnabled() const
69  { return this->bEnabled_; }
70 
71  void setVisible(bool visible);
72  inline bool isVisible() const
73  { return this->bVisible_; }
74 
75  void setDetailLevel(unsigned int level);
76 
77  void setDimensions(float scale);
78 
79  protected:
80  virtual void changedTimeFactor(float factor_new, float factor_old) override;
81 
82  private:
83  void updateVisibility();
84  void detailLevelChanged();
85 
86  Ogre::ParticleSystem* particleSystem_;
87  Ogre::SceneManager* scenemanager_;
88  bool bVisible_;
89  bool bEnabled_;
91  unsigned int detaillevel_;
92  float speedFactor_;
93 
94  // config values
95  unsigned int globalDetailLevel_;
96 
97  static unsigned int counter_s;
98  };
99 }
100 
101 #endif /* _ParticleInterface_H__ */
bool bEnabled_
Definition: ParticleInterface.h:89
Ogre::ParticleSystem * getParticleSystem()
Definition: ParticleInterface.h:46
unsigned int globalDetailLevel_
Global maximum detail level of particle effects (0: off, 1: low, 2: normal, 3: high) ...
Definition: ParticleInterface.h:95
bool bVisible_
Definition: ParticleInterface.h:88
Ogre::SceneManager * scenemanager_
Definition: ParticleInterface.h:87
::std::string string
Definition: gtest-port.h:756
float speedFactor_
Definition: ParticleInterface.h:92
Ogre::ParticleSystem * particleSystem_
Definition: ParticleInterface.h:86
Shared library macros, enums, constants and forward declarations for the tools module ...
#define _ToolsExport
Definition: ToolsPrereqs.h:59
bool isEnabled() const
Definition: ParticleInterface.h:68
static unsigned int counter_s
Definition: ParticleInterface.h:97
Value
Definition: ToolsPrereqs.h:71
Die Wagnis Klasse hat die folgenden Aufgaben:
Definition: ApplicationPaths.cc:66
bool bAllowedByLOD_
Definition: ParticleInterface.h:90
bool isVisible() const
Definition: ParticleInterface.h:72
unsigned int detaillevel_
Detail level of this particle effect (0: off, 1: low, 2: normal, 3: high)
Definition: ParticleInterface.h:91
Definition: TimeFactorListener.h:37
Definition: ParticleInterface.h:39
float getSpeedFactor() const
Definition: ParticleInterface.h:61