aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClyne Sullivan <tullivan99@gmail.com>2017-04-27 21:28:33 -0400
committerClyne Sullivan <tullivan99@gmail.com>2017-04-27 21:28:33 -0400
commit00de7a4b0aa48c3cb42c45e0f203902ca034b94c (patch)
treee364575a000af4a9c65b2e43f5ec565bb2df4bf8
parentef1ea79375ce865d78fb7da4244aee65d25c04b3 (diff)
important textls
-rw-r--r--assets/music/town.oggbin0 -> 3159813 bytes
-rw-r--r--include/components.hpp16
-rw-r--r--include/ui.hpp2
-rw-r--r--main.cpp4
-rw-r--r--src/components.cpp32
-rw-r--r--src/ui.cpp22
-rw-r--r--src/world.cpp2
-rw-r--r--xml/!town.xml2
-rw-r--r--xml/entities.xml9
9 files changed, 76 insertions, 13 deletions
diff --git a/assets/music/town.ogg b/assets/music/town.ogg
new file mode 100644
index 0000000..0cbe3a7
--- /dev/null
+++ b/assets/music/town.ogg
Binary files differ
diff --git a/include/components.hpp b/include/components.hpp
index dafb859..87d4293 100644
--- a/include/components.hpp
+++ b/include/components.hpp
@@ -623,6 +623,22 @@ struct Hit : public Component {
}
};
+struct Trigger : public Component {
+ Trigger(const std::string& t)
+ : text(t) {}
+ Trigger(XMLElement* imp, XMLElement* def) {
+ fromXML(imp, def);
+ }
+
+ std::string text;
+
+ void fromXML(XMLElement* imp, XMLElement* def) final {
+ (void)imp;
+ (void)def;
+ text = "You got me!";
+ }
+};
+
/**
* SYSTEMS
*/
diff --git a/include/ui.hpp b/include/ui.hpp
index 456c88a..3f0a67f 100644
--- a/include/ui.hpp
+++ b/include/ui.hpp
@@ -126,6 +126,8 @@ namespace ui {
*/
void takeScreenshot(GLubyte *pixels);
+
+ bool handleGLEvent(SDL_Event& e);
}
#endif // UI_HPP_
diff --git a/main.cpp b/main.cpp
index 967050c..a934b40 100644
--- a/main.cpp
+++ b/main.cpp
@@ -166,8 +166,10 @@ int main(int argc, char *argv[])
Render::render(fps);
SDL_Event e;
- while (SDL_PollEvent(&e))
+ while (SDL_PollEvent(&e)) {
+ ui::handleGLEvent(e);
eventQueue.push_back(e);
+ }
}
// on game end, get back together
diff --git a/src/components.cpp b/src/components.cpp
index d89e195..dcb1551 100644
--- a/src/components.cpp
+++ b/src/components.cpp
@@ -50,11 +50,9 @@ void MovementSystem::update(entityx::EntityManager &en, entityx::EventManager &e
fl = (direction.x < 0);
}
- // make the entity wander
- // TODO initialX and range?
- if (entity.has_component<Aggro>()) {
- auto ppos = game::engine.getSystem<PlayerSystem>()->getPosition();
- if (ppos.x > position.x && ppos.x < position.x + entity.component<Solid>()->width) {
+ auto ppos = game::engine.getSystem<PlayerSystem>()->getPosition();
+ if (ppos.x > position.x && ppos.x < position.x + entity.component<Solid>()->width) {
+ if (entity.has_component<Aggro>()) {
auto dim = entity.component<Solid>();
ev.emit<AttackEvent>(vec2(position.x + dim->width, position.y + dim->height),
AttackType::ShortSlash, false);
@@ -64,9 +62,27 @@ void MovementSystem::update(entityx::EntityManager &en, entityx::EventManager &e
toFight = entity;
h = 0;
}*/
- } else
- direction.x = (ppos.x > position.x) ? .01 : -.01;
- } else if (entity.has_component<Wander>()) {
+ } else if (entity.has_component<Trigger>()) {
+ static bool triggering = false;
+ if (!triggering) {
+ triggering = true;
+ std::thread([&](entityx::Entity e) {
+ UISystem::fadeToggle();
+ UISystem::waitForCover();
+ UISystem::dialogImportant(e.component<Trigger>()->text);
+ UISystem::waitForDialog();
+ UISystem::fadeToggle();
+ e.destroy();
+ triggering = false;
+ }, entity).detach();
+ }
+ return;
+ }
+ }
+
+ // make the entity wander
+ // TODO initialX and range?
+ if (entity.has_component<Wander>()) {
auto& countdown = entity.component<Wander>()->countdown;
if (countdown > 0) {
diff --git a/src/ui.cpp b/src/ui.cpp
index fc815f2..d14b0a6 100644
--- a/src/ui.cpp
+++ b/src/ui.cpp
@@ -618,6 +618,20 @@ namespace ui {
fclose(bmp);
}
+
+ bool handleGLEvent(SDL_Event& e) {
+ switch (e.type) {
+ case SDL_MOUSEBUTTONDOWN:
+ if ((UISystem::isDialog() | pageTexReady) && (e.button.button & SDL_BUTTON_RIGHT))
+ UISystem::advanceDialog();
+ return true;
+ break;
+ default:
+ break;
+ }
+
+ return false;
+ }
}
using namespace ui;
@@ -658,8 +672,6 @@ void InputSystem::receive(const MainSDLEvent& event)
case SDL_MOUSEBUTTONDOWN:
ev.emit<MouseClickEvent>(mouse, e.button.button);
- UISystem::advanceDialog();
-
if (UISystem::isDialog() || pageTexReady) {
if ((e.button.button & SDL_BUTTON_RIGHT))
UISystem::advanceDialog();
@@ -974,6 +986,10 @@ void UISystem::render(void)
}
if (!importantText.empty()) {
- putStringCentered(offset, importantText);
+ FontSystem::setFontSize(24);
+ FontSystem::setFontZ(-9.0f);
+ putStringCentered(vec2(offset.x, 400), importantText);
+ FontSystem::setFontZ(-6.0f);
+ FontSystem::setFontSize(16);
}
}
diff --git a/src/world.cpp b/src/world.cpp
index 648507a..e251706 100644
--- a/src/world.cpp
+++ b/src/world.cpp
@@ -389,6 +389,8 @@ void WorldSystem::load(const std::string& file)
entity.assign<Aggro>(wxml, abcd);
else if (tname == "Animation")
entity.assign<Animate>(wxml, abcd);
+ else if (tname == "Trigger")
+ entity.assign<Trigger>(wxml, abcd);
abcd = abcd->NextSiblingElement();
}
diff --git a/xml/!town.xml b/xml/!town.xml
index e3fb946..32f696a 100644
--- a/xml/!town.xml
+++ b/xml/!town.xml
@@ -2,7 +2,7 @@
<include file="entities.xml"/>
<World>
- <style background="0" bgm="assets/music/embark.wav" folder="assets/style/classic/"/>
+ <style background="0" bgm="assets/music/town.ogg" folder="assets/style/classic/"/>
<generation width="320"/>
<weather>Sunny</weather>
<link right="!town2.xml"/>
diff --git a/xml/entities.xml b/xml/entities.xml
index a1b5f5c..c557361 100644
--- a/xml/entities.xml
+++ b/xml/entities.xml
@@ -67,6 +67,8 @@
<Physics />
<Name value="SKIRL" />
<Wander />
+ <!--<Aggro arena="arena.xml" />-->
+ <Trigger />
</skirl>
<structure>
@@ -93,3 +95,10 @@
<Solid />
<Grounded />
</chest>
+
+<trigger>
+ <Position value="200.0,100.0" />
+ <Direction />
+ <Solid value="1.0,1.0" />
+ <Trigger />
+</trigger>