X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fbadguy%2Fflame.cpp;h=66ce6d3167fc4d3843543deb49c7b60caa028721;hb=75fc1b8f0bd2cc8ba9f448678d46db1e882b40a9;hp=9acd1c64a1243f9a32eb5292db86b20732685eed;hpb=8eea3ab830de99d82e659474e0f2a60aa18c3bb1;p=supertux.git diff --git a/src/badguy/flame.cpp b/src/badguy/flame.cpp index 9acd1c64a..66ce6d316 100644 --- a/src/badguy/flame.cpp +++ b/src/badguy/flame.cpp @@ -1,12 +1,10 @@ -// $Id$ -// // SuperTux // Copyright (C) 2006 Matthias Braun // -// This program is free software; you can redistribute it and/or -// modify it under the terms of the GNU General Public License -// as published by the Free Software Foundation; either version 2 -// of the License, or (at your option) any later version. +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -14,57 +12,80 @@ // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License -// along with this program; if not, write to the Free Software -// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// along with this program. If not, see . + +#include "badguy/flame.hpp" -#include +#include -#include "flame.hpp" -#include "log.hpp" +#include "audio/sound_manager.hpp" +#include "math/random_generator.hpp" +#include "sprite/sprite.hpp" +#include "sprite/sprite_manager.hpp" +#include "object/sprite_particle.hpp" +#include "supertux/object_factory.hpp" +#include "supertux/sector.hpp" +#include "util/reader.hpp" -static const std::string SOUNDFILE = "sounds/flame.wav"; +static const std::string FLAME_SOUND = "sounds/flame.wav"; -Flame::Flame(const lisp::Lisp& reader) - : BadGuy(reader, "images/creatures/flame/flame.sprite", LAYER_FLOATINGOBJECTS), angle(0), radius(100), speed(2) +Flame::Flame(const Reader& reader) : + BadGuy(reader, "images/creatures/flame/flame.sprite", LAYER_FLOATINGOBJECTS), + angle(0), + radius(100), + speed(2), + light(0.0f,0.0f,0.0f), + lightsprite(SpriteManager::current()->create("images/objects/lightmap_light/lightmap_light-small.sprite")), + sound_source() { reader.get("radius", radius); reader.get("speed", speed); bbox.set_pos(Vector(start_position.x + cos(angle) * radius, start_position.y + sin(angle) * radius)); countMe = false; - sound_manager->preload(SOUNDFILE); -} - -void -Flame::write(lisp::Writer& writer) -{ - writer.start_list("flame"); + SoundManager::current()->preload(FLAME_SOUND); - writer.write_float("x", start_position.x); - writer.write_float("y", start_position.y); - writer.write_float("radius", radius); - writer.write_float("speed", speed); + set_colgroup_active(COLGROUP_TOUCHABLE); - writer.end_list("flame"); + lightsprite->set_blend(Blend(GL_SRC_ALPHA, GL_ONE)); + lightsprite->set_color(Color(0.21f, 0.13f, 0.08f)); } void Flame::active_update(float elapsed_time) { - angle = fmodf(angle + elapsed_time * speed, 2*M_PI); + angle = fmodf(angle + elapsed_time * speed, (float) (2*M_PI)); Vector newpos(start_position.x + cos(angle) * radius, start_position.y + sin(angle) * radius); movement = newpos - get_pos(); sound_source->set_position(get_pos()); + + if (sprite->get_action() == "fade" && sprite->animation_done()) remove_me(); } void -Flame::activate() +Flame::draw(DrawingContext& context) { - set_group(COLGROUP_TOUCHABLE); + //Draw the Sprite. + sprite->draw(context, get_pos(), LAYER_OBJECTS); + //Draw the light if dark + if(true){ + context.get_light( get_bbox().get_middle(), &light ); + if (light.red + light.green < 2.0){ + context.push_target(); + context.set_target(DrawingContext::LIGHTMAP); + sprite->draw(context, get_pos(), layer); + lightsprite->draw(context, get_bbox().get_middle(), 0); + context.pop_target(); + } + } +} - sound_source.reset(sound_manager->create_sound_source(SOUNDFILE)); +void +Flame::activate() +{ + sound_source = SoundManager::current()->create_sound_source(FLAME_SOUND); sound_source->set_position(get_pos()); sound_source->set_looping(true); sound_source->set_gain(2.0); @@ -78,10 +99,28 @@ Flame::deactivate() sound_source.reset(); } + void Flame::kill_fall() { } -IMPLEMENT_FACTORY(Flame, "flame") +void +Flame::freeze() +{ + SoundManager::current()->play("sounds/sizzle.ogg", get_pos()); + sprite->set_action("fade", 1); + Sector::current()->add_object(new SpriteParticle("images/objects/particles/smoke.sprite", "default", bbox.get_middle(), ANCHOR_MIDDLE, Vector(0, -150), Vector(0,0), LAYER_BACKGROUNDTILES+2)); + set_group(COLGROUP_DISABLED); + + // start dead-script + run_dead_script(); +} + +bool +Flame::is_freezable() const +{ + return true; +} +/* EOF */