aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorClyne Sullivan <tullivan99@gmail.com>2017-03-23 21:00:40 -0400
committerClyne Sullivan <tullivan99@gmail.com>2017-03-23 21:00:40 -0400
commitc90bfe8ac7c068b33fe4639564286befcc96a91c (patch)
treec933aeb5ba5f59ce68214e9cca9ea563d5f6eb56 /src
parent16836bb93bf57f01f416d3a0a55d0716dcf50c94 (diff)
better arrows
Diffstat (limited to 'src')
-rw-r--r--src/attack.cpp15
-rw-r--r--src/world.cpp2
2 files changed, 16 insertions, 1 deletions
diff --git a/src/attack.cpp b/src/attack.cpp
index 4047b0a..550b849 100644
--- a/src/attack.cpp
+++ b/src/attack.cpp
@@ -49,6 +49,21 @@ void AttackSystem::update(entityx::EntityManager& en, entityx::EventManager& ev,
}
);
break;
+ case AttackType::SmallBoom:
+ en.each<Position, Solid, Health>(
+ [&a](entityx::Entity e, Position& pos, Solid& dim, Health& h) {
+ (void)e;
+ if (e.has_component<Player>())
+ return;
+
+ if (inrange(a.pos.x, pos.x, pos.x + dim.width, shortSlashLength)) {
+ h.health -= a.power;
+ game::engine.getSystem<ParticleSystem>()->addMultiple(15, ParticleType::SmallBlast,
+ [&](){ return vec2(pos.x + dim.width / 2, pos.y + dim.height / 2); }, 300, 7);
+ }
+ }
+ );
+ break;
default:
break;
}
diff --git a/src/world.cpp b/src/world.cpp
index c41ab2a..353f4d9 100644
--- a/src/world.cpp
+++ b/src/world.cpp
@@ -1143,7 +1143,7 @@ void WorldSystem::detect(entityx::TimeDelta dt)
vel.y = 0;
if (e.has_component<Hit>()) {
game::events.emit<AttackEvent>(vec2(loc.x, loc.y),
- AttackType::ShortSlash, e.component<Hit>()->damage);
+ AttackType::SmallBoom, e.component<Hit>()->damage);
e.destroy();
}
if (!vel.grounded) {