13
0

Fix skin overlays
Alle Prüfungen waren erfolgreich
SteamWarCI Build successful

Dieser Commit ist enthalten in:
yoyosource 2022-03-26 13:33:44 +01:00
Ursprung 55b1a26b6a
Commit 14c3be143d
2 geänderte Dateien mit 28 neuen und 16 gelöschten Zeilen

Datei anzeigen

@ -22,8 +22,13 @@ package de.steamwar.lobby.display;
import com.comphenix.tinyprotocol.Reflection; import com.comphenix.tinyprotocol.Reflection;
import com.comphenix.tinyprotocol.TinyProtocol; import com.comphenix.tinyprotocol.TinyProtocol;
import com.mojang.authlib.GameProfile; import com.mojang.authlib.GameProfile;
import net.minecraft.server.v1_15_R1.DataWatcher;
import net.minecraft.server.v1_15_R1.DataWatcherRegistry;
import net.minecraft.server.v1_15_R1.EntityHuman;
import net.minecraft.server.v1_15_R1.PacketPlayOutEntityMetadata;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.craftbukkit.v1_15_R1.entity.CraftPlayer;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import java.lang.reflect.Field; import java.lang.reflect.Field;
@ -108,14 +113,14 @@ public class NPC {
return packet; return packet;
} }
private static Object skinPartsDataWatcherObject = getDataWatcherObject(17, Byte.class); private static Object skinPartsDataWatcherObject = getDataWatcherObject(16, Byte.class);
private final Displayable display; private final Displayable display;
private final int entityId; private final int entityId;
private final UUID uuid; private final UUID uuid;
private final String name; private final String name;
private final Location location; private Location location;
private final Object addPlayerInfo; private final Object addPlayerInfo;
private final Object namedSpawn; private final Object namedSpawn;
@ -156,6 +161,7 @@ public class NPC {
} }
public void setLocation(Location location) { public void setLocation(Location location) {
this.location = location;
byte yaw = (byte)(int)(location.getYaw() * 256.0 / 360.0); byte yaw = (byte)(int)(location.getYaw() * 256.0 / 360.0);
headRotationYaw.set(headRotation, yaw); headRotationYaw.set(headRotation, yaw);
move = movePacketConstructor.invoke(); move = movePacketConstructor.invoke();
@ -178,9 +184,7 @@ public class NPC {
} }
private void show(Player player) { private void show(Player player) {
if (Bukkit.getOnlinePlayers().stream().noneMatch(p -> p.getUniqueId().equals(uuid))) { TinyProtocol.instance.sendPacket(player, addPlayerInfo);
TinyProtocol.instance.sendPacket(player, addPlayerInfo);
}
TinyProtocol.instance.sendPacket(player, namedSpawn); TinyProtocol.instance.sendPacket(player, namedSpawn);
TinyProtocol.instance.sendPacket(player, headRotation); TinyProtocol.instance.sendPacket(player, headRotation);
TinyProtocol.instance.sendPacket(player, skinParts); TinyProtocol.instance.sendPacket(player, skinParts);

Datei anzeigen

@ -37,28 +37,33 @@ import org.bukkit.potion.PotionEffectType;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.logging.Level;
public class TeamPlayer extends BasicListener { public class TeamPlayer extends BasicListener {
private static Map<Entity, NPC> entities = new HashMap<>(); private static final World world = Bukkit.getWorlds().get(0);
private static final Map<String, NPC> entities = new HashMap<>();
public static void spawnTeamPlayer(World world, String name) { public static void spawnTeamPlayer(World world, SteamwarUser steamwarUser) {
Location location = new Location(world, 1524.5, 52, 1481.5); Location location = new Location(world, 1524.5, 52, 1484.5);
NPC npc = new NPC(location, SteamwarUser.get(name).getUUID(), name); String name = steamwarUser.getUserName();
NPC npc = new NPC(location, steamwarUser.getUUID(), name);
Villager villager = (Villager) world.spawnEntity(location, EntityType.VILLAGER); Villager villager = (Villager) world.spawnEntity(location, EntityType.VILLAGER);
villager.setSilent(true); villager.setSilent(true);
villager.setInvulnerable(true); villager.setInvulnerable(true);
villager.addPotionEffect(new PotionEffect(PotionEffectType.INVISIBILITY, Integer.MAX_VALUE, 1, false, false, false)); villager.addPotionEffect(new PotionEffect(PotionEffectType.INVISIBILITY, Integer.MAX_VALUE, 1, false, false, false));
villager.setCustomName(name); villager.setCustomName(name);
villager.setProfession(Villager.Profession.NITWIT); villager.setProfession(Villager.Profession.NITWIT);
entities.put(villager, npc); entities.put(name, npc);
} }
public static void cleanup() { public static void cleanup() {
entities.forEach((entity, npc) -> entity.remove()); forceLoad(world, true);
world.getEntitiesByClasses(Villager.class).forEach(Entity::remove);
forceLoad(world, false);
} }
private void forceLoad(World world, boolean setTo) { private static void forceLoad(World world, boolean setTo) {
for (int x = -10; x < 10; x++) { for (int x = -10; x < 10; x++) {
for (int z = -10; z < 10; z++) { for (int z = -10; z < 10; z++) {
world.setChunkForceLoaded(95 + x , 93 + z, setTo); world.setChunkForceLoaded(95 + x , 93 + z, setTo);
@ -67,18 +72,21 @@ public class TeamPlayer extends BasicListener {
} }
{ {
World world = Bukkit.getWorlds().get(0);
forceLoad(world, true); forceLoad(world, true);
world.getEntitiesByClasses(Villager.class).forEach(Entity::remove); world.getEntitiesByClasses(Villager.class).forEach(Entity::remove);
forceLoad(world, false); forceLoad(world, false);
SteamwarUser.getServerTeam().forEach(user -> { SteamwarUser.getServerTeam().forEach(user -> {
spawnTeamPlayer(world, user.getUserName()); spawnTeamPlayer(world, user);
}); });
LobbySystem.getPlugin().getLogger().log(Level.INFO, "Loaded " + entities.size() + " team players");
Bukkit.getScheduler().runTaskTimer(LobbySystem.getPlugin(), () -> { Bukkit.getScheduler().runTaskTimer(LobbySystem.getPlugin(), () -> {
entities.forEach((entity, npc) -> { world.getEntitiesByClasses(Villager.class).forEach(entity -> {
npc.setLocation(entity.getLocation()); NPC npc = entities.get(entity.getName());
if (npc != null) {
npc.setLocation(entity.getLocation());
}
}); });
}, 1L, 1L); }, 1L, 1L);
} }