fix(bukkit): 传送功能失效

This commit is contained in:
2023-01-19 12:28:55 +08:00
parent 8e9f97bca7
commit decbe16e98
2 changed files with 48 additions and 15 deletions

View File

@@ -2,7 +2,6 @@ package cn.hamster3.mc.plugin.ball.bukkit.listener;
import cn.hamster3.mc.plugin.ball.bukkit.data.BukkitLocation; import cn.hamster3.mc.plugin.ball.bukkit.data.BukkitLocation;
import cn.hamster3.mc.plugin.ball.common.api.BallAPI; import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
import cn.hamster3.mc.plugin.ball.common.data.BallLocation;
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo; import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType; import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
import cn.hamster3.mc.plugin.ball.common.event.operate.DispatchConsoleCommandEvent; import cn.hamster3.mc.plugin.ball.common.event.operate.DispatchConsoleCommandEvent;
@@ -10,14 +9,17 @@ import cn.hamster3.mc.plugin.ball.common.event.operate.DispatchPlayerCommandEven
import cn.hamster3.mc.plugin.ball.common.event.operate.SendPlayerToLocationEvent; import cn.hamster3.mc.plugin.ball.common.event.operate.SendPlayerToLocationEvent;
import cn.hamster3.mc.plugin.ball.common.event.operate.SendPlayerToPlayerEvent; import cn.hamster3.mc.plugin.ball.common.event.operate.SendPlayerToPlayerEvent;
import cn.hamster3.mc.plugin.ball.common.listener.BallListener; import cn.hamster3.mc.plugin.ball.common.listener.BallListener;
import cn.hamster3.mc.plugin.core.bukkit.api.CoreBukkitAPI;
import cn.hamster3.mc.plugin.core.common.constant.CoreConstantObjects; import cn.hamster3.mc.plugin.core.common.constant.CoreConstantObjects;
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
import cn.hamster3.mc.plugin.core.common.util.Pair;
import net.kyori.adventure.audience.Audience;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority; import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.player.AsyncPlayerChatEvent;
import org.bukkit.event.player.PlayerLoginEvent; import org.bukkit.event.player.PlayerLoginEvent;
import org.bukkit.event.player.PlayerTeleportEvent; import org.bukkit.event.player.PlayerTeleportEvent;
import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.NotNull;
@@ -28,7 +30,7 @@ import java.util.UUID;
public class BallBukkitListener extends BallListener implements Listener { public class BallBukkitListener extends BallListener implements Listener {
public static final BallBukkitListener INSTANCE = new BallBukkitListener(); public static final BallBukkitListener INSTANCE = new BallBukkitListener();
private final HashMap<UUID, Location> playerToLocation = new HashMap<>(); private final HashMap<UUID, Pair<Location, DisplayMessage>> playerToLocation = new HashMap<>();
private BallBukkitListener() { private BallBukkitListener() {
} }
@@ -72,23 +74,41 @@ public class BallBukkitListener extends BallListener implements Listener {
} }
case SendPlayerToLocationEvent.ACTION: { case SendPlayerToLocationEvent.ACTION: {
SendPlayerToLocationEvent event = CoreConstantObjects.GSON.fromJson(info.getContent(), SendPlayerToLocationEvent.class); SendPlayerToLocationEvent event = CoreConstantObjects.GSON.fromJson(info.getContent(), SendPlayerToLocationEvent.class);
BallLocation location = event.getLocation(); BukkitLocation location = new BukkitLocation(event.getLocation());
if (BallAPI.getInstance().isLocalServer(location.getServerID())) { if (BallAPI.getInstance().isLocalServer(location.getServerID())) {
for (UUID uuid : event.getSendPlayerUUID()) { for (UUID uuid : event.getSendPlayerUUID()) {
playerToLocation.put(uuid, new BukkitLocation(location).toBukkitLocation()); Player player = Bukkit.getPlayer(uuid);
if (player != null) {
player.teleport(location.toBukkitLocation());
if (event.getDoneMessage() != null) {
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(player);
event.getDoneMessage().show(audience);
}
} else {
playerToLocation.put(uuid, new Pair<>(location.toBukkitLocation(), event.getDoneMessage()));
}
} }
} }
break; break;
} }
case SendPlayerToPlayerEvent.ACTION: { case SendPlayerToPlayerEvent.ACTION: {
SendPlayerToPlayerEvent event = CoreConstantObjects.GSON.fromJson(info.getContent(), SendPlayerToPlayerEvent.class); SendPlayerToPlayerEvent event = CoreConstantObjects.GSON.fromJson(info.getContent(), SendPlayerToPlayerEvent.class);
Player player = Bukkit.getPlayer(event.getToPlayerUUID()); Player toPlayer = Bukkit.getPlayer(event.getToPlayerUUID());
if (player == null) { if (toPlayer == null) {
return; return;
} }
Location location = player.getLocation(); Location location = toPlayer.getLocation();
for (UUID uuid : event.getSendPlayerUUID()) { for (UUID uuid : event.getSendPlayerUUID()) {
playerToLocation.put(uuid, location); Player player = Bukkit.getPlayer(uuid);
if (player != null) {
player.teleport(location);
if (event.getDoneMessage() != null) {
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(player);
event.getDoneMessage().show(audience);
}
} else {
playerToLocation.put(uuid, new Pair<>(location, event.getDoneMessage()));
}
} }
break; break;
} }
@@ -98,13 +118,14 @@ public class BallBukkitListener extends BallListener implements Listener {
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH) @EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
public void onPlayerLogin(PlayerLoginEvent event) { public void onPlayerLogin(PlayerLoginEvent event) {
Player player = event.getPlayer(); Player player = event.getPlayer();
Location location = playerToLocation.remove(player.getUniqueId()); Pair<Location, DisplayMessage> pair = playerToLocation.remove(player.getUniqueId());
if (location != null) { if (pair != null) {
player.teleport(location, PlayerTeleportEvent.TeleportCause.PLUGIN); player.teleport(pair.getKey(), PlayerTeleportEvent.TeleportCause.PLUGIN);
if (pair.getValue() != null) {
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(player);
pair.getValue().show(audience);
}
} }
} }
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
public void onAsyncPlayerChat(AsyncPlayerChatEvent event) {
}
} }

View File

@@ -93,6 +93,18 @@ public final class BallBungeeCordListener extends BallListener implements Listen
} }
break; break;
} }
case SendPlayerToLocationEvent.ACTION: {
SendPlayerToLocationEvent event = CoreConstantObjects.GSON.fromJson(info.getContent(), SendPlayerToLocationEvent.class);
String serverID = event.getLocation().getServerID();
for (UUID uuid : event.getSendPlayerUUID()) {
ProxiedPlayer player = ProxyServer.getInstance().getPlayer(uuid);
if (player.getServer().getInfo().getName().equals(serverID)) {
continue;
}
player.connect(ProxyServer.getInstance().getServerInfo(serverID));
}
break;
}
} }
} }