| [4597] | 1 | /* | 
|---|
| [1853] | 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. | 
|---|
| [1855] | 10 |  | 
|---|
|  | 11 | ### File Specific: | 
|---|
| [3925] | 12 | main-programmer: Benjamin Grauer | 
|---|
| [1855] | 13 | co-programmer: ... | 
|---|
| [1853] | 14 | */ | 
|---|
|  | 15 |  | 
|---|
| [5357] | 16 | #define DEBUG_SPECIAL_MODULE DEBUG_MODULE_GRAPHICS | 
|---|
| [1853] | 17 |  | 
|---|
| [6621] | 18 | #include "sprite_particles.h" | 
|---|
| [1853] | 19 |  | 
|---|
| [7193] | 20 | #include "util/loading/load_param.h" | 
|---|
|  | 21 | #include "util/loading/factory.h" | 
|---|
| [3942] | 22 | #include "material.h" | 
|---|
| [4338] | 23 | #include "state.h" | 
|---|
| [5446] | 24 | #include "shell_command.h" | 
|---|
| [3930] | 25 |  | 
|---|
| [5944] | 26 | #include "parser/tinyxml/tinyxml.h" | 
|---|
| [6612] | 27 | #include <algorithm> | 
|---|
| [4338] | 28 |  | 
|---|
| [6612] | 29 |  | 
|---|
| [6621] | 30 | CREATE_FACTORY(SpriteParticles, CL_SPRITE_PARTICLES); | 
|---|
|  | 31 |  | 
|---|
|  | 32 | SHELL_COMMAND(texture, SpriteParticles, setMaterialTexture) | 
|---|
| [7198] | 33 | ->defaultValues("maps/evil-flower.png"); | 
|---|
| [4725] | 34 |  | 
|---|
| [1853] | 35 |  | 
|---|
| [9406] | 36 |  | 
|---|
| [3245] | 37 | /** | 
|---|
| [4836] | 38 | *  standard constructor | 
|---|
|  | 39 | * @param maxCount the Count of particles in the System | 
|---|
| [6621] | 40 | * @param type The Type of the SpriteParticles | 
|---|
| [3245] | 41 | */ | 
|---|
| [6621] | 42 | SpriteParticles::SpriteParticles (unsigned int maxCount) | 
|---|
|  | 43 | : ParticleSystem(maxCount) | 
|---|
| [3365] | 44 | { | 
|---|
| [4602] | 45 | this->init(); | 
|---|
| [3365] | 46 | } | 
|---|
| [1853] | 47 |  | 
|---|
| [4677] | 48 | /** | 
|---|
| [5445] | 49 | * @brief creates a Particle System out of a XML-element | 
|---|
|  | 50 | * @param root: the XML-element to load from | 
|---|
| [4677] | 51 | */ | 
|---|
| [6621] | 52 | SpriteParticles::SpriteParticles(const TiXmlElement* root) | 
|---|
| [4602] | 53 | { | 
|---|
|  | 54 | this->init(); | 
|---|
| [6623] | 55 | if (root != NULL) | 
|---|
|  | 56 | this->loadParams(root); | 
|---|
| [4602] | 57 | } | 
|---|
| [1853] | 58 |  | 
|---|
| [3245] | 59 | /** | 
|---|
| [4836] | 60 | *  standard deconstructor | 
|---|
| [3245] | 61 | */ | 
|---|
| [6621] | 62 | SpriteParticles::~SpriteParticles() | 
|---|
| [6653] | 63 | { } | 
|---|
| [4123] | 64 |  | 
|---|
| [3945] | 65 | /** | 
|---|
| [6621] | 66 | * @brief initializes the SpriteParticles with default values | 
|---|
| [4602] | 67 | */ | 
|---|
| [6621] | 68 | void SpriteParticles::init() | 
|---|
| [4602] | 69 | { | 
|---|
| [6621] | 70 | this->setClassID(CL_SPRITE_PARTICLES, "SpriteParticles"); | 
|---|
| [4602] | 71 |  | 
|---|
| [6626] | 72 | this->material.setDiffuseMap("maps/radial-trans-noise.png"); | 
|---|
| [4602] | 73 | } | 
|---|
|  | 74 |  | 
|---|
|  | 75 |  | 
|---|
|  | 76 | /** | 
|---|
|  | 77 | * loads Parameters from a TiXmlElement | 
|---|
|  | 78 | * @param root the XML-element to load from. | 
|---|
|  | 79 | */ | 
|---|
| [6621] | 80 | void SpriteParticles::loadParams(const TiXmlElement* root) | 
|---|
| [4602] | 81 | { | 
|---|
| [6623] | 82 | ParticleSystem::loadParams(root); | 
|---|
| [4602] | 83 |  | 
|---|
| [6621] | 84 | LoadParam(root, "texture", this, SpriteParticles, setMaterialTexture); | 
|---|
| [4602] | 85 | } | 
|---|
| [4727] | 86 |  | 
|---|
| [4478] | 87 | /** | 
|---|
| [6626] | 88 | * @brief sets the Texutre that is placed onto the particles | 
|---|
|  | 89 | * @param textureFile the Texture to load onto these SpriteParticles | 
|---|
|  | 90 | */ | 
|---|
| [7221] | 91 | void SpriteParticles::setMaterialTexture(const std::string& textureFile) | 
|---|
| [5446] | 92 | { | 
|---|
| [6621] | 93 | this->material.setDiffuseMap(textureFile); | 
|---|
| [5446] | 94 | } | 
|---|
|  | 95 |  | 
|---|
| [3938] | 96 | /** | 
|---|
| [6621] | 97 | * @brief draws all the Particles of this System | 
|---|
|  | 98 | * | 
|---|
|  | 99 | * The Cases in this Function all do the same: | 
|---|
|  | 100 | * Drawing all the particles with the appropriate Type. | 
|---|
|  | 101 | * This is just the fastest Way to do this, but will most likely be changed in the future. | 
|---|
| [4338] | 102 | */ | 
|---|
| [6621] | 103 | void SpriteParticles::draw() const | 
|---|
| [4338] | 104 | { | 
|---|
|  | 105 |  | 
|---|
| [4176] | 106 | Particle* drawPart = particles; | 
|---|
| [6799] | 107 | this->material.select(); | 
|---|
| [4597] | 108 |  | 
|---|
| [6628] | 109 | GLboolean checkLight = false; | 
|---|
|  | 110 | glGetBooleanv(GL_LIGHTING, &checkLight); | 
|---|
| [6846] | 111 | glPushAttrib(GL_LIGHTING_BIT); | 
|---|
| [6729] | 112 | if (checkLight == GL_TRUE) | 
|---|
|  | 113 | glDisable(GL_LIGHTING); | 
|---|
| [6812] | 114 |  | 
|---|
|  | 115 | glDepthMask(GL_FALSE); | 
|---|
|  | 116 | /* | 
|---|
| [6799] | 117 | glClearDepth(1.0); | 
|---|
|  | 118 | glDepthFunc(GL_LEQUAL); | 
|---|
|  | 119 | glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 
|---|
|  | 120 | glEnable(GL_BLEND); | 
|---|
|  | 121 | glAlphaFunc(GL_GREATER,0.1); | 
|---|
|  | 122 | glEnable(GL_ALPHA_TEST); | 
|---|
|  | 123 | glEnable(GL_TEXTURE_2D); | 
|---|
|  | 124 | glEnable(GL_CULL_FACE); | 
|---|
| [6812] | 125 | */ | 
|---|
| [6799] | 126 | //glDepthMask(GL_FALSE); | 
|---|
|  | 127 | //glBlendFunc(GL_SRC_ALPHA, GL_DST_ALPHA); | 
|---|
| [4338] | 128 |  | 
|---|
| [6729] | 129 | glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 
|---|
| [4338] | 130 |  | 
|---|
| [4597] | 131 |  | 
|---|
| [6621] | 132 | while (likely(drawPart != NULL)) | 
|---|
|  | 133 | { | 
|---|
|  | 134 | glColor4fv(drawPart->color); | 
|---|
|  | 135 | //! @todo implement a faster code for the look-at Camera algorithm. | 
|---|
| [4338] | 136 |  | 
|---|
| [7014] | 137 | const PNode* camera = State::getCameraNode();  //!< @todo MUST be different | 
|---|
| [6621] | 138 | Vector cameraPos = camera->getAbsCoor(); | 
|---|
| [7014] | 139 | Vector cameraTargetPos = State::getCameraTargetNode()->getAbsCoor(); | 
|---|
| [6621] | 140 | Vector view = cameraTargetPos - cameraPos; | 
|---|
|  | 141 | Vector up = Vector(0, 1, 0); | 
|---|
|  | 142 | up = camera->getAbsDir().apply(up); | 
|---|
|  | 143 | Vector h = up.cross(view); | 
|---|
|  | 144 | Vector v = h.cross(view); | 
|---|
|  | 145 | h.normalize(); | 
|---|
|  | 146 | v.normalize(); | 
|---|
|  | 147 | v *= .5 * drawPart->radius; | 
|---|
|  | 148 | h *= .5 * drawPart->radius; | 
|---|
| [4338] | 149 |  | 
|---|
| [6621] | 150 | glBegin(GL_TRIANGLE_STRIP); | 
|---|
|  | 151 | glTexCoord2i(1, 1); | 
|---|
|  | 152 | glVertex3f(drawPart->position.x - h.x - v.x, | 
|---|
|  | 153 | drawPart->position.y - h.y - v.y, | 
|---|
|  | 154 | drawPart->position.z - h.z - v.z); | 
|---|
|  | 155 | glTexCoord2i(0, 1); | 
|---|
|  | 156 | glVertex3f(drawPart->position.x - h.x + v.x, | 
|---|
|  | 157 | drawPart->position.y - h.y + v.y, | 
|---|
|  | 158 | drawPart->position.z - h.z + v.z); | 
|---|
|  | 159 | glTexCoord2i(1, 0); | 
|---|
|  | 160 | glVertex3f(drawPart->position.x + h.x - v.x, | 
|---|
|  | 161 | drawPart->position.y + h.y - v.y, | 
|---|
|  | 162 | drawPart->position.z + h.z - v.z); | 
|---|
|  | 163 | glTexCoord2i(0, 0); | 
|---|
|  | 164 | glVertex3f(drawPart->position.x + h.x + v.x, | 
|---|
|  | 165 | drawPart->position.y + h.y + v.y, | 
|---|
|  | 166 | drawPart->position.z + h.z + v.z); | 
|---|
| [4338] | 167 |  | 
|---|
| [6621] | 168 | glEnd(); | 
|---|
| [4597] | 169 |  | 
|---|
| [6621] | 170 | drawPart = drawPart->next; | 
|---|
| [4663] | 171 | } | 
|---|
| [6812] | 172 | glDepthMask(GL_TRUE); | 
|---|
| [4176] | 173 | glPopAttrib(); | 
|---|
| [3932] | 174 | } | 
|---|