diff --git a/src/main/java/de/erethon/dungeonsxl/player/DGamePlayer.java b/src/main/java/de/erethon/dungeonsxl/player/DGamePlayer.java index c04c4ee5..7a7e01c2 100644 --- a/src/main/java/de/erethon/dungeonsxl/player/DGamePlayer.java +++ b/src/main/java/de/erethon/dungeonsxl/player/DGamePlayer.java @@ -692,9 +692,9 @@ public void ready() { ready(GameTypeDefault.DEFAULT); } - public void ready(GameType gameType) { + public boolean ready(GameType gameType) { if (getDGroup() == null) { - return; + return false; } Game game = Game.getByGameWorld(dGroup.getGameWorld()); @@ -708,21 +708,24 @@ public void ready(GameType gameType) { if (!checkRequirements(game)) { MessageUtil.sendMessage(player, DMessage.ERROR_REQUIREMENTS.getMessage()); - return; + return false; } ready = true; + boolean start = true; for (DGroup gameGroup : game.getDGroups()) { if (!gameGroup.isPlaying()) { - gameGroup.startGame(game); - + if (!gameGroup.startGame(game)) { + start = false; + } } else { respawn(); } } game.setStarted(true); + return start; } public void respawn() { diff --git a/src/main/java/de/erethon/dungeonsxl/player/DGroup.java b/src/main/java/de/erethon/dungeonsxl/player/DGroup.java index bd09906e..8b4a663e 100644 --- a/src/main/java/de/erethon/dungeonsxl/player/DGroup.java +++ b/src/main/java/de/erethon/dungeonsxl/player/DGroup.java @@ -758,9 +758,9 @@ public void delete() { plugin.getGlobalProtectionCache().updateGroupSigns(this); } - public void startGame(Game game) { + public boolean startGame(Game game) { if (game == null) { - return; + return false; } game.fetchRules(); GameRuleProvider rules = game.getRules(); @@ -788,7 +788,7 @@ public void startGame(Game game) { } if (!ready) { - return; + return false; } } @@ -796,7 +796,7 @@ public void startGame(Game game) { Bukkit.getPluginManager().callEvent(event); if (event.isCancelled()) { - return; + return false; } playing = true; @@ -872,6 +872,7 @@ public void startGame(Game game) { nextFloor = null; initialLives = rules.getInitialGroupLives(); lives = initialLives; + return true; } public void winGame() { diff --git a/src/main/java/de/erethon/dungeonsxl/sign/lobby/ReadySign.java b/src/main/java/de/erethon/dungeonsxl/sign/lobby/ReadySign.java index 66d75531..d197d008 100644 --- a/src/main/java/de/erethon/dungeonsxl/sign/lobby/ReadySign.java +++ b/src/main/java/de/erethon/dungeonsxl/sign/lobby/ReadySign.java @@ -34,19 +34,19 @@ import org.bukkit.ChatColor; import org.bukkit.block.Sign; import org.bukkit.entity.Player; -import org.bukkit.scheduler.BukkitRunnable; /** * @author Frank Baumann, Milan Albrecht, Daniel Saukel */ public class ReadySign extends DSign { - + private DSignType type = DSignTypeDefault.READY; - + private GameType gameType; private double autoStart = -1; private boolean triggered = false; - + private ProgressBar bar; + public ReadySign(DungeonsXL plugin, Sign sign, String[] lines, DGameWorld gameWorld) { super(plugin, sign, lines, gameWorld); } @@ -78,101 +78,103 @@ public double getTimeToAutoStart() { public void setTimeToAutoStart(double time) { autoStart = time; } - + @Override public boolean check() { return true; } - + @Override public void onInit() { if (plugin.getGameTypeCache().getBySign(this) != null) { gameType = plugin.getGameTypeCache().getBySign(this); - + } else { gameType = GameTypeDefault.CUSTOM; } - + if (!lines[2].isEmpty()) { autoStart = NumberUtil.parseDouble(lines[2], -1); } - + if (!getTriggers().isEmpty()) { getSign().getBlock().setType(VanillaItem.AIR.getMaterial()); return; } - + InteractTrigger trigger = InteractTrigger.getOrCreate(0, getSign().getBlock(), getGameWorld()); if (trigger != null) { trigger.addListener(this); addTrigger(trigger); } - + getSign().setLine(0, ChatColor.DARK_BLUE + "############"); getSign().setLine(1, DMessage.SIGN_READY.getMessage()); getSign().setLine(2, ChatColor.DARK_RED + gameType.getSignName()); getSign().setLine(3, ChatColor.DARK_BLUE + "############"); getSign().update(); } - + @Override public boolean onPlayerTrigger(Player player) { ready(DGamePlayer.getByPlayer(player)); - + if (!triggered && autoStart >= 0) { triggered = true; - - new BukkitRunnable() { - @Override - public void run() { - onTrigger(); - } - }.runTaskLater(plugin, (long) (autoStart * 20)); - + if (!DGroup.getByPlayer(player).isPlaying()) { - new ProgressBar(getGame().getPlayers(), (int) Math.ceil(autoStart)).send(plugin); + bar = new ProgressBar(getGame().getPlayers(), (int) Math.ceil(autoStart)) { + @Override + public void onFinish() { + onTrigger(); + } + }; + bar.send(plugin); } } - + return true; } - + @Override public void onTrigger() { if (getGame() == null) { return; } - + + if (bar != null) { + bar.cancel(); + } + for (Player player : getGame().getPlayers()) { ready(DGamePlayer.getByPlayer(player)); } } - + private void ready(DGamePlayer dPlayer) { - if (dPlayer == null) { + if (dPlayer == null || dPlayer.isReady()) { return; } - - if (dPlayer.isReady()) { - return; - } - + if (getGameWorld().getClassesSigns().isEmpty() || dPlayer.getDClass() != null) { GameType forced = null; if (getGameWorld().getConfig() != null) { forced = getGameWorld().getConfig().getForcedGameType(); } - dPlayer.ready(forced == null ? gameType : forced); + boolean ready = dPlayer.ready(forced == null ? gameType : forced); + if (ready && bar != null) { + bar.cancel(); + } } - + if (dPlayer.isReady()) { MessageUtil.sendMessage(dPlayer.getPlayer(), (dPlayer.isReady() ? DMessage.PLAYER_READY : DMessage.ERROR_READY).getMessage()); } } - + @Override public DSignType getType() { return type; } - + } diff --git a/src/main/java/de/erethon/dungeonsxl/util/ProgressBar.java b/src/main/java/de/erethon/dungeonsxl/util/ProgressBar.java index 7bd730e2..1ef8a5d3 100644 --- a/src/main/java/de/erethon/dungeonsxl/util/ProgressBar.java +++ b/src/main/java/de/erethon/dungeonsxl/util/ProgressBar.java @@ -17,7 +17,6 @@ package de.erethon.dungeonsxl.util; import de.erethon.commons.chat.MessageUtil; -import de.erethon.commons.javaplugin.DREPlugin; import java.util.ArrayList; import java.util.Collection; import java.util.List; @@ -83,12 +82,19 @@ public void run() { } if (secondsLeft == 0) { + onFinish(); cancel(); } else { secondsLeft--; } } + /** + * Method to override to set actions when no seconds are left. + */ + public void onFinish() { + } + /** * Sends the progress bar to a player *