SteamWar/BauSystem
Archiviert
13
0

Add CommandAutostartTimer

Dieser Commit ist enthalten in:
yoyosource 2021-04-10 17:43:48 +02:00
Ursprung 2120559bfa
Commit 97fe199ffd
3 geänderte Dateien mit 77 neuen und 2 gelöschten Zeilen

Datei anzeigen

@ -95,6 +95,7 @@ public class BauSystem extends JavaPlugin implements Listener {
new CommandWorldSpawn(); new CommandWorldSpawn();
new CommandRegion(); new CommandRegion();
new CommandSelect(); new CommandSelect();
new CommandAutostartTimer();
VersionedRunnable.call(new VersionedRunnable(() -> { VersionedRunnable.call(new VersionedRunnable(() -> {
if (Region.buildAreaEnabled()) { if (Region.buildAreaEnabled()) {

Datei anzeigen

@ -19,19 +19,85 @@
package de.steamwar.bausystem.commands; package de.steamwar.bausystem.commands;
import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.SWUtils;
import de.steamwar.bausystem.world.TPSUtils;
import de.steamwar.bausystem.world.regions.GlobalRegion;
import de.steamwar.bausystem.world.regions.Region;
import de.steamwar.bausystem.world.regions.RegionExtensionType;
import de.steamwar.bausystem.world.regions.RegionType;
import de.steamwar.command.SWCommand; import de.steamwar.command.SWCommand;
import de.steamwar.inventory.SWItem; import de.steamwar.inventory.SWItem;
import org.bukkit.Bukkit;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityExplodeEvent;
import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import java.text.SimpleDateFormat;
import java.util.Arrays; import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
public class CommandAutostartTimer extends SWCommand { public class CommandAutostartTimer extends SWCommand implements Listener {
public static final ItemStack WAND = new SWItem(Material.BLAZE_ROD, "§eRedstonetester", Arrays.asList("§eRechtsklick Block §8- §7Starte den Timer"), false, null).getItemStack(); public static final ItemStack WAND = new SWItem(Material.BLAZE_ROD, "§eAutostartTimer", Arrays.asList("§eRechtsklick Block §8- §7Starte den Timer"), false, null).getItemStack();
private Map<Region, Long> regionStartTime = new HashMap<>();
public CommandAutostartTimer() { public CommandAutostartTimer() {
super("timer", "autostarttimer", "at"); super("timer", "autostarttimer", "at");
Bukkit.getPluginManager().registerEvents(this, BauSystem.getPlugin());
} }
@Register(help = true)
public void genericHelp(Player p, String... args) {
p.sendMessage("§8/§etimer §8- §7Legt den AutostartTimer ins Inventar");
}
@Register
public void genericCommand(Player p) {
SWUtils.giveItemToPlayer(p, WAND);
}
@EventHandler
public void onPlayerInteract(PlayerInteractEvent event) {
if (!WAND.isSimilar(event.getItem())) {
return;
}
if (event.getClickedBlock() == null) {
return;
}
Player player = event.getPlayer();
Region region = Region.getRegion(event.getClickedBlock().getLocation());
if (GlobalRegion.isGlobalRegion(region)) {
player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner Region");
return;
}
if (!region.hasTestblock()) {
player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner Region");
return;
}
if (regionStartTime.containsKey(region)) {
player.sendMessage(BauSystem.PREFIX + "§eDer AutostartTimer wurde zurückgesetzt");
} else {
player.sendMessage(BauSystem.PREFIX + "§eAutostartTimer gestartet");
}
regionStartTime.put(region, TPSUtils.currentTick.get());
}
@EventHandler
public void onEntityExplode(EntityExplodeEvent event) {
event.blockList().forEach(block -> {
Region region = Region.getRegion(block.getLocation());
if (!regionStartTime.containsKey(region)) return;
if (!region.hasTestblock()) return;
if (!region.inRegion(block.getLocation(), RegionType.TESTBLOCK, RegionExtensionType.EXTENSION)) return;
RegionUtils.message(region, BauSystem.PREFIX + "§eZeit §7bis zur §eExplosion §7am Gegner§8:§e " + new SimpleDateFormat("mm:ss SSSS").format(new Date((TPSUtils.currentTick.get() - regionStartTime.remove(region)) * 50)));
});
}
} }

Datei anzeigen

@ -39,4 +39,12 @@ public class RegionUtils {
} }
} }
public static void message(Region region, String s) {
if (GlobalRegion.isGlobalRegion(region)) {
Bukkit.getOnlinePlayers().stream().filter(player -> Region.getRegion(player.getLocation()) == null).forEach(player -> player.sendMessage(s));
} else {
Bukkit.getOnlinePlayers().stream().filter(player -> region.inRegion(player.getLocation(), RegionType.NORMAL, RegionExtensionType.NORMAL)).forEach(player -> player.sendMessage(s));
}
}
} }