2017-12-30 08:36:36 +01:00
|
|
|
package net.citizensnpcs.nms.v1_10_R1.entity;
|
|
|
|
|
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
import org.bukkit.craftbukkit.v1_10_R1.CraftServer;
|
|
|
|
import org.bukkit.craftbukkit.v1_10_R1.entity.CraftEntity;
|
|
|
|
import org.bukkit.craftbukkit.v1_10_R1.entity.CraftWither;
|
|
|
|
import org.bukkit.entity.Wither;
|
|
|
|
import org.bukkit.util.Vector;
|
2023-02-22 17:06:13 +01:00
|
|
|
|
2017-12-30 08:36:36 +01:00
|
|
|
import net.citizensnpcs.api.npc.NPC;
|
2023-02-13 13:32:20 +01:00
|
|
|
import net.citizensnpcs.nms.v1_10_R1.util.NMSBoundingBox;
|
2017-12-30 08:36:36 +01:00
|
|
|
import net.citizensnpcs.nms.v1_10_R1.util.NMSImpl;
|
|
|
|
import net.citizensnpcs.npc.CitizensNPC;
|
|
|
|
import net.citizensnpcs.npc.ai.NPCHolder;
|
2023-02-13 13:32:20 +01:00
|
|
|
import net.citizensnpcs.util.NMS;
|
2017-12-30 08:36:36 +01:00
|
|
|
import net.citizensnpcs.util.Util;
|
2023-02-13 13:32:20 +01:00
|
|
|
import net.minecraft.server.v1_10_R1.AxisAlignedBB;
|
2022-11-13 16:33:18 +01:00
|
|
|
import net.minecraft.server.v1_10_R1.Entity;
|
2017-12-30 08:36:36 +01:00
|
|
|
import net.minecraft.server.v1_10_R1.EntityWither;
|
|
|
|
import net.minecraft.server.v1_10_R1.NBTTagCompound;
|
|
|
|
import net.minecraft.server.v1_10_R1.SoundEffect;
|
|
|
|
import net.minecraft.server.v1_10_R1.World;
|
|
|
|
|
|
|
|
public class WitherController extends MobEntityController {
|
|
|
|
public WitherController() {
|
|
|
|
super(EntityWitherNPC.class);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Wither getBukkitEntity() {
|
|
|
|
return (Wither) super.getBukkitEntity();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class EntityWitherNPC extends EntityWither implements NPCHolder {
|
|
|
|
private final CitizensNPC npc;
|
|
|
|
|
|
|
|
public EntityWitherNPC(World world) {
|
|
|
|
this(world, null);
|
|
|
|
}
|
|
|
|
|
|
|
|
public EntityWitherNPC(World world, NPC npc) {
|
|
|
|
super(world);
|
|
|
|
this.npc = (CitizensNPC) npc;
|
|
|
|
}
|
|
|
|
|
2023-02-13 13:32:20 +01:00
|
|
|
@Override
|
|
|
|
public void a(AxisAlignedBB bb) {
|
|
|
|
super.a(NMSBoundingBox.makeBB(npc, bb));
|
|
|
|
}
|
|
|
|
|
2022-11-13 16:33:18 +01:00
|
|
|
@Override
|
|
|
|
public void a(Entity entity, float strength, double dx, double dz) {
|
2023-02-13 13:32:20 +01:00
|
|
|
NMS.callKnockbackEvent(npc, strength, dx, dz, (evt) -> super.a(entity, (float) evt.getStrength(),
|
|
|
|
evt.getKnockbackVector().getX(), evt.getKnockbackVector().getZ()));
|
2022-11-13 16:33:18 +01:00
|
|
|
}
|
|
|
|
|
2023-03-12 15:29:41 +01:00
|
|
|
@Override
|
|
|
|
public int aY() {
|
|
|
|
return NMS.getFallDistance(npc, super.aY());
|
|
|
|
}
|
|
|
|
|
2017-12-30 08:36:36 +01:00
|
|
|
@Override
|
|
|
|
protected SoundEffect bV() {
|
2023-01-01 08:26:35 +01:00
|
|
|
return NMSImpl.getSoundEffect(npc, super.bV(), NPC.Metadata.DEATH_SOUND);
|
2017-12-30 08:36:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected SoundEffect bW() {
|
2023-01-01 08:26:35 +01:00
|
|
|
return NMSImpl.getSoundEffect(npc, super.bW(), NPC.Metadata.HURT_SOUND);
|
2017-12-30 08:36:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void collide(net.minecraft.server.v1_10_R1.Entity entity) {
|
|
|
|
// this method is called by both the entities involved - cancelling
|
|
|
|
// it will not stop the NPC from moving.
|
|
|
|
super.collide(entity);
|
|
|
|
if (npc != null)
|
|
|
|
Util.callCollisionEvent(npc, entity.getBukkitEntity());
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean d(NBTTagCompound save) {
|
|
|
|
return npc == null ? super.d(save) : false;
|
|
|
|
}
|
|
|
|
|
2022-09-08 07:28:14 +02:00
|
|
|
@Override
|
|
|
|
public boolean df() {
|
2022-09-14 19:01:48 +02:00
|
|
|
return npc == null || !npc.data().has("wither-arrow-shield") ? super.df()
|
|
|
|
: npc.data().get("wither-arrow-shield");
|
2022-09-08 07:28:14 +02:00
|
|
|
}
|
|
|
|
|
2017-12-30 08:36:36 +01:00
|
|
|
@Override
|
|
|
|
public void g(double x, double y, double z) {
|
2021-01-02 17:09:21 +01:00
|
|
|
Vector vector = Util.callPushEvent(npc, x, y, z);
|
|
|
|
if (vector != null) {
|
2017-12-30 08:36:36 +01:00
|
|
|
super.g(vector.getX(), vector.getY(), vector.getZ());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected SoundEffect G() {
|
2023-01-01 08:26:35 +01:00
|
|
|
return NMSImpl.getSoundEffect(npc, super.G(), NPC.Metadata.AMBIENT_SOUND);
|
2017-12-30 08:36:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public CraftEntity getBukkitEntity() {
|
|
|
|
if (npc != null && !(bukkitEntity instanceof NPCHolder))
|
|
|
|
bukkitEntity = new WitherNPC(this);
|
|
|
|
return super.getBukkitEntity();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public NPC getNPC() {
|
|
|
|
return npc;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isLeashed() {
|
2023-02-13 17:46:30 +01:00
|
|
|
return NMSImpl.isLeashed(npc, super::isLeashed, this);
|
2017-12-30 08:36:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void L() {
|
|
|
|
if (npc == null) {
|
|
|
|
super.L();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int m(int i) {
|
|
|
|
return npc == null ? super.m(i) : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void M() {
|
|
|
|
if (npc == null) {
|
|
|
|
super.M();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
npc.update();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class WitherNPC extends CraftWither implements NPCHolder {
|
|
|
|
private final CitizensNPC npc;
|
|
|
|
|
|
|
|
public WitherNPC(EntityWitherNPC entity) {
|
|
|
|
super((CraftServer) Bukkit.getServer(), entity);
|
|
|
|
this.npc = entity.npc;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public NPC getNPC() {
|
|
|
|
return npc;
|
|
|
|
}
|
|
|
|
}
|
2012-10-28 05:37:37 +01:00
|
|
|
}
|