Add SplashPotion for 1.8.8
This commit is contained in:
parent
487d587675
commit
8a78c5788f
|
@ -0,0 +1,103 @@
|
|||
package net.citizensnpcs.nms.v1_8_R3.entity.nonliving;
|
||||
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.craftbukkit.v1_8_R3.CraftServer;
|
||||
import org.bukkit.craftbukkit.v1_8_R3.entity.CraftEntity;
|
||||
import org.bukkit.craftbukkit.v1_8_R3.entity.CraftThrownPotion;
|
||||
import org.bukkit.entity.ThrownPotion;
|
||||
import org.bukkit.util.Vector;
|
||||
|
||||
import net.citizensnpcs.api.npc.NPC;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.MobEntityController;
|
||||
import net.citizensnpcs.npc.CitizensNPC;
|
||||
import net.citizensnpcs.npc.ai.NPCHolder;
|
||||
import net.citizensnpcs.util.Util;
|
||||
import net.minecraft.server.v1_8_R3.EntityPotion;
|
||||
import net.minecraft.server.v1_8_R3.NBTTagCompound;
|
||||
import net.minecraft.server.v1_8_R3.World;
|
||||
|
||||
public class SplashPotionController extends MobEntityController {
|
||||
public SplashPotionController() {
|
||||
super(EntityPotionNPC.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ThrownPotion getBukkitEntity() {
|
||||
return (ThrownPotion) super.getBukkitEntity();
|
||||
}
|
||||
|
||||
public static class EntityPotionNPC extends EntityPotion implements NPCHolder {
|
||||
private final CitizensNPC npc;
|
||||
|
||||
public EntityPotionNPC(World world) {
|
||||
this(world, null);
|
||||
}
|
||||
|
||||
public EntityPotionNPC(World world, NPC npc) {
|
||||
super(world);
|
||||
this.npc = (CitizensNPC) npc;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void collide(net.minecraft.server.v1_8_R3.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;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void g(double x, double y, double z) {
|
||||
Vector vector = Util.callPushEvent(npc, x, y, z);
|
||||
if (vector != null) {
|
||||
super.g(vector.getX(), vector.getY(), vector.getZ());
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public CraftEntity getBukkitEntity() {
|
||||
if (npc != null && !(bukkitEntity instanceof NPCHolder)) {
|
||||
bukkitEntity = new PotionNPC(this);
|
||||
}
|
||||
return super.getBukkitEntity();
|
||||
}
|
||||
|
||||
@Override
|
||||
public NPC getNPC() {
|
||||
return npc;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void t_() {
|
||||
if (npc != null) {
|
||||
npc.update();
|
||||
if (!npc.data().get(NPC.DEFAULT_PROTECTED_METADATA, true)) {
|
||||
super.t_();
|
||||
}
|
||||
} else {
|
||||
super.t_();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static class PotionNPC extends CraftThrownPotion implements NPCHolder {
|
||||
private final CitizensNPC npc;
|
||||
|
||||
public PotionNPC(EntityPotionNPC entity) {
|
||||
super((CraftServer) Bukkit.getServer(), entity);
|
||||
this.npc = entity.npc;
|
||||
}
|
||||
|
||||
@Override
|
||||
public NPC getNPC() {
|
||||
return npc;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -122,6 +122,7 @@ import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.MinecartTNTController;
|
|||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.PaintingController;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.SmallFireballController;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.SnowballController;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.SplashPotionController;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.TNTPrimedController;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.ThrownExpBottleController;
|
||||
import net.citizensnpcs.nms.v1_8_R3.entity.nonliving.WitherSkullController;
|
||||
|
@ -612,6 +613,7 @@ public class NMSImpl implements NMSBridge {
|
|||
EntityControllers.setEntityControllerForType(EntityType.PAINTING, PaintingController.class);
|
||||
EntityControllers.setEntityControllerForType(EntityType.PIG, PigController.class);
|
||||
EntityControllers.setEntityControllerForType(EntityType.PIG_ZOMBIE, PigZombieController.class);
|
||||
EntityControllers.setEntityControllerForType(EntityType.SPLASH_POTION, SplashPotionController.class);
|
||||
EntityControllers.setEntityControllerForType(EntityType.PLAYER, HumanController.class);
|
||||
EntityControllers.setEntityControllerForType(EntityType.RABBIT, RabbitController.class);
|
||||
EntityControllers.setEntityControllerForType(EntityType.SHEEP, SheepController.class);
|
||||
|
|
Loading…
Reference in New Issue