aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorClyne Sullivan <tullivan99@gmail.com>2017-10-21 13:50:04 -0400
committerClyne Sullivan <tullivan99@gmail.com>2017-10-21 13:50:04 -0400
commit7644b740e87053838f3c7a80e88ad192fcf1a5e2 (patch)
treedc2ba05afc79b9a75eba1ce52756fb613c83607a
parentad8d35b1398ac798b22175329254f1f0f3428f14 (diff)
lightsgit status! fireflies
-rw-r--r--assets/style/classic/bg/insideWoodHouse.pngbin23738 -> 8078 bytes
-rw-r--r--include/components/all.hpp1
-rw-r--r--include/components/light.hpp26
-rw-r--r--include/systems/light.hpp34
-rw-r--r--src/engine.cpp3
-rw-r--r--src/render.cpp2
-rw-r--r--src/systems/light.cpp60
-rw-r--r--src/world.cpp2
-rw-r--r--xcf/insideWoodHouse.xcfbin42953 -> 12756 bytes
-rw-r--r--xml/entities.xml1
10 files changed, 129 insertions, 0 deletions
diff --git a/assets/style/classic/bg/insideWoodHouse.png b/assets/style/classic/bg/insideWoodHouse.png
index 47d3918..f926cb2 100644
--- a/assets/style/classic/bg/insideWoodHouse.png
+++ b/assets/style/classic/bg/insideWoodHouse.png
Binary files differ
diff --git a/include/components/all.hpp b/include/components/all.hpp
index 7c4e0d1..3c243a7 100644
--- a/include/components/all.hpp
+++ b/include/components/all.hpp
@@ -13,6 +13,7 @@
#include "hit.hpp"
#include "hop.hpp"
#include "itemdrop.hpp"
+#include "light.hpp"
#include "name.hpp"
#include "physics.hpp"
#include "player.hpp"
diff --git a/include/components/light.hpp b/include/components/light.hpp
new file mode 100644
index 0000000..95fe6ec
--- /dev/null
+++ b/include/components/light.hpp
@@ -0,0 +1,26 @@
+#ifndef COMPONENTS_LIGHT_HPP_
+#define COMPONENTS_LIGHT_HPP_
+
+#include <components/base.hpp>
+#include <vector2.hpp>
+#include <color.hpp>
+#include <systems/light.hpp>
+
+struct Illuminate : public Component {
+ int index;
+
+ Illuminate(vec2 pos, float radius, Color color) {
+ index = LightSystem::addLight(pos, radius, color);
+ }
+ Illuminate(XMLElement* imp, XMLElement* def) {
+ fromXML(imp, def);
+ }
+
+ void fromXML(XMLElement* imp, XMLElement* def) final {
+ (void)imp;
+ float radius = def->FloatAttribute("radius");
+ index = LightSystem::addLight(vec2(), radius, Color(1, 1, 0));
+ }
+};
+
+#endif // COMPONENTS_LIGHT_HPP_
diff --git a/include/systems/light.hpp b/include/systems/light.hpp
new file mode 100644
index 0000000..71c541a
--- /dev/null
+++ b/include/systems/light.hpp
@@ -0,0 +1,34 @@
+#ifndef SYSTEM_LIGHT_HPP_
+#define SYSTEM_LIGHT_HPP_
+
+#include <color.hpp>
+#include <render.hpp>
+#include <vector2.hpp>
+
+#include <entityx/entityx.h>
+#include <vector>
+
+struct Light {
+ vec2 pos;
+ float radius;
+ Color color;
+
+ Light(vec2 p = vec2(), float r = 0, Color c = Color())
+ : pos(p), radius(r), color(c) {}
+};
+
+class LightSystem : public entityx::System<LightSystem> {
+private:
+ static std::vector<Light> lights;
+
+public:
+ void update(entityx::EntityManager& en, entityx::EventManager& ev, entityx::TimeDelta dt) override;
+
+ static void render(void);
+
+ static int addLight(vec2 pos, float radius, Color color = Color(1, 1, 1));
+ static void updateLight(int index, vec2 pos, float radius = -1);
+ static void removeLight(int index);
+};
+
+#endif // SYSTEM_LIGHT_HPP_
diff --git a/src/engine.cpp b/src/engine.cpp
index bf0bca9..232d11c 100644
--- a/src/engine.cpp
+++ b/src/engine.cpp
@@ -13,6 +13,7 @@
#include <particle.hpp>
#include <weather.hpp>
#include <attack.hpp>
+#include <systems/light.hpp>
Engine::Engine(void)
: shouldRun(true), systems(game::entities, game::events)
@@ -40,6 +41,7 @@ void Engine::init(void) {
systems.add<AttackSystem>();
systems.add<UISystem>();
+ systems.add<LightSystem>();
systems.add<SDLReceiver>();
systems.configure();
@@ -69,6 +71,7 @@ void Engine::update(entityx::TimeDelta dt)
systems.update<ParticleSystem>(dt);
systems.update<AttackSystem>(dt);
systems.update<RenderSystem>(dt);
+ systems.update<LightSystem>(dt);
//systems.update<UISystem>(dt);
}
diff --git a/src/render.cpp b/src/render.cpp
index 85384ce..f9f84c9 100644
--- a/src/render.cpp
+++ b/src/render.cpp
@@ -7,6 +7,7 @@
#include <glm.hpp>
#include <font.hpp>
#include <texture.hpp>
+#include <systems/light.hpp>
extern vec2 offset;
@@ -198,5 +199,6 @@ void render(const int& fps)
FontSystem::setFontZ();
}
+ LightSystem::render();
WindowSystem::render();
}
diff --git a/src/systems/light.cpp b/src/systems/light.cpp
new file mode 100644
index 0000000..361099d
--- /dev/null
+++ b/src/systems/light.cpp
@@ -0,0 +1,60 @@
+#include <systems/light.hpp>
+
+#include <components/light.hpp>
+#include <components/position.hpp>
+#include <components/solid.hpp>
+
+std::vector<Light> LightSystem::lights;
+
+void LightSystem::update(entityx::EntityManager& en, entityx::EventManager& ev, entityx::TimeDelta dt) {
+ (void)ev;
+ (void)dt;
+
+ en.each<Illuminate, Position, Solid>([&](entityx::Entity e, Illuminate& ill, Position& pos,
+ Solid& dim) {
+ (void)e;
+ vec2 p (pos.x, pos.y);
+ vec2 d (dim.width, dim.height);
+ LightSystem::updateLight(ill.index, p + d / 2);
+ });
+}
+
+void LightSystem::render(void) {
+ auto coords = new GLfloat[lights.size() * 4];
+ auto colors = new GLfloat[lights.size() * 4];
+
+ unsigned int offset = 0;
+ for (const auto& l : lights) {
+ coords[offset] = l.pos.x, coords[offset + 1] = l.pos.y,
+ coords[offset + 2] = 0, coords[offset + 3] = l.radius;
+ colors[offset] = l.color.red, colors[offset + 1] = l.color.green,
+ colors[offset + 2] = l.color.blue, colors[offset + 3] = 1.0f;
+ offset += 4;
+ }
+
+ Render::worldShader.use();
+ Render::worldShader.enable();
+
+ glUniform4fv(Render::worldShader.uniform[WU_light], lights.size(), coords);
+ glUniform4fv(Render::worldShader.uniform[WU_light_color], lights.size(), colors);
+ glUniform1i(Render::worldShader.uniform[WU_light_size], lights.size());
+
+ Render::worldShader.disable();
+ Render::worldShader.unuse();
+}
+
+int LightSystem::addLight(vec2 pos, float radius, Color color) {
+ lights.emplace_back(pos, radius, color);
+ return lights.size() - 1;
+}
+
+void LightSystem::updateLight(int index, vec2 pos, float radius) {
+ lights[index].pos = pos;
+ if (radius >= 0)
+ lights[index].radius = radius;
+}
+
+void LightSystem::removeLight(int index) {
+ lights.erase(lights.begin() + index);
+}
+
diff --git a/src/world.cpp b/src/world.cpp
index b163979..ea2566a 100644
--- a/src/world.cpp
+++ b/src/world.cpp
@@ -371,6 +371,8 @@ void WorldSystem::loader(void)
entity.assign<Trigger>(wxml, abcd);
else if (tname == "Drop")
entity.assign<Drop>(wxml, abcd);
+ else if (tname == "Illuminate")
+ entity.assign<Illuminate>(wxml, abcd);
abcd = abcd->NextSiblingElement();
}
diff --git a/xcf/insideWoodHouse.xcf b/xcf/insideWoodHouse.xcf
index f08dff8..c0a2fcd 100644
--- a/xcf/insideWoodHouse.xcf
+++ b/xcf/insideWoodHouse.xcf
Binary files differ
diff --git a/xml/entities.xml b/xml/entities.xml
index 96c8d79..b95b5a6 100644
--- a/xml/entities.xml
+++ b/xml/entities.xml
@@ -10,6 +10,7 @@
</Sprite>
<Direction />
<Solid />
+ <Illuminate radius="100" />
<Wander>
countdown = 0