Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'src/render')
-rw-r--r--src/render/particles.cc71
-rw-r--r--src/render/particles.h4
2 files changed, 40 insertions, 35 deletions
diff --git a/src/render/particles.cc b/src/render/particles.cc
index 71ec26b..07a8dc1 100644
--- a/src/render/particles.cc
+++ b/src/render/particles.cc
@@ -188,8 +188,13 @@ ParticleSystem::ParticleSystem(ParticleScript *script, core::Entity *entity, mod
if (particlesystem_script) {
particlesystem_texture = Textures::load("textures/" + particlesystem_script->texture());
+
+ // map entity radius overrules script value
+ if (modelclass->radius())
+ particlesystem_radius = modelclass->radius();
+ else
+ particlesystem_radius = particlesystem_script->radius();
- radius = particlesystem_script->radius();
color.assign(particlesystem_script->color());
}
@@ -310,7 +315,7 @@ void Jet::draw(float elapsed) {
}
f *= f;
- float radius = particlesystem_script->radius() * f;
+ float radius = particlesystem_radius * f;
color.a = f * particlesystem_script->alpha();
gl::color(color);
@@ -369,7 +374,7 @@ void Spray::draw(float elapsed) {
}
f *= f;
- float radius = particlesystem_script->radius() * f;
+ float radius = particlesystem_radius * f;
color.a = f * particlesystem_script->alpha();
gl::color(color);
@@ -437,9 +442,9 @@ void Trail::draw(float elapsed) {
gl::color(color);
glTexCoord2f(0,1);
- gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_radius * fp);
glTexCoord2f(1,1);
- gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_radius * fp);
Stats::quads++;
}
@@ -462,17 +467,17 @@ void Trail::draw(float elapsed) {
gl::color(color);
glTexCoord2f(1,0);
- gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_radius * fp);
glTexCoord2f(0,0);
- gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_radius * fp);
color.a = f * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,1);
- gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_radius * f);
glTexCoord2f(1,1);
- gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_radius * f);
Stats::quads++;
@@ -533,9 +538,9 @@ void Flame::draw(float elapsed) {
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,tp);
- gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_radius * fp);
glTexCoord2f(1,tp);
- gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_radius * fp);
Stats::quads++;
color.a = 0;
@@ -548,9 +553,9 @@ void Flame::draw(float elapsed) {
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,tp);
- gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_radius * fp);
glTexCoord2f(1,tp);
- gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_radius * fp);
Stats::quads++;
color.a = 0;
@@ -563,9 +568,9 @@ void Flame::draw(float elapsed) {
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,tp);
- gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_radius * fp);
glTexCoord2f(1,tp);
- gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_radius * fp);
Stats::quads++;
color.a = 0;
@@ -578,9 +583,9 @@ void Flame::draw(float elapsed) {
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,tp);
- gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_radius * fp);
glTexCoord2f(1,tp);
- gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_radius * fp);
Stats::quads++;
}
@@ -601,61 +606,61 @@ void Flame::draw(float elapsed) {
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(1,tp);
- gl::vertex((*first)->location() + (*first)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() + (*first)->axis().up() * particlesystem_radius * fp);
glTexCoord2f(0,tp);
- gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_radius * fp);
color.a = f * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,t);
- gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_radius * f);
glTexCoord2f(1,t);
- gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_radius * f);
Stats::quads++;
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(1,tp);
- gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_radius * fp);
glTexCoord2f(0,tp);
- gl::vertex((*first)->location() + (*first)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() + (*first)->axis().up() * particlesystem_radius * fp);
color.a = f * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,t);
- gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() + (*next)->axis().up() * particlesystem_radius * f);
glTexCoord2f(1,t);
- gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_radius * f);
Stats::quads++;
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(1,tp);
- gl::vertex((*first)->location() - (*first)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() - (*first)->axis().up() * particlesystem_radius * fp);
glTexCoord2f(0,tp);
- gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() + (*first)->axis().left() * particlesystem_radius * fp);
color.a = f * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,t);
- gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() + (*next)->axis().left() * particlesystem_radius * f);
glTexCoord2f(1,t);
- gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_radius * f);
Stats::quads++;
color.a = fp * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(1,tp);
- gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() - (*first)->axis().left() * particlesystem_radius * fp);
glTexCoord2f(0,tp);
- gl::vertex((*first)->location() - (*first)->axis().up() * particlesystem_script->radius() * fp);
+ gl::vertex((*first)->location() - (*first)->axis().up() * particlesystem_radius * fp);
color.a = f * particlesystem_script->alpha();
gl::color(color);
glTexCoord2f(0,t);
- gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() - (*next)->axis().up() * particlesystem_radius * f);
glTexCoord2f(1,t);
- gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_script->radius() * f);
+ gl::vertex((*next)->location() - (*next)->axis().left() * particlesystem_radius * f);
Stats::quads++;
first = next;
diff --git a/src/render/particles.h b/src/render/particles.h
index 88789a5..096833c 100644
--- a/src/render/particles.h
+++ b/src/render/particles.h
@@ -111,7 +111,7 @@ public:
/// axis of the particle system within the entity
inline const math::Axis &axis() const { return particlesystem_axis; }
-
+
virtual void draw(float elapsed);
void set_timeout(float timeout);
@@ -141,7 +141,7 @@ protected:
math::Vector3f ejector_location;
bool ejector_active;
- float radius;
+ float particlesystem_radius;
float now;
math::Color color;