mirror of
https://github.com/filoghost/HolographicDisplays.git
synced 2025-01-04 23:27:36 +01:00
1.9.4 update
This commit is contained in:
parent
5f2ddc6ae1
commit
afa3ed6691
HolographicDisplays
@ -138,6 +138,10 @@ public class HolographicDisplays extends JavaPlugin {
|
|||||||
is18orGreater = true;
|
is18orGreater = true;
|
||||||
is19orGreater = true;
|
is19orGreater = true;
|
||||||
nmsManager = new com.gmail.filoghost.holographicdisplays.nms.v1_9_R1.NmsManagerImpl();
|
nmsManager = new com.gmail.filoghost.holographicdisplays.nms.v1_9_R1.NmsManagerImpl();
|
||||||
|
} else if ("v1_9_R2".equals(version)) {
|
||||||
|
is18orGreater = true;
|
||||||
|
is19orGreater = true;
|
||||||
|
nmsManager = new com.gmail.filoghost.holographicdisplays.nms.v1_9_R2.NmsManagerImpl();
|
||||||
} else {
|
} else {
|
||||||
printWarnAndDisable(
|
printWarnAndDisable(
|
||||||
"******************************************************",
|
"******************************************************",
|
||||||
|
@ -0,0 +1,68 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
import org.bukkit.EntityEffect;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.CraftServer;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftArmorStand;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.util.EulerAngle;
|
||||||
|
import org.bukkit.util.Vector;
|
||||||
|
|
||||||
|
public class CraftNMSArmorStand extends CraftArmorStand {
|
||||||
|
|
||||||
|
public CraftNMSArmorStand(CraftServer server, EntityNMSArmorStand entity) {
|
||||||
|
super(server, entity);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disallow all the bukkit methods.
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void remove() {
|
||||||
|
// Cannot be removed, this is the most important to override.
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods from Armor stand class
|
||||||
|
@Override public void setArms(boolean arms) { }
|
||||||
|
@Override public void setBasePlate(boolean basePlate) { }
|
||||||
|
@Override public void setBodyPose(EulerAngle pose) { }
|
||||||
|
@Override public void setBoots(ItemStack item) { }
|
||||||
|
@Override public void setChestplate(ItemStack item) { }
|
||||||
|
@Override public void setGravity(boolean gravity) { }
|
||||||
|
@Override public void setHeadPose(EulerAngle pose) { }
|
||||||
|
@Override public void setHelmet(ItemStack item) { }
|
||||||
|
@Override public void setItemInHand(ItemStack item) { }
|
||||||
|
@Override public void setLeftArmPose(EulerAngle pose) { }
|
||||||
|
@Override public void setLeftLegPose(EulerAngle pose) { }
|
||||||
|
@Override public void setLeggings(ItemStack item) { }
|
||||||
|
@Override public void setRightArmPose(EulerAngle pose) { }
|
||||||
|
@Override public void setRightLegPose(EulerAngle pose) { }
|
||||||
|
@Override public void setSmall(boolean small) { }
|
||||||
|
@Override public void setVisible(boolean visible) { }
|
||||||
|
@Override public void setMarker(boolean marker) { }
|
||||||
|
|
||||||
|
// Methods from LivingEntity class
|
||||||
|
@Override public boolean addPotionEffect(PotionEffect effect) { return false; }
|
||||||
|
@Override public boolean addPotionEffect(PotionEffect effect, boolean param) { return false; }
|
||||||
|
@Override public boolean addPotionEffects(Collection<PotionEffect> effects) { return false; }
|
||||||
|
@Override public void setRemoveWhenFarAway(boolean remove) { }
|
||||||
|
|
||||||
|
// Methods from Entity
|
||||||
|
@Override public void setVelocity(Vector vel) { }
|
||||||
|
@Override public boolean teleport(Location loc) { return false; }
|
||||||
|
@Override public boolean teleport(Entity entity) { return false; }
|
||||||
|
@Override public boolean teleport(Location loc, TeleportCause cause) { return false; }
|
||||||
|
@Override public boolean teleport(Entity entity, TeleportCause cause) { return false; }
|
||||||
|
@Override public void setFireTicks(int ticks) { }
|
||||||
|
@Override public boolean setPassenger(Entity entity) { return false; }
|
||||||
|
@Override public boolean eject() { return false; }
|
||||||
|
@Override public boolean leaveVehicle() { return false; }
|
||||||
|
@Override public void playEffect(EntityEffect effect) { }
|
||||||
|
@Override public void setCustomName(String name) { }
|
||||||
|
@Override public void setCustomNameVisible(boolean flag) { }
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,43 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import org.bukkit.EntityEffect;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.CraftServer;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftItem;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
import org.bukkit.util.Vector;
|
||||||
|
|
||||||
|
public class CraftNMSItem extends CraftItem {
|
||||||
|
|
||||||
|
public CraftNMSItem(CraftServer server, EntityNMSItem entity) {
|
||||||
|
super(server, entity);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disallow all the bukkit methods.
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void remove() {
|
||||||
|
// Cannot be removed, this is the most important to override.
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods from Entity
|
||||||
|
@Override public void setVelocity(Vector vel) { }
|
||||||
|
@Override public boolean teleport(Location loc) { return false; }
|
||||||
|
@Override public boolean teleport(Entity entity) { return false; }
|
||||||
|
@Override public boolean teleport(Location loc, TeleportCause cause) { return false; }
|
||||||
|
@Override public boolean teleport(Entity entity, TeleportCause cause) { return false; }
|
||||||
|
@Override public void setFireTicks(int ticks) { }
|
||||||
|
@Override public boolean setPassenger(Entity entity) { return false; }
|
||||||
|
@Override public boolean eject() { return false; }
|
||||||
|
@Override public boolean leaveVehicle() { return false; }
|
||||||
|
@Override public void playEffect(EntityEffect effect) { }
|
||||||
|
@Override public void setCustomName(String name) { }
|
||||||
|
@Override public void setCustomNameVisible(boolean flag) { }
|
||||||
|
|
||||||
|
// Methods from Item
|
||||||
|
@Override public void setItemStack(ItemStack stack) { }
|
||||||
|
@Override public void setPickupDelay(int delay) { }
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,50 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
import org.bukkit.EntityEffect;
|
||||||
|
import org.bukkit.Location;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.CraftServer;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftSlime;
|
||||||
|
import org.bukkit.entity.Entity;
|
||||||
|
import org.bukkit.event.player.PlayerTeleportEvent.TeleportCause;
|
||||||
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
import org.bukkit.util.Vector;
|
||||||
|
|
||||||
|
public class CraftNMSSlime extends CraftSlime {
|
||||||
|
|
||||||
|
public CraftNMSSlime(CraftServer server, EntityNMSSlime entity) {
|
||||||
|
super(server, entity);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disallow all the bukkit methods.
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void remove() {
|
||||||
|
// Cannot be removed, this is the most important to override.
|
||||||
|
}
|
||||||
|
|
||||||
|
// Methods from LivingEntity class
|
||||||
|
@Override public boolean addPotionEffect(PotionEffect effect) { return false; }
|
||||||
|
@Override public boolean addPotionEffect(PotionEffect effect, boolean param) { return false; }
|
||||||
|
@Override public boolean addPotionEffects(Collection<PotionEffect> effects) { return false; }
|
||||||
|
@Override public void setRemoveWhenFarAway(boolean remove) { }
|
||||||
|
|
||||||
|
// Methods from Entity
|
||||||
|
@Override public void setVelocity(Vector vel) { }
|
||||||
|
@Override public boolean teleport(Location loc) { return false; }
|
||||||
|
@Override public boolean teleport(Entity entity) { return false; }
|
||||||
|
@Override public boolean teleport(Location loc, TeleportCause cause) { return false; }
|
||||||
|
@Override public boolean teleport(Entity entity, TeleportCause cause) { return false; }
|
||||||
|
@Override public void setFireTicks(int ticks) { }
|
||||||
|
@Override public boolean setPassenger(Entity entity) { return false; }
|
||||||
|
@Override public boolean eject() { return false; }
|
||||||
|
@Override public boolean leaveVehicle() { return false; }
|
||||||
|
@Override public void playEffect(EntityEffect effect) { }
|
||||||
|
@Override public void setCustomName(String name) { }
|
||||||
|
@Override public void setCustomNameVisible(boolean flag) { }
|
||||||
|
|
||||||
|
// Methods from Slime
|
||||||
|
@Override public void setSize(int size) { }
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,231 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import net.minecraft.server.v1_9_R2.AxisAlignedBB;
|
||||||
|
import net.minecraft.server.v1_9_R2.DamageSource;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityArmorStand;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityHuman;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityPlayer;
|
||||||
|
import net.minecraft.server.v1_9_R2.EnumHand;
|
||||||
|
import net.minecraft.server.v1_9_R2.EnumInteractionResult;
|
||||||
|
import net.minecraft.server.v1_9_R2.EnumItemSlot;
|
||||||
|
import net.minecraft.server.v1_9_R2.ItemStack;
|
||||||
|
import net.minecraft.server.v1_9_R2.NBTTagCompound;
|
||||||
|
import net.minecraft.server.v1_9_R2.PacketPlayOutEntityTeleport;
|
||||||
|
import net.minecraft.server.v1_9_R2.SoundEffect;
|
||||||
|
import net.minecraft.server.v1_9_R2.Vec3D;
|
||||||
|
import net.minecraft.server.v1_9_R2.World;
|
||||||
|
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftEntity;
|
||||||
|
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSArmorStand;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftHologramLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.Utils;
|
||||||
|
|
||||||
|
public class EntityNMSArmorStand extends EntityArmorStand implements NMSArmorStand {
|
||||||
|
|
||||||
|
private boolean lockTick;
|
||||||
|
private CraftHologramLine parentPiece;
|
||||||
|
|
||||||
|
public EntityNMSArmorStand(World world, CraftHologramLine parentPiece) {
|
||||||
|
super(world);
|
||||||
|
super.setInvisible(true);
|
||||||
|
super.setSmall(true);
|
||||||
|
super.setArms(false);
|
||||||
|
super.setGravity(true);
|
||||||
|
super.setBasePlate(true);
|
||||||
|
super.setMarker(true);
|
||||||
|
this.parentPiece = parentPiece;
|
||||||
|
forceSetBoundingBox(new NullBoundingBox());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void b(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean c(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean d(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NBTTagCompound e(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return nbttagcompound;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void f(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not load NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not load NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isInvulnerable(DamageSource source) {
|
||||||
|
/*
|
||||||
|
* The field Entity.invulnerable is private.
|
||||||
|
* It's only used while saving NBTTags, but since the entity would be killed
|
||||||
|
* on chunk unload, we prefer to override isInvulnerable().
|
||||||
|
*/
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isCollidable() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCustomName(String customName) {
|
||||||
|
// Locks the custom name.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCustomNameVisible(boolean visible) {
|
||||||
|
// Locks the custom name.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EnumInteractionResult a(EntityHuman human, Vec3D vec3d, ItemStack itemstack, EnumHand enumhand) {
|
||||||
|
// Prevent stand being equipped
|
||||||
|
return EnumInteractionResult.PASS;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean c(int i, ItemStack item) {
|
||||||
|
// Prevent stand being equipped
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setSlot(EnumItemSlot enumitemslot, ItemStack itemstack) {
|
||||||
|
// Prevent stand being equipped
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(AxisAlignedBB boundingBox) {
|
||||||
|
// Do not change it!
|
||||||
|
}
|
||||||
|
|
||||||
|
public void forceSetBoundingBox(AxisAlignedBB boundingBox) {
|
||||||
|
super.a(boundingBox);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getId() {
|
||||||
|
|
||||||
|
StackTraceElement[] elements = Thread.currentThread().getStackTrace();
|
||||||
|
if (elements.length > 2 && elements[2] != null && elements[2].getFileName().equals("EntityTrackerEntry.java") && elements[2].getLineNumber() > 142 && elements[2].getLineNumber() < 152) {
|
||||||
|
// Then this method is being called when creating a new packet, we return a fake ID!
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void m() {
|
||||||
|
if (!lockTick) {
|
||||||
|
super.m();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(SoundEffect soundeffect, float f, float f1) {
|
||||||
|
// Remove sounds.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCustomNameNMS(String name) {
|
||||||
|
if (name != null && name.length() > 300) {
|
||||||
|
name = name.substring(0, 300);
|
||||||
|
}
|
||||||
|
super.setCustomName(name);
|
||||||
|
super.setCustomNameVisible(name != null && !name.isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getCustomNameNMS() {
|
||||||
|
return super.getCustomName();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void callSuperTick() {
|
||||||
|
super.h();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setLockTick(boolean lock) {
|
||||||
|
lockTick = lock;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void die() {
|
||||||
|
// Prevent being killed.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CraftEntity getBukkitEntity() {
|
||||||
|
if (super.bukkitEntity == null) {
|
||||||
|
super.bukkitEntity = new CraftNMSArmorStand(super.world.getServer(), this);
|
||||||
|
}
|
||||||
|
return super.bukkitEntity;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void killEntityNMS() {
|
||||||
|
super.dead = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setLocationNMS(double x, double y, double z) {
|
||||||
|
super.setPosition(x, y, z);
|
||||||
|
|
||||||
|
// Send a packet near to update the position.
|
||||||
|
PacketPlayOutEntityTeleport teleportPacket = new PacketPlayOutEntityTeleport(this);
|
||||||
|
|
||||||
|
for (Object obj : super.world.players) {
|
||||||
|
if (obj instanceof EntityPlayer) {
|
||||||
|
EntityPlayer nmsPlayer = (EntityPlayer) obj;
|
||||||
|
|
||||||
|
double distanceSquared = Utils.square(nmsPlayer.locX - super.locX) + Utils.square(nmsPlayer.locZ - super.locZ);
|
||||||
|
if (distanceSquared < 8192 && nmsPlayer.playerConnection != null) {
|
||||||
|
nmsPlayer.playerConnection.sendPacket(teleportPacket);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isDeadNMS() {
|
||||||
|
return super.dead;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getIdNMS() {
|
||||||
|
return super.getId(); // Return the real ID without checking the stack trace.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CraftHologramLine getHologramLine() {
|
||||||
|
return parentPiece;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public org.bukkit.entity.Entity getBukkitEntityNMS() {
|
||||||
|
return getBukkitEntity();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,267 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import net.minecraft.server.v1_9_R2.Entity;
|
||||||
|
import net.minecraft.server.v1_9_R2.Blocks;
|
||||||
|
import net.minecraft.server.v1_9_R2.DamageSource;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityHuman;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityItem;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityPlayer;
|
||||||
|
import net.minecraft.server.v1_9_R2.ItemStack;
|
||||||
|
import net.minecraft.server.v1_9_R2.NBTTagCompound;
|
||||||
|
import net.minecraft.server.v1_9_R2.NBTTagList;
|
||||||
|
import net.minecraft.server.v1_9_R2.NBTTagString;
|
||||||
|
import net.minecraft.server.v1_9_R2.PacketPlayOutMount;
|
||||||
|
import net.minecraft.server.v1_9_R2.World;
|
||||||
|
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftEntity;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.inventory.CraftItemStack;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import com.gmail.filoghost.holographicdisplays.listener.MainListener;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSEntityBase;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSItem;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftItemLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.DebugHandler;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.ItemUtils;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.ReflectionUtils;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.Utils;
|
||||||
|
|
||||||
|
public class EntityNMSItem extends EntityItem implements NMSItem {
|
||||||
|
|
||||||
|
private boolean lockTick;
|
||||||
|
private CraftItemLine parentPiece;
|
||||||
|
|
||||||
|
private int resendMountPacketTicks;
|
||||||
|
|
||||||
|
public EntityNMSItem(World world, CraftItemLine piece) {
|
||||||
|
super(world);
|
||||||
|
super.pickupDelay = Integer.MAX_VALUE;
|
||||||
|
this.parentPiece = piece;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void m() {
|
||||||
|
|
||||||
|
// So it won't get removed.
|
||||||
|
ticksLived = 0;
|
||||||
|
|
||||||
|
if (resendMountPacketTicks++ > 20) {
|
||||||
|
resendMountPacketTicks = 0;
|
||||||
|
|
||||||
|
if (bz() != null) {
|
||||||
|
// Send a packet near to "remind" players that the item is riding the armor stand (Spigot bug or client bug)
|
||||||
|
PacketPlayOutMount mountPacket = new PacketPlayOutMount(bz());
|
||||||
|
|
||||||
|
for (Object obj : super.world.players) {
|
||||||
|
if (obj instanceof EntityPlayer) {
|
||||||
|
EntityPlayer nmsPlayer = (EntityPlayer) obj;
|
||||||
|
|
||||||
|
double distanceSquared = Utils.square(nmsPlayer.locX - super.locX) + Utils.square(nmsPlayer.locZ - super.locZ);
|
||||||
|
if (distanceSquared < 1024 && nmsPlayer.playerConnection != null) {
|
||||||
|
nmsPlayer.playerConnection.sendPacket(mountPacket);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!lockTick) {
|
||||||
|
super.m();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack getItemStack() {
|
||||||
|
// Dirty method to check if the icon is being picked up
|
||||||
|
StackTraceElement[] stacktrace = Thread.currentThread().getStackTrace();
|
||||||
|
if (stacktrace.length > 2 && stacktrace[2].getClassName().contains("EntityInsentient")) {
|
||||||
|
return null; // Try to pickup this, dear entity ignoring the pickupDelay!
|
||||||
|
}
|
||||||
|
|
||||||
|
return super.getItemStack();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Method called when a player is near.
|
||||||
|
@Override
|
||||||
|
public void d(EntityHuman human) {
|
||||||
|
|
||||||
|
if (human.locY < super.locY - 1.5 || human.locY > super.locY + 1.0) {
|
||||||
|
// Too low or too high, it's a bit weird.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parentPiece.getPickupHandler() != null && human instanceof EntityPlayer) {
|
||||||
|
MainListener.handleItemLinePickup((Player) human.getBukkitEntity(), parentPiece.getPickupHandler(), parentPiece.getParent());
|
||||||
|
// It is never added to the inventory.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void b(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean c(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean d(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NBTTagCompound e(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return nbttagcompound;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void f(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not load NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not load NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isInvulnerable(DamageSource source) {
|
||||||
|
/*
|
||||||
|
* The field Entity.invulnerable is private.
|
||||||
|
* It's only used while saving NBTTags, but since the entity would be killed
|
||||||
|
* on chunk unload, we prefer to override isInvulnerable().
|
||||||
|
*/
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isCollidable() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void inactiveTick() {
|
||||||
|
// Check inactive ticks.
|
||||||
|
|
||||||
|
if (!lockTick) {
|
||||||
|
super.inactiveTick();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setLockTick(boolean lock) {
|
||||||
|
lockTick = lock;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void die() {
|
||||||
|
// Prevent being killed.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CraftEntity getBukkitEntity() {
|
||||||
|
if (super.bukkitEntity == null) {
|
||||||
|
super.bukkitEntity = new CraftNMSItem(super.world.getServer(), this);
|
||||||
|
}
|
||||||
|
return super.bukkitEntity;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isDeadNMS() {
|
||||||
|
return super.dead;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void killEntityNMS() {
|
||||||
|
super.dead = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setLocationNMS(double x, double y, double z) {
|
||||||
|
super.setPosition(x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setItemStackNMS(org.bukkit.inventory.ItemStack stack) {
|
||||||
|
ItemStack newItem = CraftItemStack.asNMSCopy(stack);
|
||||||
|
|
||||||
|
if (newItem == null) {
|
||||||
|
newItem = new ItemStack(Blocks.BEDROCK);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (newItem.getTag() == null) {
|
||||||
|
newItem.setTag(new NBTTagCompound());
|
||||||
|
}
|
||||||
|
NBTTagCompound display = newItem.getTag().getCompound("display");
|
||||||
|
|
||||||
|
if (!newItem.getTag().hasKey("display")) {
|
||||||
|
newItem.getTag().set("display", display);
|
||||||
|
}
|
||||||
|
|
||||||
|
NBTTagList tagList = new NBTTagList();
|
||||||
|
tagList.add(new NBTTagString(ItemUtils.ANTISTACK_LORE)); // Antistack lore
|
||||||
|
|
||||||
|
display.set("Lore", tagList);
|
||||||
|
newItem.count = 0;
|
||||||
|
setItemStack(newItem);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getIdNMS() {
|
||||||
|
return super.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CraftItemLine getHologramLine() {
|
||||||
|
return parentPiece;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void allowPickup(boolean pickup) {
|
||||||
|
if (pickup) {
|
||||||
|
super.pickupDelay = 0;
|
||||||
|
} else {
|
||||||
|
super.pickupDelay = Integer.MAX_VALUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public org.bukkit.entity.Entity getBukkitEntityNMS() {
|
||||||
|
return getBukkitEntity();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setPassengerOfNMS(NMSEntityBase vehicleBase) {
|
||||||
|
if (vehicleBase == null || !(vehicleBase instanceof Entity)) {
|
||||||
|
// It should never dismount
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Entity entity = (Entity) vehicleBase;
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (super.bz() != null) {
|
||||||
|
Entity oldVehicle = super.bz();
|
||||||
|
ReflectionUtils.setPrivateField(Entity.class, this, "at", null);
|
||||||
|
oldVehicle.passengers.remove(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReflectionUtils.setPrivateField(Entity.class, this, "at", entity);
|
||||||
|
entity.passengers.clear();
|
||||||
|
entity.passengers.add(this);
|
||||||
|
|
||||||
|
} catch (Exception ex) {
|
||||||
|
DebugHandler.handleDebugException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object getRawItemStack() {
|
||||||
|
return super.getItemStack();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,229 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityDamageSource;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityPlayer;
|
||||||
|
import net.minecraft.server.v1_9_R2.AxisAlignedBB;
|
||||||
|
import net.minecraft.server.v1_9_R2.DamageSource;
|
||||||
|
import net.minecraft.server.v1_9_R2.Entity;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntitySlime;
|
||||||
|
import net.minecraft.server.v1_9_R2.NBTTagCompound;
|
||||||
|
import net.minecraft.server.v1_9_R2.PacketPlayOutMount;
|
||||||
|
import net.minecraft.server.v1_9_R2.SoundEffect;
|
||||||
|
import net.minecraft.server.v1_9_R2.World;
|
||||||
|
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftEntity;
|
||||||
|
import org.bukkit.event.player.PlayerInteractEntityEvent;
|
||||||
|
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSEntityBase;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSSlime;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftHologramLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftTouchSlimeLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.DebugHandler;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.ReflectionUtils;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.Utils;
|
||||||
|
|
||||||
|
public class EntityNMSSlime extends EntitySlime implements NMSSlime {
|
||||||
|
|
||||||
|
private boolean lockTick;
|
||||||
|
private CraftTouchSlimeLine parentPiece;
|
||||||
|
|
||||||
|
private int resendMountPacketTicks;
|
||||||
|
|
||||||
|
public EntityNMSSlime(World world, CraftTouchSlimeLine parentPiece) {
|
||||||
|
super(world);
|
||||||
|
super.persistent = true;
|
||||||
|
a(0.0F, 0.0F);
|
||||||
|
setSize(1);
|
||||||
|
setInvisible(true);
|
||||||
|
this.parentPiece = parentPiece;
|
||||||
|
forceSetBoundingBox(new NullBoundingBox());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(AxisAlignedBB boundingBox) {
|
||||||
|
// Do not change it!
|
||||||
|
}
|
||||||
|
|
||||||
|
public void forceSetBoundingBox(AxisAlignedBB boundingBox) {
|
||||||
|
super.a(boundingBox);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void m() {
|
||||||
|
|
||||||
|
// So it won't get removed.
|
||||||
|
ticksLived = 0;
|
||||||
|
|
||||||
|
if (resendMountPacketTicks++ > 20) {
|
||||||
|
resendMountPacketTicks = 0;
|
||||||
|
|
||||||
|
if (bz() != null) {
|
||||||
|
// Send a packet near to "remind" players that the slime is riding the armor stand (Spigot bug or client bug)
|
||||||
|
PacketPlayOutMount mountPacket = new PacketPlayOutMount(bz());
|
||||||
|
|
||||||
|
for (Object obj : super.world.players) {
|
||||||
|
if (obj instanceof EntityPlayer) {
|
||||||
|
EntityPlayer nmsPlayer = (EntityPlayer) obj;
|
||||||
|
|
||||||
|
double distanceSquared = Utils.square(nmsPlayer.locX - super.locX) + Utils.square(nmsPlayer.locZ - super.locZ);
|
||||||
|
if (distanceSquared < 1024 && nmsPlayer.playerConnection != null) {
|
||||||
|
nmsPlayer.playerConnection.sendPacket(mountPacket);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!lockTick) {
|
||||||
|
super.m();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void b(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean c(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean d(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NBTTagCompound e(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not save NBT.
|
||||||
|
return nbttagcompound;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void f(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not load NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(NBTTagCompound nbttagcompound) {
|
||||||
|
// Do not load NBT.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean damageEntity(DamageSource damageSource, float amount) {
|
||||||
|
if (damageSource instanceof EntityDamageSource) {
|
||||||
|
EntityDamageSource entityDamageSource = (EntityDamageSource) damageSource;
|
||||||
|
if (entityDamageSource.getEntity() instanceof EntityPlayer) {
|
||||||
|
Bukkit.getPluginManager().callEvent(new PlayerInteractEntityEvent(((EntityPlayer) entityDamageSource.getEntity()).getBukkitEntity(), getBukkitEntity())); // Bukkit takes care of the exceptions
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isInvulnerable(DamageSource source) {
|
||||||
|
/*
|
||||||
|
* The field Entity.invulnerable is private.
|
||||||
|
* It's only used while saving NBTTags, but since the entity would be killed
|
||||||
|
* on chunk unload, we prefer to override isInvulnerable().
|
||||||
|
*/
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isCollidable() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCustomName(String customName) {
|
||||||
|
// Locks the custom name.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setCustomNameVisible(boolean visible) {
|
||||||
|
// Locks the custom name.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void a(SoundEffect soundeffect, float f, float f1) {
|
||||||
|
// Remove sounds.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setLockTick(boolean lock) {
|
||||||
|
lockTick = lock;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void die() {
|
||||||
|
// Prevent being killed.
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CraftEntity getBukkitEntity() {
|
||||||
|
if (super.bukkitEntity == null) {
|
||||||
|
super.bukkitEntity = new CraftNMSSlime(super.world.getServer(), this);
|
||||||
|
}
|
||||||
|
return super.bukkitEntity;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isDeadNMS() {
|
||||||
|
return super.dead;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void killEntityNMS() {
|
||||||
|
super.dead = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setLocationNMS(double x, double y, double z) {
|
||||||
|
super.setPosition(x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getIdNMS() {
|
||||||
|
return super.getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CraftHologramLine getHologramLine() {
|
||||||
|
return parentPiece;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public org.bukkit.entity.Entity getBukkitEntityNMS() {
|
||||||
|
return getBukkitEntity();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setPassengerOfNMS(NMSEntityBase vehicleBase) {
|
||||||
|
if (vehicleBase == null || !(vehicleBase instanceof Entity)) {
|
||||||
|
// It should never dismount
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Entity entity = (Entity) vehicleBase;
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (super.bz() != null) {
|
||||||
|
Entity oldVehicle = super.bz();
|
||||||
|
ReflectionUtils.setPrivateField(Entity.class, this, "at", null);
|
||||||
|
oldVehicle.passengers.remove(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReflectionUtils.setPrivateField(Entity.class, this, "at", entity);
|
||||||
|
entity.passengers.clear();
|
||||||
|
entity.passengers.add(this);
|
||||||
|
|
||||||
|
} catch (Exception ex) {
|
||||||
|
DebugHandler.handleDebugException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,170 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import net.minecraft.server.v1_9_R2.IChatBaseComponent;
|
||||||
|
import net.minecraft.server.v1_9_R2.PacketPlayOutChat;
|
||||||
|
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
|
|
||||||
|
import com.google.gson.stream.JsonWriter;
|
||||||
|
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftPlayer;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.FancyMessage;
|
||||||
|
|
||||||
|
public class FancyMessageImpl implements FancyMessage {
|
||||||
|
|
||||||
|
private List<MessagePart> messageParts;
|
||||||
|
|
||||||
|
public FancyMessageImpl(String firstPartText) {
|
||||||
|
messageParts = new ArrayList<MessagePart>();
|
||||||
|
messageParts.add(new MessagePart(firstPartText));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl color(ChatColor color) {
|
||||||
|
if (!color.isColor()) {
|
||||||
|
throw new IllegalArgumentException(color.name() + " is not a color");
|
||||||
|
}
|
||||||
|
latest().color = color;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl style(ChatColor... styles) {
|
||||||
|
for (ChatColor style : styles) {
|
||||||
|
if (!style.isFormat()) {
|
||||||
|
throw new IllegalArgumentException(style.name() + " is not a style");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
latest().styles = styles;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl file(String path) {
|
||||||
|
onClick("open_file", path);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl link(String url) {
|
||||||
|
onClick("open_url", url);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl suggest(String command) {
|
||||||
|
onClick("suggest_command", command);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl command(String command) {
|
||||||
|
onClick("run_command", command);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl tooltip(String text) {
|
||||||
|
onHover("show_text", text);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessageImpl then(Object obj) {
|
||||||
|
messageParts.add(new MessagePart(obj.toString()));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toJSONString() {
|
||||||
|
StringWriter stringWriter = new StringWriter();
|
||||||
|
JsonWriter json = new JsonWriter(stringWriter);
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (messageParts.size() == 1) {
|
||||||
|
latest().writeJson(json);
|
||||||
|
} else {
|
||||||
|
json.beginObject().name("text").value("").name("extra").beginArray();
|
||||||
|
for (MessagePart part : messageParts) {
|
||||||
|
part.writeJson(json);
|
||||||
|
}
|
||||||
|
json.endArray().endObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new RuntimeException("invalid message");
|
||||||
|
}
|
||||||
|
return stringWriter.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void send(Player player) {
|
||||||
|
((CraftPlayer) player).getHandle().playerConnection.sendPacket(new PacketPlayOutChat(IChatBaseComponent.ChatSerializer.a(toJSONString())));
|
||||||
|
}
|
||||||
|
|
||||||
|
private MessagePart latest() {
|
||||||
|
return messageParts.get(messageParts.size() - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onClick(String name, String data) {
|
||||||
|
MessagePart latest = latest();
|
||||||
|
latest.clickActionName = name;
|
||||||
|
latest.clickActionData = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onHover(String name, String data) {
|
||||||
|
MessagePart latest = latest();
|
||||||
|
latest.hoverActionName = name;
|
||||||
|
latest.hoverActionData = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
static class MessagePart {
|
||||||
|
|
||||||
|
public ChatColor color = null;
|
||||||
|
public ChatColor[] styles = null;
|
||||||
|
public String clickActionName = null;
|
||||||
|
public String clickActionData = null;
|
||||||
|
public String hoverActionName = null;
|
||||||
|
public String hoverActionData = null;
|
||||||
|
public final String text;
|
||||||
|
|
||||||
|
public MessagePart(final String text) {
|
||||||
|
this.text = text;
|
||||||
|
}
|
||||||
|
|
||||||
|
public JsonWriter writeJson(final JsonWriter json) throws IOException {
|
||||||
|
json.beginObject().name("text").value(text);
|
||||||
|
if (color != null) {
|
||||||
|
json.name("color").value(color.name().toLowerCase());
|
||||||
|
}
|
||||||
|
if (styles != null) {
|
||||||
|
for (final ChatColor style : styles) {
|
||||||
|
json.name(style == ChatColor.UNDERLINE ? "underlined" : style.name().toLowerCase()).value(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (clickActionName != null && clickActionData != null) {
|
||||||
|
json.name("clickEvent")
|
||||||
|
.beginObject()
|
||||||
|
.name("action").value(clickActionName)
|
||||||
|
.name("value").value(clickActionData)
|
||||||
|
.endObject();
|
||||||
|
}
|
||||||
|
if (hoverActionName != null && hoverActionData != null) {
|
||||||
|
json.name("hoverEvent")
|
||||||
|
.beginObject()
|
||||||
|
.name("action").value(hoverActionName)
|
||||||
|
.name("value").value(hoverActionData)
|
||||||
|
.endObject();
|
||||||
|
}
|
||||||
|
return json.endObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,152 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
|
||||||
|
import net.minecraft.server.v1_9_R2.Entity;
|
||||||
|
import net.minecraft.server.v1_9_R2.EntityTypes;
|
||||||
|
import net.minecraft.server.v1_9_R2.MathHelper;
|
||||||
|
import net.minecraft.server.v1_9_R2.World;
|
||||||
|
import net.minecraft.server.v1_9_R2.WorldServer;
|
||||||
|
|
||||||
|
import org.apache.commons.lang.NotImplementedException;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.CraftWorld;
|
||||||
|
import org.bukkit.craftbukkit.v1_9_R2.entity.CraftEntity;
|
||||||
|
import org.bukkit.inventory.ItemStack;
|
||||||
|
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.FancyMessage;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.NMSManager;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSArmorStand;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSEntityBase;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSHorse;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSItem;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.nms.interfaces.entity.NMSWitherSkull;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftHologramLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftItemLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.object.line.CraftTouchSlimeLine;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.DebugHandler;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.ReflectionUtils;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.Validator;
|
||||||
|
import com.gmail.filoghost.holographicdisplays.util.VersionUtils;
|
||||||
|
|
||||||
|
public class NmsManagerImpl implements NMSManager {
|
||||||
|
|
||||||
|
private Method validateEntityMethod;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setup() throws Exception {
|
||||||
|
registerCustomEntity(EntityNMSArmorStand.class, "ArmorStand", 30);
|
||||||
|
registerCustomEntity(EntityNMSItem.class, "Item", 1);
|
||||||
|
registerCustomEntity(EntityNMSSlime.class, "Slime", 55);
|
||||||
|
|
||||||
|
validateEntityMethod = World.class.getDeclaredMethod("b", Entity.class);
|
||||||
|
validateEntityMethod.setAccessible(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("rawtypes")
|
||||||
|
public void registerCustomEntity(Class entityClass, String name, int id) throws Exception {
|
||||||
|
if (VersionUtils.isMCPCOrCauldron()) {
|
||||||
|
// MCPC+ / Cauldron entity registration.
|
||||||
|
throw new UnsupportedOperationException("MCPC, Cauldron and similar softwares are not supported");
|
||||||
|
} else {
|
||||||
|
// Normal entity registration.
|
||||||
|
ReflectionUtils.putInPrivateStaticMap(EntityTypes.class, "d", entityClass, name);
|
||||||
|
ReflectionUtils.putInPrivateStaticMap(EntityTypes.class, "f", entityClass, Integer.valueOf(id));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NMSHorse spawnNMSHorse(org.bukkit.World world, double x, double y, double z, CraftHologramLine parentPiece) {
|
||||||
|
throw new NotImplementedException("Method can only be used on 1.7 or lower");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NMSWitherSkull spawnNMSWitherSkull(org.bukkit.World bukkitWorld, double x, double y, double z, CraftHologramLine parentPiece) {
|
||||||
|
throw new NotImplementedException("Method can only be used on 1.7 or lower");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NMSItem spawnNMSItem(org.bukkit.World bukkitWorld, double x, double y, double z, CraftItemLine parentPiece, ItemStack stack) {
|
||||||
|
WorldServer nmsWorld = ((CraftWorld) bukkitWorld).getHandle();
|
||||||
|
EntityNMSItem customItem = new EntityNMSItem(nmsWorld, parentPiece);
|
||||||
|
customItem.setLocationNMS(x, y, z);
|
||||||
|
customItem.setItemStackNMS(stack);
|
||||||
|
if (!addEntityToWorld(nmsWorld, customItem)) {
|
||||||
|
DebugHandler.handleSpawnFail(parentPiece);
|
||||||
|
}
|
||||||
|
return customItem;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public EntityNMSSlime spawnNMSSlime(org.bukkit.World bukkitWorld, double x, double y, double z, CraftTouchSlimeLine parentPiece) {
|
||||||
|
WorldServer nmsWorld = ((CraftWorld) bukkitWorld).getHandle();
|
||||||
|
EntityNMSSlime touchSlime = new EntityNMSSlime(nmsWorld, parentPiece);
|
||||||
|
touchSlime.setLocationNMS(x, y, z);
|
||||||
|
if (!addEntityToWorld(nmsWorld, touchSlime)) {
|
||||||
|
DebugHandler.handleSpawnFail(parentPiece);
|
||||||
|
}
|
||||||
|
return touchSlime;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NMSArmorStand spawnNMSArmorStand(org.bukkit.World world, double x, double y, double z, CraftHologramLine parentPiece) {
|
||||||
|
WorldServer nmsWorld = ((CraftWorld) world).getHandle();
|
||||||
|
EntityNMSArmorStand invisibleArmorStand = new EntityNMSArmorStand(nmsWorld, parentPiece);
|
||||||
|
invisibleArmorStand.setLocationNMS(x, y, z);
|
||||||
|
if (!addEntityToWorld(nmsWorld, invisibleArmorStand)) {
|
||||||
|
DebugHandler.handleSpawnFail(parentPiece);
|
||||||
|
}
|
||||||
|
return invisibleArmorStand;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean addEntityToWorld(WorldServer nmsWorld, Entity nmsEntity) {
|
||||||
|
Validator.isTrue(Bukkit.isPrimaryThread(), "Async entity add");
|
||||||
|
|
||||||
|
final int chunkX = MathHelper.floor(nmsEntity.locX / 16.0);
|
||||||
|
final int chunkZ = MathHelper.floor(nmsEntity.locZ / 16.0);
|
||||||
|
|
||||||
|
if (!nmsWorld.getChunkProviderServer().isLoaded(chunkX, chunkZ)) {
|
||||||
|
// This should never happen
|
||||||
|
nmsEntity.dead = true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
nmsWorld.getChunkAt(chunkX, chunkZ).a(nmsEntity);
|
||||||
|
nmsWorld.entityList.add(nmsEntity);
|
||||||
|
|
||||||
|
try {
|
||||||
|
validateEntityMethod.invoke(nmsWorld, nmsEntity);
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isNMSEntityBase(org.bukkit.entity.Entity bukkitEntity) {
|
||||||
|
return ((CraftEntity) bukkitEntity).getHandle() instanceof NMSEntityBase;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NMSEntityBase getNMSEntityBase(org.bukkit.entity.Entity bukkitEntity) {
|
||||||
|
|
||||||
|
Entity nmsEntity = ((CraftEntity) bukkitEntity).getHandle();
|
||||||
|
if (nmsEntity instanceof NMSEntityBase) {
|
||||||
|
return ((NMSEntityBase) nmsEntity);
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FancyMessage newFancyMessage(String text) {
|
||||||
|
return new FancyMessageImpl(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean hasChatHoverFeature() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,111 @@
|
|||||||
|
package com.gmail.filoghost.holographicdisplays.nms.v1_9_R2;
|
||||||
|
|
||||||
|
import net.minecraft.server.v1_9_R2.AxisAlignedBB;
|
||||||
|
import net.minecraft.server.v1_9_R2.BlockPosition;
|
||||||
|
import net.minecraft.server.v1_9_R2.MovingObjectPosition;
|
||||||
|
import net.minecraft.server.v1_9_R2.Vec3D;
|
||||||
|
|
||||||
|
public class NullBoundingBox extends AxisAlignedBB {
|
||||||
|
|
||||||
|
public NullBoundingBox() {
|
||||||
|
super(0, 0, 0, 0, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public double a() {
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public double a(AxisAlignedBB arg0, double arg1) {
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB a(AxisAlignedBB arg0) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB a(double arg0, double arg1, double arg2) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public MovingObjectPosition a(Vec3D arg0, Vec3D arg1) {
|
||||||
|
return super.a(arg0, arg1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean a(Vec3D arg0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public double b(AxisAlignedBB arg0, double arg1) {
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean b(AxisAlignedBB arg0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public double c(AxisAlignedBB arg0, double arg1) {
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB c(double arg0, double arg1, double arg2) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB grow(double arg0, double arg1, double arg2) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB shrink(double arg0) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB a(BlockPosition arg0) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean a(double arg0, double arg1, double arg2, double arg3, double arg4, double arg5) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean b(Vec3D arg0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean c(Vec3D arg0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean d(Vec3D arg0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB e(double arg0) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public AxisAlignedBB g(double arg0) {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -1,6 +1,6 @@
|
|||||||
name: HolographicDisplays
|
name: HolographicDisplays
|
||||||
main: com.gmail.filoghost.holographicdisplays.HolographicDisplays
|
main: com.gmail.filoghost.holographicdisplays.HolographicDisplays
|
||||||
version: 2.1.12
|
version: 2.1.13
|
||||||
|
|
||||||
softdepend: [Multiverse-Core, MultiWorld, My Worlds, My_Worlds, ProtocolLib]
|
softdepend: [Multiverse-Core, MultiWorld, My Worlds, My_Worlds, ProtocolLib]
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user