fix(bukkit): 传送功能失效
This commit is contained in:
@@ -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) {
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user