From af2b41da0738df10ccf6244f5ff6d1e9094838e8 Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Fri, 10 Jul 2015 16:24:02 +1000 Subject: [PATCH] Add basic sendTitle / resetTitle API. More APIs to follow pending feedback of whether this is the preferred implementation. Methods marked as deprecated and subject to change, but work as is. By: Jofkos --- .../craftbukkit/entity/CraftPlayer.java | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java index 813adbba37..abc135ea34 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java @@ -21,6 +21,7 @@ import java.util.logging.Level; import java.util.logging.Logger; import net.minecraft.server.*; +import net.minecraft.server.PacketPlayOutTitle.EnumTitleAction; import org.apache.commons.lang.Validate; import org.apache.commons.lang.NotImplementedException; @@ -1326,4 +1327,23 @@ public class CraftPlayer extends CraftHumanEntity implements Player { Preconditions.checkArgument(getGameMode() == GameMode.SPECTATOR, "Player must be in spectator mode"); getHandle().setSpectatorTarget((entity == null) ? null : ((CraftEntity) entity).getHandle()); } + + @Override + public void sendTitle(String title, String subtitle) { + if (title != null) { + PacketPlayOutTitle packetTitle = new PacketPlayOutTitle(EnumTitleAction.TITLE, CraftChatMessage.fromString(title)[0]); + getHandle().playerConnection.sendPacket(packetTitle); + } + + if (subtitle != null) { + PacketPlayOutTitle packetSubtitle = new PacketPlayOutTitle(EnumTitleAction.SUBTITLE, CraftChatMessage.fromString(subtitle)[0]); + getHandle().playerConnection.sendPacket(packetSubtitle); + } + } + + @Override + public void resetTitle() { + PacketPlayOutTitle packetReset = new PacketPlayOutTitle(EnumTitleAction.RESET, null); + getHandle().playerConnection.sendPacket(packetReset); + } }