SteamWar/BauSystem
Archiviert
13
0

Detonator on Item Locations #197

Manuell gemergt
YoyoNow hat 6 Commits von multi-detonator nach master 2021-03-07 10:58:31 +01:00 zusammengeführt
4 geänderte Dateien mit 205 neuen und 92 gelöschten Zeilen

Datei anzeigen

@ -108,6 +108,7 @@ public class BauSystem extends JavaPlugin implements Listener {
Bukkit.getPluginManager().registerEvents(new ClipboardListener(), this); Bukkit.getPluginManager().registerEvents(new ClipboardListener(), this);
Bukkit.getPluginManager().registerEvents(new TNTSimulatorListener(), this); Bukkit.getPluginManager().registerEvents(new TNTSimulatorListener(), this);
Bukkit.getPluginManager().registerEvents(new CommandGUI(), this); Bukkit.getPluginManager().registerEvents(new CommandGUI(), this);
Bukkit.getPluginManager().registerEvents(new DetonatorListener(), this);
new AFKStopper(); new AFKStopper();
autoShutdown = Bukkit.getScheduler().runTaskLater(this, Bukkit::shutdown, 1200); autoShutdown = Bukkit.getScheduler().runTaskLater(this, Bukkit::shutdown, 1200);

Datei anzeigen

@ -65,21 +65,19 @@ public class CommandDetonator implements CommandExecutor {
case "item": case "item":
PlayerUtils.giveItemToPlayer(player, Detonator.WAND); PlayerUtils.giveItemToPlayer(player, Detonator.WAND);
player.updateInventory(); player.updateInventory();
Detonator.getDetonator(player);
break; break;
case "remove": case "remove":
Detonator.deleteDetonator(player);
player.getInventory().removeItem(Detonator.WAND); player.getInventory().removeItem(Detonator.WAND);
break; break;
case "detonate": case "detonate":
case "click": case "click":
case "use": case "use":
Detonator.getDetonator(player).execute(); Detonator.execute(player);
break; break;
case "clear": case "clear":
case "delete": case "delete":
case "reset": case "reset":
Detonator.getDetonator(player).clearLocs(); player.getInventory().setItemInMainHand(Detonator.clearDetonator(player.getInventory().getItemInMainHand()));
break; break;
default: default:
help(player); help(player);

Datei anzeigen

@ -25,27 +25,24 @@ import de.steamwar.core.VersionedRunnable;
import net.md_5.bungee.api.ChatMessageType; import net.md_5.bungee.api.ChatMessageType;
import net.md_5.bungee.api.chat.TextComponent; import net.md_5.bungee.api.chat.TextComponent;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.NamespacedKey;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.HandlerList;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.event.player.PlayerQuitEvent;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.ItemMeta; import org.bukkit.inventory.meta.ItemMeta;
import org.bukkit.persistence.PersistentDataContainer;
import org.bukkit.persistence.PersistentDataType;
import java.util.*; import java.util.*;
import java.util.stream.Collectors;
public class Detonator implements Listener { public class Detonator implements Listener {
public static final ItemStack WAND; public static final ItemStack WAND;
private static final Map<Player, Detonator> players = new HashMap<>(); private static final String DETO_PREFIX = "deto-loc-";
private final Set<Detoloader.DetonatorActivation> locs = new HashSet<>();
private final Player player;
public static final Map<Player, Set<Detoloader.DetonatorActivation>> PLAYER_LOCS = new HashMap<>();
static { static {
WAND = new ItemStack(Material.BLAZE_ROD, 1); WAND = new ItemStack(Material.BLAZE_ROD, 1);
@ -53,6 +50,8 @@ public class Detonator implements Listener {
im.setDisplayName("§eFernzünder"); im.setDisplayName("§eFernzünder");
VersionedRunnable.call(new VersionedRunnable(() -> im.getPersistentDataContainer().set(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE, (byte) 1), 15));
List<String> lorelist = Arrays.asList("§eLinks Klick §8- §7Setzte einen Punkt zum Aktivieren", List<String> lorelist = Arrays.asList("§eLinks Klick §8- §7Setzte einen Punkt zum Aktivieren",
"§eLinks Klick + Shift §8- §7Füge einen Punkt hinzu", "§eRechts Klick §8- §7Löse alle Punkte aus"); "§eLinks Klick + Shift §8- §7Füge einen Punkt hinzu", "§eRechts Klick §8- §7Löse alle Punkte aus");
im.setLore(lorelist); im.setLore(lorelist);
@ -60,25 +59,64 @@ public class Detonator implements Listener {
WAND.setItemMeta(im); WAND.setItemMeta(im);
} }
public static Detonator getDetonator(Player player) { public static Detonator getDetonator(Player player, ItemStack item) {
if (!players.containsKey(player)) return VersionedCallable.call(new VersionedCallable<>(() -> {
return new Detonator(player); return new Detonator(player, PLAYER_LOCS.get(player));
return players.get(player); }, 12), new VersionedCallable<>(() -> {
ItemMeta meta = item.getItemMeta();
PersistentDataContainer container = meta.getPersistentDataContainer();
List<int[]> locs = new ArrayList<>();
for (int i = 0; i < 128; i++) {
NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i);
if(container.has(key, PersistentDataType.INTEGER_ARRAY))
locs.add(container.get(key, PersistentDataType.INTEGER_ARRAY));
}
return new Detonator(player, locs.toArray(new int[0][0]));
}, 15));
} }
public Detonator(Player player) { public static ItemStack setLocation(Player player, ItemStack item, Detoloader.DetonatorActivation detoloader) {
this.player = player; return VersionedCallable.call(new VersionedCallable<>(() -> {
Bukkit.getPluginManager().registerEvents(this, BauSystem.getPlugin()); PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).clear();
players.put(player, this); PLAYER_LOCS.get(player).add(detoloader);
return item;
}, 12), new VersionedCallable<>(() -> pushLocToDetonator(clearDetonator(item), detoloader), 15));
} }
public static void deleteDetonator(Player player) { public static ItemStack toggleLocation(ItemStack item, Player player, Detoloader detoloader, Location location) {
if (players.containsKey(player)) if(VersionedCallable.call(new VersionedCallable<>(() -> PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).stream().anyMatch(activation -> activation.location.equals(location)), 12),
HandlerList.unregisterAll(players.remove(player)); new VersionedCallable<>(() -> hasLocation(item, location), 15))) {
DetonatorListener.print(player, detoloader.addBack ? "§e" + detoloader.getBlock() + " entfernt" :
detoloader.getBlock(), Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() - 1);
return VersionedCallable.call(new VersionedCallable<>(() -> {
PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).removeIf(activation -> activation.location.equals(location));
return item;
}, 12), new VersionedCallable<>(() -> removeLocation(item, location), 15));
}else {
DetonatorListener.print(player, detoloader.addBack ? "§e" + detoloader.getBlock() + " hinzugefügt" :
detoloader.getBlock(), Math.min(Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size() + 1, 128));
if(detoloader.getActivation() == 0)
return VersionedCallable.call(new VersionedCallable<>(() -> {
PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).add(new Detoloader.DetonatorActivation(location));
return item;
}, 12), new VersionedCallable<>(() -> pushLocToDetonator(item, new Detoloader.DetonatorActivation(location)), 15));
else
return VersionedCallable.call(new VersionedCallable<>(() -> {
PLAYER_LOCS.computeIfAbsent(player, player1 -> new HashSet<>()).add(new Detoloader.DetonatorActivation(detoloader.getActivation(), location));
return item;
}, 12), new VersionedCallable<>(() -> pushLocToDetonator(item, new Detoloader.DetonatorActivation(detoloader.getActivation(), location)), 15));
}
} }
public void execute() { public static void execute(Player player) {
for (Detoloader.DetonatorActivation activation : getLocations()) { VersionedRunnable.call(new VersionedRunnable(() -> execute(player, PLAYER_LOCS.get(player)), 12), new VersionedRunnable(() -> {
Detonator detonator = getDetonator(player, player.getInventory().getItemInMainHand());
execute(player, detonator.getLocs());
}, 15));
}
private static void execute(Player player, Set<Detoloader.DetonatorActivation> locs) {
for (Detoloader.DetonatorActivation activation : locs) {
if (activation.activation == -1) { if (activation.activation == -1) {
VersionedRunnable.call(new VersionedRunnable(() -> { VersionedRunnable.call(new VersionedRunnable(() -> {
@ -98,87 +136,88 @@ public class Detonator implements Listener {
}, 15)); }, 15));
} }
} }
player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText("§a" + locs.size() + " Punkt" + (locs.size() > 1 ? "e" : "") + " ausgelöst!")); player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText("§e" + locs.size() + " §7Punkt" + (locs.size() > 1 ? "e" : "") + " ausgelöst!"));
Review

Ich fände wichtig, das man weiß wie viele von wie vielen ausgelöst werden. Bzw ausgelöst werden konnten, anhand der Welt.

Ich fände wichtig, das man weiß wie viele von wie vielen ausgelöst werden. Bzw ausgelöst werden konnten, anhand der Welt.
Review

Dass ist nicht sonderlich möglich, da in der 1.12 z.B. ein Armourstand in den Tripwire gespawnt wird, da läst sich relativ schlecht herausfinden, ob dieser jetzt ausgelöst wurde

Dass ist nicht sonderlich möglich, da in der 1.12 z.B. ein Armourstand in den Tripwire gespawnt wird, da läst sich relativ schlecht herausfinden, ob dieser jetzt ausgelöst wurde
Review

Kannst du es denn für die 1.15 einbauen, dass man es da wenigstens weiß?

Kannst du es denn für die 1.15 einbauen, dass man es da wenigstens weiß?
Review

Eben hier noch mit deiner künstlichen Limitierung versucht die 1.15 und 1.12 gleich zu halten, und so etwas vorschlagen, es in 1.15 einzubauen und in 1.12 nicht. Also ja, könnte man machen, aber was würde diese Information dir bringen? Wenn es nicht auslöst, dann wählt man halt neu aus, und wenn es dann trotzdem nicht tut, dann ist das Problem ein anderes.

Eben hier noch mit deiner künstlichen Limitierung versucht die 1.15 und 1.12 gleich zu halten, und so etwas vorschlagen, es in 1.15 einzubauen und in 1.12 nicht. Also ja, könnte man machen, aber was würde diese Information dir bringen? Wenn es nicht auslöst, dann wählt man halt neu aus, und wenn es dann trotzdem nicht tut, dann ist das Problem ein anderes.
Review

Diese Info bringt dir eine Rückmeldung, ob irgendwas nicht geklappt hat

Diese Info bringt dir eine Rückmeldung, ob irgendwas nicht geklappt hat
Review

Diese Rückmeldung bekommst du auch, wenn es nicht so funktioniert wie es soll

Diese Rückmeldung bekommst du auch, wenn es nicht so funktioniert wie es soll
} }
@EventHandler private static int getFreeSlot(ItemStack item) {
public void onPlayerInteract(PlayerInteractEvent event) { ItemMeta meta = item.getItemMeta();
if (!event.getPlayer().equals(player)) PersistentDataContainer container = meta.getPersistentDataContainer();
return; for (int i = 0; i < 128; i++) {
if (!container.has(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i), PersistentDataType.INTEGER_ARRAY))
return i;
}
return -1;
}
if (event.getItem() == null) return; public static ItemStack pushLocToDetonator(ItemStack item, Detoloader.DetonatorActivation detoloader) {
if (event.getItem().isSimilar(WAND)) { int slot = getFreeSlot(item);
event.setCancelled(true); if(slot == -1)
switch (event.getAction()) { throw new SecurityException("Der Detonator ist auf 128 Positionen Limitiert");
Review

Ist diese Limitierung nicht etwas hoch und ich würde dann auch die 1.12 limitieren auf die gleiche Zahl, das der User sich nicht fragt, warum er in der 1.12 mehr Locations bei einem Detonator nehmen kann als in der 1.15.

Ist diese Limitierung nicht etwas hoch und ich würde dann auch die 1.12 limitieren auf die gleiche Zahl, das der User sich nicht fragt, warum er in der 1.12 mehr Locations bei einem Detonator nehmen kann als in der 1.15.
Review

Die Locations sind extra so hoch, dass da nie ein User dran kommen wird. Und wieso sollte man eine künstliche Limitierung einbauen, sind wir hier bei Intel oder was?

Die Locations sind extra so hoch, dass da nie ein User dran kommen wird. Und wieso sollte man eine künstliche Limitierung einbauen, sind wir hier bei Intel oder was?
Review

Dann limitiere bitte dies in der 1.15 auch nicht, danke. Wir sind nämlich nicht bei Intel!

Dann limitiere bitte dies in der 1.15 auch nicht, danke. Wir sind nämlich nicht bei Intel!
Review

In der 1.15 ist es eine pur technische Limitierung, da ich sonst nicht wüsste, wann der Platz für den Detonator aufhört, dass mit dem Intel war eine Anspielung darauf, dass die dafür bekannt sind in ihre Produkte künstliche Limitierungen einzubauen, um das teurere Produkt zu verkaufen.

In der 1.15 ist es eine pur technische Limitierung, da ich sonst nicht wüsste, wann der Platz für den Detonator aufhört, dass mit dem Intel war eine Anspielung darauf, dass die dafür bekannt sind in ihre Produkte künstliche Limitierungen einzubauen, um das teurere Produkt zu verkaufen.
case LEFT_CLICK_BLOCK: ItemMeta meta = item.getItemMeta();
Detoloader detoloader = VersionedCallable.call( Location block = detoloader.location;
new VersionedCallable<>(() -> AutoLoader_12.onPlayerInteractLoader(event), 12), meta.getPersistentDataContainer().set(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + slot), PersistentDataType.INTEGER_ARRAY, new int[]
new VersionedCallable<>(() -> AutoLoader_15.onPlayerInteractLoader(event), 15)); {block.getBlockX(), block.getBlockY(), block.getBlockZ(), detoloader.activation});
item.setItemMeta(meta);
return item;
}
if (detoloader == null) { public static ItemStack clearDetonator(ItemStack item) {
return; ItemMeta meta = item.getItemMeta();
} else if (detoloader.activation == -1) { PersistentDataContainer container = meta.getPersistentDataContainer();
print(detoloader.getBlock(), detoloader.addBack); for (int i = 0; i < 128; i++) {
return; NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i);
} container.remove(key);
}
item.setItemMeta(meta);
return item;
}
public static boolean hasLocation(ItemStack item, Location location) {
return getSlotOfLocation(item, location) != -1;
}
if (event.getPlayer().isSneaking()) { private static int getSlotOfLocation(ItemStack item, Location location) {
if (locs.stream().filter(detonatorActivation -> detonatorActivation.location.equals(event.getClickedBlock().getLocation())).collect(Collectors.toList()).size() == 1) { ItemMeta meta = item.getItemMeta();
locs.removeIf(detonatorActivation -> detonatorActivation.location.equals(event.getClickedBlock().getLocation())); PersistentDataContainer container = meta.getPersistentDataContainer();
print(detoloader.addBack ? "§e" + detoloader.getBlock() + " entfernt" : for (int i = 0; i < 128; i++) {
detoloader.getBlock(), detoloader.addBack); NamespacedKey key = new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + i);
} else { if(container.has(key, PersistentDataType.INTEGER_ARRAY)) {
if (detoloader.getActivation() == 0) { int[] locs = container.get(key, PersistentDataType.INTEGER_ARRAY);
locs.add(new Detoloader.DetonatorActivation(event.getClickedBlock().getLocation())); if(locs[0] == location.getBlockX() && locs[1] == location.getBlockY() && locs[2] == location.getBlockZ())
} else { return i;
locs.add(new Detoloader.DetonatorActivation(detoloader.getActivation(), event.getClickedBlock().getLocation()));
}
print(detoloader.addBack ? "§e" + detoloader.getBlock() + " hinzugefügt" :
detoloader.getBlock(), detoloader.addBack);
}
} else {
locs.clear();
if (detoloader.getActivation() == 0) {
locs.add(new Detoloader.DetonatorActivation(event.getClickedBlock().getLocation()));
} else {
locs.add(new Detoloader.DetonatorActivation(detoloader.getActivation(), event.getClickedBlock().getLocation()));
}
print(detoloader.addBack ? "§e" + detoloader.getBlock() + " gesetzt" :
detoloader.getBlock(), detoloader.addBack);
}
break;
case RIGHT_CLICK_AIR:
case RIGHT_CLICK_BLOCK:
execute();
break;
} }
} }
return -1;
}
public static ItemStack removeLocation(ItemStack item, Location location) {
ItemMeta meta = item.getItemMeta();
PersistentDataContainer container = meta.getPersistentDataContainer();
container.remove(new NamespacedKey(BauSystem.getPlugin(), DETO_PREFIX + getSlotOfLocation(item, location)));
item.setItemMeta(meta);
return item;
}
private Set<Detoloader.DetonatorActivation> locs = new HashSet<>();
private final Player player;
private Detonator(Player player, int[][] activations) {
this.player = player;
for (int[] activation : activations) {
locs.add(new Detoloader.DetonatorActivation(activation[3], new Location(player.getWorld(), activation[0], activation[1], activation[2])));
Review

Dieser dritte Wert sollte nicht gespeichert werden, sondern von der Welt genommen werden, weil warum sollte der Detonator einen ehemaligen Hebel, jetzigen Button, wie ein Hebel aktivieren das verwirrt den User.

Dieser dritte Wert sollte nicht gespeichert werden, sondern von der Welt genommen werden, weil warum sollte der Detonator einen ehemaligen Hebel, jetzigen Button, wie ein Hebel aktivieren das verwirrt den User.
Review

*viert, und ja er muss nicht gespeichert werden, aber die Aktivierung wird öfter ausgeführt als das einspeichern, und hierbei sollte man auf die Prozess last achten, dann muss man nicht bei jedem auslösen, was ca. 128 PRO TICK passieren kann nicht jedes mal neu berechnen.

*viert, und ja er muss nicht gespeichert werden, aber die Aktivierung wird öfter ausgeführt als das einspeichern, und hierbei sollte man auf die Prozess last achten, dann muss man nicht bei jedem auslösen, was ca. 128 PRO TICK passieren kann nicht jedes mal neu berechnen.
}
} }
@EventHandler private Detonator(Player player, Set<Detoloader.DetonatorActivation> locs) {
public void onPlayerQuit(PlayerQuitEvent event) { this.player = player;
if (event.getPlayer().equals(player)) this.locs = locs;
deleteDetonator(player);
} }
Set<Detoloader.DetonatorActivation> getLocations() { public Set<Detoloader.DetonatorActivation> getLocs() {
return locs; return locs;
} }
Player getPlayer() { public Player getPlayer() {
return player; return player;
} }
public void clearLocs() {
locs.clear();
}
void print(String message, boolean withSize) {
if (withSize) {
getPlayer().spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message + " §8" + getLocations().size()));
}else {
getPlayer().spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message));
}
}
} }

Datei anzeigen

@ -0,0 +1,75 @@
package de.steamwar.bausystem.world;
import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.Permission;
import de.steamwar.core.VersionedCallable;
import net.md_5.bungee.api.ChatMessageType;
import net.md_5.bungee.api.chat.TextComponent;
import org.bukkit.NamespacedKey;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerInteractEvent;
import org.bukkit.inventory.ItemStack;
import org.bukkit.persistence.PersistentDataType;
public class DetonatorListener implements Listener {
@EventHandler
public void onPlayerInteract(PlayerInteractEvent event) {
if (event.getItem() == null) return;
if (VersionedCallable.call(new VersionedCallable<>(() -> event.getItem().isSimilar(Detonator.WAND), 12),
new VersionedCallable<>(() -> event.getItem().getItemMeta().getPersistentDataContainer().has(new NamespacedKey(BauSystem.getPlugin(), "deto"), PersistentDataType.BYTE), 15))) {
Player player = event.getPlayer();
if(Welt.noPermission(player, Permission.world)){
player.sendMessage(BauSystem.PREFIX + "§cDu darfst hier nicht den Detonator nutzen");
return;
}
ItemStack item = event.getItem();
event.setCancelled(true);
try {
switch (event.getAction()) {
case LEFT_CLICK_BLOCK:
Detoloader detoloader = VersionedCallable.call(
new VersionedCallable<>(() -> AutoLoader_12.onPlayerInteractLoader(event), 12),
new VersionedCallable<>(() -> AutoLoader_15.onPlayerInteractLoader(event), 15));
if (detoloader == null) {
return;
} else if (detoloader.activation == -1) {
print(player, detoloader.getBlock(), detoloader.addBack?Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size():0);
return;
}
if (event.getPlayer().isSneaking()) {
player.getInventory().setItemInMainHand(Detonator.toggleLocation(item, player, detoloader, event.getClickedBlock().getLocation()));
} else {
if (detoloader.getActivation() == 0) {
player.getInventory().setItemInMainHand(Detonator.setLocation(player, item, new Detoloader.DetonatorActivation(event.getClickedBlock().getLocation())));
} else {
player.getInventory().setItemInMainHand(Detonator.setLocation(player, item, new Detoloader.DetonatorActivation(detoloader.activation, event.getClickedBlock().getLocation())));
}
print(player, detoloader.addBack ? "§e" + detoloader.getBlock() + " gesetzt" :
detoloader.getBlock(), detoloader.addBack?Detonator.getDetonator(player, player.getInventory().getItemInMainHand()).getLocs().size():0);
}
break;
case RIGHT_CLICK_AIR:
case RIGHT_CLICK_BLOCK:
Detonator.execute(player);
break;
}
}catch (RuntimeException e) {
player.sendMessage(BauSystem.PREFIX + "§c" + e.getMessage());
player.getInventory().setItemInMainHand(item);
}
}
}
public static void print(Player player, String message, int size) {
if (size == 0) {
player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message));
}else {
player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message + " §8" + size));
}
}
}