| [4597] | 1 | /*! | 
|---|
| [5039] | 2 | * @file skybox.h | 
|---|
| [5357] | 3 | *  Definition of the SkyBox, that handles the Display of an atmosphere for orxonox. | 
|---|
|  | 4 | * | 
|---|
|  | 5 | * A SkyBox is always centered at the current working Camera, and will only obey the cameras | 
|---|
|  | 6 | * movment but not its rotation. | 
|---|
| [3416] | 7 | */ | 
|---|
|  | 8 |  | 
|---|
| [3796] | 9 | #ifndef _SKYBOX_H | 
|---|
|  | 10 | #define _SKYBOX_H | 
|---|
| [3416] | 11 |  | 
|---|
| [3419] | 12 | /* INCLUDES */ | 
|---|
| [3502] | 13 | #include "world_entity.h" | 
|---|
| [6771] | 14 | #include "material.h" | 
|---|
| [3411] | 15 |  | 
|---|
| [6771] | 16 | enum SKY_SIDE | 
|---|
|  | 17 | { | 
|---|
| [7328] | 18 | SKY_BACK = 0, | 
|---|
|  | 19 | SKY_FRONT, | 
|---|
| [6771] | 20 | SKY_BOTTOM, | 
|---|
| [7328] | 21 | SKY_TOP, | 
|---|
| [6771] | 22 | SKY_LEFT, | 
|---|
|  | 23 | SKY_RIGHT, | 
|---|
|  | 24 | }; | 
|---|
| [3419] | 25 |  | 
|---|
| [3807] | 26 | //! A Class to handle a SkyBox | 
|---|
| [3796] | 27 | class SkyBox : public WorldEntity | 
|---|
| [3411] | 28 | { | 
|---|
| [3416] | 29 | public: | 
|---|
| [7221] | 30 | SkyBox(const std::string& fileName = ""); | 
|---|
| [4261] | 31 | SkyBox(const TiXmlElement* root); | 
|---|
| [4010] | 32 |  | 
|---|
| [3796] | 33 | virtual ~SkyBox(); | 
|---|
| [3419] | 34 |  | 
|---|
| [5357] | 35 | void init(); | 
|---|
| [4746] | 36 | void preInit(); | 
|---|
| [4680] | 37 |  | 
|---|
| [6512] | 38 | virtual void loadParams(const TiXmlElement* root); | 
|---|
| [4261] | 39 |  | 
|---|
| [4746] | 40 | void postInit(); | 
|---|
| [4010] | 41 |  | 
|---|
| [6634] | 42 | virtual void draw(); | 
|---|
| [4012] | 43 |  | 
|---|
| [3796] | 44 | void setSize(float size); | 
|---|
| [4998] | 45 | /** assumes jpg as input-format */ | 
|---|
| [7221] | 46 | void setTexture(const std::string& name); | 
|---|
| [4680] | 47 |  | 
|---|
| [7221] | 48 | void setTextureAndType(const std::string& name, const std::string& extension); | 
|---|
| [7328] | 49 | void setTextures(const std::string& negX, const std::string& posX, const std::string& negY, | 
|---|
|  | 50 | const std::string& posY, const std::string& negZ, const std::string& posZ); | 
|---|
| [3420] | 51 |  | 
|---|
| [7328] | 52 | void loadCubeMapTextures(const std::string& negX, const std::string& posX, const std::string& negY, | 
|---|
|  | 53 | const std::string& posY, const std::string& negZ, const std::string& posZ); | 
|---|
| [6470] | 54 |  | 
|---|
| [8575] | 55 | GLuint getTexture(SKY_SIDE side) const { return (this->material[side]) ? this->material[side]->diffuseTextureID(): 0; }; | 
|---|
| [6771] | 56 |  | 
|---|
| [6470] | 57 | static void enableCubeMap(); | 
|---|
|  | 58 | static void disableCubeMap(); | 
|---|
|  | 59 |  | 
|---|
| [7954] | 60 | virtual void varChangeHandler( std::list<int> & id ); | 
|---|
| [6341] | 61 |  | 
|---|
| [3801] | 62 | private: | 
|---|
|  | 63 | void rebuild(); | 
|---|
|  | 64 |  | 
|---|
| [6307] | 65 | Material*       material[6];     //!< Materials for the SkyBox. sorted by number (0-5) top, bottom, left, right, front, back | 
|---|
| [6519] | 66 | Texture*        cubeTexture[6];  //!< Textures for the CubeMap. | 
|---|
| [6470] | 67 |  | 
|---|
| [4597] | 68 | float           size;            //!< Size of the SkyBox. This should match the frustum maximum range. | 
|---|
| [6634] | 69 | float           textureSize;     //!< this is the length of a texture (assumes a square texture) | 
|---|
| [7221] | 70 | std::string     textureName;     //!< Name of the Texture | 
|---|
| [8575] | 71 |  | 
|---|
| [7954] | 72 | int textureName_handle;          //!< used to notify about changes of textureName | 
|---|
|  | 73 | int size_handle;                 //!< used to notify about changes of size | 
|---|
| [4597] | 74 |  | 
|---|
| [3411] | 75 | }; | 
|---|
|  | 76 |  | 
|---|
| [3796] | 77 | #endif  /* _SKYBOX_H */ | 
|---|
| [3411] | 78 |  | 
|---|
|  | 79 |  | 
|---|
| [3484] | 80 |  | 
|---|