Add in Missing Variants, Kill Mobs Correctly

Add in Missing Variants, Kill Mobs Correctly, Allow capture by Smacking
with Eggs, Create Custom Egg for Elder Guardians
This commit is contained in:
Nicolas Shreiner 2015-01-29 06:06:55 -05:00
parent 7b1d05bd05
commit 6be7739949
5 changed files with 124 additions and 52 deletions

View File

@ -84,13 +84,6 @@
<artifactId>Vault</artifactId> <artifactId>Vault</artifactId>
<version>1.5.0</version> <version>1.5.0</version>
</dependency> </dependency>
<dependency>
<groupId>io.hotmail.com.jacob_vejvoda</groupId>
<artifactId>ElderGuardianBoss</artifactId>
<version>0.2</version>
<scope>system</scope>
<systemPath>${basedir}/lib/ElderGuardianBoss.jar</systemPath>
</dependency>
<dependency> <dependency>
<groupId>org.mcstats.bukkit</groupId> <groupId>org.mcstats.bukkit</groupId>
<artifactId>metrics</artifactId> <artifactId>metrics</artifactId>

View File

@ -62,16 +62,4 @@ public class EggCatcher extends JavaPlugin {
} }
} }
} }
// **************************** Specialized Support for Personal ElderGuardian Boss *****************************
/*
public static boolean isElderGuardianBoss()
{
if (pm.isPluginEnabled("ElderGuardianBoss")) {
return true;
}
return false;
}
*/
} }

View File

@ -9,9 +9,12 @@ import me.shansen.EggCatcher.events.EggCaptureEvent;
import org.bukkit.ChatColor; import org.bukkit.ChatColor;
import org.bukkit.Effect; import org.bukkit.Effect;
import org.bukkit.GameMode;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.configuration.file.FileConfiguration; import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.entity.Ageable; import org.bukkit.entity.Ageable;
import org.bukkit.entity.Creeper;
import org.bukkit.entity.Damageable;
import org.bukkit.entity.Egg; import org.bukkit.entity.Egg;
import org.bukkit.entity.Entity; import org.bukkit.entity.Entity;
import org.bukkit.entity.Guardian; import org.bukkit.entity.Guardian;
@ -21,6 +24,7 @@ import org.bukkit.entity.Ocelot;
import org.bukkit.entity.Pig; import org.bukkit.entity.Pig;
import org.bukkit.entity.PigZombie; import org.bukkit.entity.PigZombie;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.entity.Rabbit;
import org.bukkit.entity.Sheep; import org.bukkit.entity.Sheep;
import org.bukkit.entity.Skeleton; import org.bukkit.entity.Skeleton;
import org.bukkit.entity.Tameable; import org.bukkit.entity.Tameable;
@ -31,6 +35,7 @@ import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDamageByEntityEvent; import org.bukkit.event.entity.EntityDamageByEntityEvent;
import org.bukkit.event.entity.EntityDamageEvent; import org.bukkit.event.entity.EntityDamageEvent;
import org.bukkit.event.entity.EntityDeathEvent;
import org.bukkit.event.player.PlayerInteractEntityEvent; import org.bukkit.event.player.PlayerInteractEntityEvent;
import org.bukkit.inventory.HorseInventory; import org.bukkit.inventory.HorseInventory;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
@ -103,25 +108,30 @@ public class EggCatcherEntityListener
} }
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
@EventHandler @EventHandler(ignoreCancelled = true, priority = EventPriority.MONITOR)
public void onEntityStruckByEgg(EntityDamageByEntityEvent event) public void onEntityStruckByEgg(EntityDamageEvent event)
{ {
Player player = null; Player player = null;
Entity entity = event.getEntity(); Entity entity = event.getEntity();
EggType eggType = null; EggType eggType = null;
double vaultCost = 0.0; double vaultCost = 0.0;
if(!(event.getDamager() instanceof Player)) EntityDamageByEntityEvent damageEvent = null;
if (!(event instanceof EntityDamageByEntityEvent)) {
return;
}
damageEvent = (EntityDamageByEntityEvent) event;
if(!(damageEvent.getDamager() instanceof Player))
{ {
return; return;
} }
player = (Player)((EntityDamageByEntityEvent)event).getDamager(); player = (Player)damageEvent.getDamager();
if(player.getItemInHand().getType() != Material.EGG) if(player.getItemInHand().getType() != Material.EGG)
return; return;
eggType = EggType.getEggType(entity); eggType = EggType.getEggType(entity);
if (eggType == null) { if (eggType == null) {
return; return;
} }
ItemStack takeEgg = new ItemStack(Material.EGG, (player.getItemInHand().getAmount() - 1)); takeEgg(player);
if (this.preventCatchingBabyAnimals) { if (this.preventCatchingBabyAnimals) {
if (entity instanceof Ageable) { if (entity instanceof Ageable) {
if (!((Ageable) entity).isAdult()) { if (!((Ageable) entity).isAdult()) {
@ -226,20 +236,13 @@ public class EggCatcherEntityListener
} }
} }
entity.getWorld().dropItem(entity.getLocation(), makeEgg(eggType, entity)); entity.getWorld().dropItem(entity.getLocation(), makeEgg(eggType, entity));
// **************************** Specialized Support for Personal ElderGuardian Boss ***************************** entity = killCatchedCreature(entity);
// killElderGuardian(entity);
entity.remove();
if (this.explosionEffect) { if (this.explosionEffect) {
entity.getWorld().createExplosion(entity.getLocation(), 0); entity.getWorld().createExplosion(entity.getLocation(), 0);
} }
if (this.smokeEffect) { if (this.smokeEffect) {
entity.getWorld().playEffect(entity.getLocation(), Effect.SMOKE, 0); entity.getWorld().playEffect(entity.getLocation(), Effect.SMOKE, 0);
} }
if(takeEgg.getAmount() > 0){
player.getInventory().setItemInHand(takeEgg);
}else{
player.getInventory().setItemInHand(new ItemStack(Material.AIR));
}
} }
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
@ -408,8 +411,6 @@ public class EggCatcherEntityListener
} }
} }
} }
entity.remove();
if (this.explosionEffect) { if (this.explosionEffect) {
entity.getWorld().createExplosion(entity.getLocation(), 0); entity.getWorld().createExplosion(entity.getLocation(), 0);
} }
@ -417,8 +418,7 @@ public class EggCatcherEntityListener
entity.getWorld().playEffect(entity.getLocation(), Effect.SMOKE, 0); entity.getWorld().playEffect(entity.getLocation(), Effect.SMOKE, 0);
} }
entity.getWorld().dropItem(entity.getLocation(), makeEgg(eggType, entity)); entity.getWorld().dropItem(entity.getLocation(), makeEgg(eggType, entity));
// **************************** Specialized Support for Personal ElderGuardian Boss ***************************** entity = killCatchedCreature(entity);
// killElderGuardian(entity);
if (!this.spawnChickenOnSuccess) { if (!this.spawnChickenOnSuccess) {
if (!EggCatcher.eggs.contains(egg)) { if (!EggCatcher.eggs.contains(egg)) {
@ -427,6 +427,8 @@ public class EggCatcherEntityListener
} }
} }
//******* Let's Seperate the Method for Creating the Eggs
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public ItemStack makeEgg(EggType eggType, Entity entity) public ItemStack makeEgg(EggType eggType, Entity entity)
{ {
@ -455,7 +457,10 @@ public class EggCatcherEntityListener
{ {
lore.add(ChatColor.BLUE + "Variant: " + ChatColor.WHITE + ((Ocelot)entity).getCatType().name()); lore.add(ChatColor.BLUE + "Variant: " + ChatColor.WHITE + ((Ocelot)entity).getCatType().name());
} }
if ((entity instanceof Creeper) && ((Creeper) entity).isPowered())
{
lore.add(ChatColor.BLUE + "Variant: " + ChatColor.WHITE + "Charged");
}
if ((entity instanceof Ageable)) if ((entity instanceof Ageable))
{ {
lore.add(ChatColor.BLUE + "Age: " + ChatColor.WHITE + ((Ageable)entity).getAge()); lore.add(ChatColor.BLUE + "Age: " + ChatColor.WHITE + ((Ageable)entity).getAge());
@ -516,9 +521,35 @@ public class EggCatcherEntityListener
} }
if((entity instanceof Guardian && ((Guardian)entity).isElder())) { if((entity instanceof Guardian && ((Guardian)entity).isElder())) {
meta = eggStack.getItemMeta();
meta.setDisplayName("Spawn Elder Guardian");
eggStack.setItemMeta(meta);
lore.add(ChatColor.BLUE + "Variant: " + ChatColor.WHITE + "Elder"); lore.add(ChatColor.BLUE + "Variant: " + ChatColor.WHITE + "Elder");
} }
if((entity instanceof Rabbit)){
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.BLACK) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.BLACK_AND_WHITE) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.BROWN) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.GOLD) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.SALT_AND_PEPPER) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.THE_KILLER_BUNNY) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
if (((Rabbit)entity).getRabbitType() == Rabbit.Type.WHITE) {
lore.add(ChatColor.BLUE + "Type: " + ChatColor.WHITE + ((Rabbit)entity).getRabbitType().toString());
}
}
if ((entity instanceof Horse)) if ((entity instanceof Horse))
{ {
if (((Horse)entity).getVariant() == Horse.Variant.HORSE) { if (((Horse)entity).getVariant() == Horse.Variant.HORSE) {
@ -567,15 +598,59 @@ public class EggCatcherEntityListener
} }
} }
//**************************** Specialized Support for Personal ElderGuardian Boss ***************************** //Take the egg from the player when Striking the entity with the egg
/*
public void killElderGuardian(Entity entity) public void takeEgg(Player player){
ItemStack takeEgg = new ItemStack(Material.EGG, (player.getItemInHand().getAmount() - 1));
if(player.getGameMode() != GameMode.CREATIVE || player.getGameMode() != GameMode.SPECTATOR){
if(takeEgg.getAmount() > 0){
player.getInventory().setItemInHand(takeEgg);
}else{
player.getInventory().setItemInHand(new ItemStack(Material.AIR));
}
}
}
//Let's Kill these creatures properly to avoid bad plugin interactions
public Entity killCatchedCreature(Entity entity)
{ {
if((entity instanceof Guardian && ((Guardian)entity).isElder())) { if(entity instanceof Damageable)
if(EggCatcher.isElderGuardianBoss()){ {
io.hotmail.com.jacob_vejvoda.ElderGuardianBoss.ElderGuardianBoss.killBoss(entity); Damageable e = (Damageable)entity;
entity.remove();
e.setHealth(0);
entity = (Entity)e;
}
return entity;
}
// ************* Stop Creatures killed by EggCatcher from Dropping Normal Drops *****************
@EventHandler(priority = EventPriority.HIGH)
public void stopCaptureDrops(EntityDeathEvent event)
{
Entity entity = event.getEntity();
LivingEntity caught = null;
Player player = null;
ItemStack hand = null;
if((entity instanceof LivingEntity && !(entity instanceof Player)))
{
caught = (LivingEntity)entity;
}else{
return;
}
if((caught.getKiller() != null) && (caught.getKiller() instanceof Player) || caught.getKiller() instanceof Egg)
{
if(caught.getKiller() instanceof Player){
player = caught.getKiller();
hand = player.getItemInHand();
if(!(hand.getType() == Material.EGG))
{
return;
} }
} }
event.getDrops().clear();
}
} }
*/
} }

View File

@ -38,7 +38,13 @@ public class EggCatcherPlayerClickListener implements org.bukkit.event.Listener
} }
if (i.getItemMeta().getDisplayName() != null) if (i.getItemMeta().getDisplayName() != null)
{ {
entity.setCustomName(i.getItemMeta().getDisplayName()); String s = i.getItemMeta().getDisplayName();
if(s.contains("Spawn ")){
String l = s.replace("§f", "");
l = l.replace("Spawn ", "");
s = l;
}
entity.setCustomName(s);
entity.setCustomNameVisible(true); entity.setCustomNameVisible(true);
} }
for (String s : i.getItemMeta().getLore()) { for (String s : i.getItemMeta().getLore()) {
@ -65,6 +71,9 @@ public class EggCatcherPlayerClickListener implements org.bukkit.event.Listener
if ((entity instanceof Guardian)){ if ((entity instanceof Guardian)){
((Guardian)entity).setElder(true); ((Guardian)entity).setElder(true);
} }
if ((entity instanceof Creeper)){
((Creeper)entity).setPowered(true);
}
} }
if (s.contains("Age:")) { if (s.contains("Age:")) {
String l = s.replaceAll("§9", ""); String l = s.replaceAll("§9", "");
@ -209,6 +218,14 @@ public class EggCatcherPlayerClickListener implements org.bukkit.event.Listener
((Horse)entity).getInventory().setArmor(new ItemStack(Material.getMaterial(l))); ((Horse)entity).getInventory().setArmor(new ItemStack(Material.getMaterial(l)));
} }
} }
if (s.contains("Type:")) {
String l = s.replaceAll("§9", "");
l = l.replaceAll("§f", "");
l = l.replaceAll("Type: ", "");
if ((entity instanceof Rabbit)) {
((Rabbit)entity).setRabbitType(Rabbit.Type.valueOf(l));
}
}
} }
} }
} }

View File

@ -3,7 +3,6 @@ version: 2.1.3
description: This plugin allows you to catch mobs in eggs. description: This plugin allows you to catch mobs in eggs.
author: shansen author: shansen
main: me.shansen.EggCatcher.EggCatcher main: me.shansen.EggCatcher.EggCatcher
softdepend: [ElderGuardianBoss]
permissions: permissions:
eggcatcher.catch.*: eggcatcher.catch.*: