X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Ftrigger%2Fsecretarea_trigger.cpp;h=3242f45e98434f7b2befb6d4fa6c4611560f417a;hb=eb9f27869479694c0da2612f346444223296bb22;hp=3b59368d47274b84b24af4cea0284e41167784d6;hpb=1aa0de39a5f87bda1e74d0992848ad5142a850bc;p=supertux.git diff --git a/src/trigger/secretarea_trigger.cpp b/src/trigger/secretarea_trigger.cpp index 3b59368d4..3242f45e9 100644 --- a/src/trigger/secretarea_trigger.cpp +++ b/src/trigger/secretarea_trigger.cpp @@ -1,35 +1,39 @@ -// $Id$ -// // SuperTux -// Copyright (C) 2005 Matthias Braun +// 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 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // 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. -#include +// along with this program. If not, see . + +#include "trigger/secretarea_trigger.hpp" -#include "secretarea_trigger.h" -#include "game_session.h" -#include "lisp/lisp.h" -#include "lisp/writer.h" -#include "object_factory.h" -#include "main.h" +#include "object/tilemap.hpp" +#include "supertux/level.hpp" +#include "supertux/globals.hpp" +#include "supertux/object_factory.hpp" +#include "supertux/resources.hpp" +#include "supertux/sector.hpp" +#include "util/gettext.hpp" +#include "util/reader.hpp" +#include "util/writer.hpp" static const float MESSAGE_TIME=3.5; -//TODO: Count numbers of triggered/total secret areas -SecretAreaTrigger::SecretAreaTrigger(const lisp::Lisp& reader) +SecretAreaTrigger::SecretAreaTrigger(const Reader& reader) : + message_timer(), + message_displayed(), + message(), + fade_tilemap(), + script() { reader.get("x", bbox.p1.x); reader.get("y", bbox.p1.y); @@ -37,15 +41,24 @@ SecretAreaTrigger::SecretAreaTrigger(const lisp::Lisp& reader) reader.get("width", w); reader.get("height", h); bbox.set_size(w, h); - + reader.get("fade-tilemap", fade_tilemap); reader.get("message", message); + if(message == "") { + message = _("You found a secret area!"); + } + reader.get("script", script); + message_displayed = false; } -SecretAreaTrigger::SecretAreaTrigger(const Rect& area) +SecretAreaTrigger::SecretAreaTrigger(const Rectf& area, std::string fade_tilemap_) : + message_timer(), + message_displayed(), + message(_("You found a secret area!")), + fade_tilemap(fade_tilemap_), + script() { bbox = area; - message = "You found a secret area!"; message_displayed = false; } @@ -53,33 +66,25 @@ SecretAreaTrigger::~SecretAreaTrigger() { } -void -SecretAreaTrigger::write(lisp::Writer& writer) +std::string +SecretAreaTrigger::get_fade_tilemap_name() { - writer.start_list("secretarea"); - - writer.write_float("x", bbox.p1.x); - writer.write_float("y", bbox.p1.y); - writer.write_float("width", bbox.get_width()); - writer.write_float("height", bbox.get_height()); - writer.write_string("message", message); - - writer.end_list("secretarea"); + return fade_tilemap; } void SecretAreaTrigger::draw(DrawingContext& context) { - if (message_timer.started()) { - context.push_transform(); - context.set_translation(Vector(0, 0)); - Vector pos = Vector(0, SCREEN_HEIGHT/2 - gold_text->get_height()/2); - context.draw_center_text(gold_text, message, pos, LAYER_GUI); - context.pop_transform(); - } - if (message_timer.check()) { - remove_me(); - } + if (message_timer.started()) { + context.push_transform(); + context.set_translation(Vector(0, 0)); + Vector pos = Vector(0, SCREEN_HEIGHT/2 - Resources::normal_font->get_height()/2); + context.draw_center_text(Resources::normal_font, message, pos, LAYER_HUD, SecretAreaTrigger::text_color); + context.pop_transform(); + } + if (message_timer.check()) { + remove_me(); + } } void @@ -89,8 +94,25 @@ SecretAreaTrigger::event(Player& , EventType type) if (!message_displayed) { message_timer.start(MESSAGE_TIME); message_displayed = true; + Sector::current()->get_level()->stats.secrets++; + + if (fade_tilemap != "") { + // fade away tilemaps + Sector& sector = *Sector::current(); + for(Sector::GameObjects::iterator i = sector.gameobjects.begin(); i != sector.gameobjects.end(); ++i) { + TileMap* tm = dynamic_cast(i->get()); + if (!tm) continue; + if (tm->get_name() != fade_tilemap) continue; + tm->fade(0.0, 1.0); + } + } + + if(script != "") { + std::istringstream stream(script); + Sector::current()->run_script(stream, "SecretAreaScript"); + } } } } -IMPLEMENT_FACTORY(SecretAreaTrigger, "secretarea"); +/* EOF */