From c155b43e5189e838c9988a464ca930efb242ee90 Mon Sep 17 00:00:00 2001 From: Clyne Sullivan Date: Mon, 28 Nov 2016 08:42:05 -0500 Subject: entity stop on talk --- src/components.cpp | 34 +++++++++++++++++++++------------- 1 file changed, 21 insertions(+), 13 deletions(-) (limited to 'src') diff --git a/src/components.cpp b/src/components.cpp index d9b9b60..28358be 100644 --- a/src/components.cpp +++ b/src/components.cpp @@ -18,20 +18,24 @@ void MovementSystem::update(entityx::EntityManager &en, entityx::EventManager &e position.x += direction.x * dt; position.y += direction.y * dt; - if (entity.has_component()) { - auto& fl = entity.component()->faceLeft; - if (direction.x != 0) - fl = (direction.x < 0); - } + if (entity.has_component() && entity.component()->talking) { + direction.x = 0; + } else { + if (entity.has_component()) { + auto& fl = entity.component()->faceLeft; + if (direction.x != 0) + fl = (direction.x < 0); + } - if (entity.has_component()) { - auto& countdown = entity.component()->countdown; + if (entity.has_component()) { + auto& countdown = entity.component()->countdown; - if (countdown > 0) { - countdown--; - } else { - countdown = 5000 + randGet() % 10 * 100; - direction.x = (randGet() % 3 - 1) * 0.02f; + if (countdown > 0) { + countdown--; + } else { + countdown = 5000 + randGet() % 10 * 100; + direction.x = (randGet() % 3 - 1) * 0.02f; + } } } }); @@ -152,6 +156,9 @@ void DialogSystem::receive(const MouseClickEvent &mce) auto exml = game::engine.getSystem()->getXML()->FirstChildElement("Dialog"); int newIndex; + if (e.has_component()) + d.talking = true; + if (d.index == 9999) { ui::dialogBox(name.name, "", false, randomDialog[d.rindex % randomDialog.size()]); ui::waitForDialog(); @@ -170,7 +177,6 @@ void DialogSystem::receive(const MouseClickEvent &mce) game::briceUpdate(); } - auto cxml = exml->FirstChildElement("content"); const char *content; if (cxml == nullptr) { @@ -186,6 +192,8 @@ void DialogSystem::receive(const MouseClickEvent &mce) if (exml->QueryIntAttribute("nextid", &newIndex) == XML_NO_ERROR) d.index = newIndex; } + + d.talking = false; }).detach(); } -- cgit v1.2.3