summaryrefslogtreewikicommitdiff
path: root/src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java
diff options
context:
space:
mode:
authorbobby29831 <bobby29831@gmail.com>2022-05-13 11:51:20 -0500
committerbobby29831 <bobby29831@gmail.com>2022-05-13 11:51:20 -0500
commitcd0f60bd1369fe80b0163c8f85de8540d01b0524 (patch)
tree7b9e498cc4a92afc6a0ec9d315e51400264921d6 /src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java
parentrefactor: clean up reused code (diff)
downloadkenshinshideandseek-cd0f60bd1369fe80b0163c8f85de8540d01b0524.tar.gz
kenshinshideandseek-cd0f60bd1369fe80b0163c8f85de8540d01b0524.tar.bz2
kenshinshideandseek-cd0f60bd1369fe80b0163c8f85de8540d01b0524.zip
refactor: break apart over saturated EventListener.java
Diffstat (limited to 'src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java')
-rw-r--r--src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java54
1 files changed, 54 insertions, 0 deletions
diff --git a/src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java b/src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java
new file mode 100644
index 0000000..61cb784
--- /dev/null
+++ b/src/main/java/net/tylermurphy/hideAndSeek/game/Glow.java
@@ -0,0 +1,54 @@
+package net.tylermurphy.hideAndSeek.game;
+
+import net.tylermurphy.hideAndSeek.util.Packet;
+import org.bukkit.entity.Player;
+
+import static net.tylermurphy.hideAndSeek.configuration.Config.glowLength;
+import static net.tylermurphy.hideAndSeek.configuration.Config.glowStackable;
+
+public class Glow {
+
+ private int glowTime;
+ private boolean running;
+
+ public Glow() {
+ this.glowTime = 0;
+ }
+
+ public void onProjectile() {
+ if (glowStackable) glowTime += glowLength;
+ else glowTime = glowLength;
+ running = true;
+ }
+
+ private void sendPackets() {
+ for (Player hider : Board.getHiders())
+ for (Player seeker : Board.getSeekers())
+ Packet.setGlow(hider, seeker, true);
+ }
+
+ protected void update() {
+ if (running) {
+ sendPackets();
+ glowTime--;
+ glowTime = Math.max(glowTime, 0);
+ if (glowTime == 0) {
+ stopGlow();
+ }
+ }
+ }
+
+ private void stopGlow() {
+ running = false;
+ for (Player hider : Board.getHiders()) {
+ for (Player seeker : Board.getSeekers()) {
+ Packet.setGlow(hider, seeker, false);
+ }
+ }
+ }
+
+ public boolean isRunning() {
+ return running;
+ }
+
+}