diff options
author | Stijn Buys <ingar@osirion.org> | 2008-05-02 13:05:03 +0000 |
---|---|---|
committer | Stijn Buys <ingar@osirion.org> | 2008-05-02 13:05:03 +0000 |
commit | 3dedab035c98772fd9607480bddc8ffd9d7dc799 (patch) | |
tree | 2d346751841dd85e9bf0edc421469239fead10c7 /src/render | |
parent | 36ce28a7557c4b2b73316621471558354024ca54 (diff) |
additional light properties
Diffstat (limited to 'src/render')
-rw-r--r-- | src/render/draw.cc | 40 |
1 files changed, 17 insertions, 23 deletions
diff --git a/src/render/draw.cc b/src/render/draw.cc index 741eb3d..3fe64a5 100644 --- a/src/render/draw.cc +++ b/src/render/draw.cc @@ -287,9 +287,6 @@ void draw_pass_default() if (!entity->model()) { gl::push(); gl::translate(entity->location()); - - // FIXME - //gl::rotate(entity->direction(), 0.0f, 0.0f, 1.0f ); gl::multmatrix(entity->axis()); if ((entity->flags() & core::Entity::Bright) == core::Entity::Bright) @@ -392,12 +389,10 @@ void draw_pass_model_lights() gl::begin(gl::Quads); - - for (std::map<unsigned int, core::Entity *>::iterator it=core::Entity::registry.begin(); it != core::Entity::registry.end(); it++) { core::Entity *entity = (*it).second; - if ( test_drawfx_distance(entity) && (entity->model()->model_light.size())) { + if (test_drawfx_distance(entity) && (entity->model()->model_light.size())) { for (std::list<core::Light *>::iterator lit = entity->model()->model_light.begin(); lit != entity->model()->model_light.end(); lit++) { // strobe frequency @@ -405,27 +400,26 @@ void draw_pass_model_lights() if ((*lit)->strobe()) t = (core::application()->time() + entity->fuzz() + (*lit)->offset()) * (*lit)->frequency(); - if (!(*lit)->strobe() || (( t - floorf(t)) < 0.5f)) { + if (!(*lit)->strobe() || (( t - floorf(t)) <= (*lit)->time())) { math::Vector3f location = entity->location() + (entity->axis() * (*lit)->location()); - float n = dotproduct(camera_axis.forward(), (camera_eye-location)); float light_size = 0.0625 * (*lit)->radius(); - if (n < 0) { - math::Color color((*lit)->color()); - color.a = fabs(-atanf(n) * 2 / M_PI); - gl::color(color); + + math::Color color((*lit)->color()); + color.a = 0.8; + gl::color(color); + + glTexCoord2f(0,1); + gl::vertex(location + (camera_axis.up() - camera_axis.left()) * light_size); + glTexCoord2f(0,0); + gl::vertex(location + (camera_axis.up() + camera_axis.left()) * light_size); + glTexCoord2f(-1,0); + gl::vertex(location + (camera_axis.up() * -1 + camera_axis.left()) * light_size); + glTexCoord2f(-1,1); + gl::vertex(location + (camera_axis.up() * -1 - camera_axis.left()) * light_size); + + Stats::quads++; - glTexCoord2f(0,1); - gl::vertex(location + (camera_axis.up() - camera_axis.left()) * light_size); - glTexCoord2f(0,0); - gl::vertex(location + (camera_axis.up() + camera_axis.left()) * light_size); - glTexCoord2f(-1,0); - gl::vertex(location + (camera_axis.up() * -1 + camera_axis.left()) * light_size); - glTexCoord2f(-1,1); - gl::vertex(location + (camera_axis.up() * -1 - camera_axis.left()) * light_size); - - Stats::quads++; - } } } } |