mirror of
https://github.com/shansen/EggCatcher.git
synced 2025-01-21 14:51:26 +01:00
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:
parent
7b1d05bd05
commit
6be7739949
7
pom.xml
7
pom.xml
@ -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>
|
||||||
|
@ -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;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
}
|
}
|
@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
@ -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));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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.*:
|
||||||
|
Loading…
Reference in New Issue
Block a user