X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ftrigger%2Fsecretarea_trigger.cpp;h=69c9d2a232130fa480658e8a2b95eb7851da11af;hb=9e3d8f3cc7a07ab4dae67e86c6f1d0e0e450fa54;hp=b57624c39466302c45ff44fa42d176223587660f;hpb=f41a5719a2dc1a50674c69fa511c38a152cc4b03;p=supertux.git diff --git a/src/trigger/secretarea_trigger.cpp b/src/trigger/secretarea_trigger.cpp index b57624c39..69c9d2a23 100644 --- a/src/trigger/secretarea_trigger.cpp +++ b/src/trigger/secretarea_trigger.cpp @@ -1,26 +1,29 @@ #include #include "secretarea_trigger.h" -#include "utils/lispwriter.h" #include "gameloop.h" +#include "lisp/lisp.h" +#include "lisp/writer.h" #define MESSAGE_TIME 3.5 //TODO: Count numbers of triggered/total secret areas -SecretAreaTrigger::SecretAreaTrigger(LispReader& reader) +SecretAreaTrigger::SecretAreaTrigger(const lisp::Lisp& reader) { - reader.read_float("x", bbox.p1.x); - reader.read_float("y", bbox.p1.y); - bbox.set_size(32, 32); + reader.get("x", bbox.p1.x); + reader.get("y", bbox.p1.y); + float w = 32, h = 32; + reader.get("width", w); + reader.get("height", h); + bbox.set_size(w, h); - reader.read_string("message", message); + reader.get("message", message); message_displayed = false; } -SecretAreaTrigger::SecretAreaTrigger(const Vector& pos) +SecretAreaTrigger::SecretAreaTrigger(const Rectangle& area) { - bbox.set_pos(pos); - bbox.set_size(32, 32); + bbox = area; message = "You found a secret area!"; message_displayed = false; } @@ -30,7 +33,7 @@ SecretAreaTrigger::~SecretAreaTrigger() } void -SecretAreaTrigger::write(LispWriter& writer) +SecretAreaTrigger::write(lisp::Writer& writer) { writer.start_list("secretarea"); @@ -68,3 +71,5 @@ SecretAreaTrigger::event(Player& , EventType type) } } } + +//IMPLEMENT_FACTORY(SecretAreaTrigger, "secretarea_trigger")