123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446 |
- /*
- This file is part of mcMMO.
- mcMMO is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
- mcMMO is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with mcMMO. If not, see <http://www.gnu.org/licenses/>.
- */
- package com.gmail.nossr50;
- import org.bukkit.Bukkit;
- import org.bukkit.World;
- import org.bukkit.entity.*;
- import org.bukkit.event.entity.EntityDamageByEntityEvent;
- import org.bukkit.event.entity.EntityDamageEvent;
- import org.bukkit.event.entity.EntityDamageEvent.DamageCause;
- import org.bukkit.plugin.Plugin;
- import com.gmail.nossr50.config.LoadProperties;
- import com.gmail.nossr50.datatypes.PlayerProfile;
- import com.gmail.nossr50.datatypes.SkillType;
- import com.gmail.nossr50.locale.mcLocale;
- import com.gmail.nossr50.party.Party;
- import com.gmail.nossr50.skills.Acrobatics;
- import com.gmail.nossr50.skills.Archery;
- import com.gmail.nossr50.skills.Axes;
- import com.gmail.nossr50.skills.Skills;
- import com.gmail.nossr50.skills.Swords;
- import com.gmail.nossr50.skills.Taming;
- import com.gmail.nossr50.skills.Unarmed;
- public class Combat
- {
- public static void combatChecks(EntityDamageEvent event, mcMMO pluginx)
- {
- if(event.isCancelled() || event.getDamage() == 0)
- return;
-
- if(event instanceof EntityDamageByEntityEvent)
- {
- /*
- * OFFENSIVE CHECKS FOR PLAYERS VERSUS ENTITIES
- */
- if(((EntityDamageByEntityEvent) event).getDamager() instanceof Player)
- {
- //Declare Things
- EntityDamageByEntityEvent eventb = (EntityDamageByEntityEvent) event;
- Player attacker = (Player)((EntityDamageByEntityEvent) event).getDamager();
- PlayerProfile PPa = Users.getProfile(attacker);
-
- //Damage modifiers
- if(mcPermissions.getInstance().unarmed(attacker) && attacker.getItemInHand().getTypeId() == 0) //Unarmed
- Unarmed.unarmedBonus(attacker, eventb);
- if(m.isAxes(attacker.getItemInHand()) && mcPermissions.getInstance().axes(attacker) && Users.getProfile(attacker).getSkillLevel(SkillType.AXES) >= 500)
- event.setDamage(event.getDamage()+4);
-
- //If there are any abilities to activate
- combatAbilityChecks(attacker, PPa, pluginx);
-
- //Check for offensive procs
- if(!(((EntityDamageByEntityEvent) event).getDamager() instanceof Arrow))
- {
- if(mcPermissions.getInstance().axes(attacker))
- Axes.axeCriticalCheck(attacker, eventb, pluginx); //Axe Criticals
-
- if(!pluginx.misc.bleedTracker.contains((LivingEntity) event.getEntity())) //Swords Bleed
- Swords.bleedCheck(attacker, (LivingEntity)event.getEntity(), pluginx);
-
- if(event.getEntity() instanceof Player && mcPermissions.getInstance().unarmed(attacker))
- {
- Player defender = (Player)event.getEntity();
- Unarmed.disarmProcCheck(attacker, defender);
- }
-
-
-
- //Modify the event damage if Attacker is Berserk
- if(PPa.getBerserkMode())
- event.setDamage(event.getDamage() + (event.getDamage() / 2));
-
- //Handle Ability Interactions
- if(PPa.getSkullSplitterMode() && m.isAxes(attacker.getItemInHand()))
- Axes.applyAoeDamage(attacker, eventb, pluginx);
- if(PPa.getSerratedStrikesMode() && m.isSwords(attacker.getItemInHand()))
- Swords.applySerratedStrikes(attacker, eventb, pluginx);
-
- //Experience
- if(event.getEntity() instanceof Player)
- {
- Player defender = (Player)event.getEntity();
- PlayerProfile PPd = Users.getProfile(defender);
- if(attacker != null && defender != null && LoadProperties.pvpxp)
- {
- if(System.currentTimeMillis() >= (PPd.getRespawnATS()*1000) + 5000
- && ((PPd.getLastLogin()+5)*1000) < System.currentTimeMillis()
- && defender.getHealth() >= 1)
- {
- //Prevent a ridiculous amount of XP being granted by capping it at the remaining health of the mob
- int hpLeft = defender.getHealth(), xpinc = 0;
-
- if(hpLeft < event.getDamage())
- xpinc = hpLeft;
- else
- xpinc = event.getDamage();
-
- int xp = (int) (xpinc * 2 * LoadProperties.pvpxprewardmodifier);
-
- if(m.isAxes(attacker.getItemInHand()) && mcPermissions.getInstance().axes(attacker))
- PPa.addXP(SkillType.AXES, xp*10, attacker);
- if(m.isSwords(attacker.getItemInHand()) && mcPermissions.getInstance().swords(attacker))
- PPa.addXP(SkillType.SWORDS, xp*10, attacker);
- if(attacker.getItemInHand().getTypeId() == 0 && mcPermissions.getInstance().unarmed(attacker))
- PPa.addXP(SkillType.UNARMED, xp*10, attacker);
- }
- }
- }
-
- if(!pluginx.misc.mobSpawnerList.contains(event.getEntity()))
- {
- int xp = getXp(event.getEntity(), event);
- if(m.isSwords(attacker.getItemInHand()) && mcPermissions.getInstance().swords(attacker))
- PPa.addXP(SkillType.SWORDS, xp*10, attacker);
- else if(m.isAxes(attacker.getItemInHand()) && mcPermissions.getInstance().axes(attacker))
- PPa.addXP(SkillType.AXES, xp*10, attacker);
- else if(attacker.getItemInHand().getTypeId() == 0 && mcPermissions.getInstance().unarmed(attacker))
- PPa.addXP(SkillType.UNARMED, xp*10, attacker);
- }
- Skills.XpCheckAll(attacker);
-
- if(event.getEntity() instanceof Wolf)
- {
- Wolf theWolf = (Wolf)event.getEntity();
-
- if(attacker.getItemInHand().getTypeId() == 352 && mcPermissions.getInstance().taming(attacker))
- {
- event.setCancelled(true);
- if(theWolf.isTamed())
- {
- attacker.sendMessage(mcLocale.getString("Combat.BeastLore")+" "+
- mcLocale.getString("Combat.BeastLoreOwner", new Object[] {Taming.getOwnerName(theWolf)})+" "+
- mcLocale.getString("Combat.BeastLoreHealthWolfTamed", new Object[] {theWolf.getHealth()}));
- }
- else
- {
- attacker.sendMessage(mcLocale.getString("Combat.BeastLore")+" "+
- mcLocale.getString("Combat.BeastLoreHealthWolf", new Object[] {theWolf.getHealth()}));
- }
- }
- }
- }
- }
- }
-
- /*
- * OFFENSIVE CHECKS FOR WOLVES VERSUS ENTITIES
- */
- if(event instanceof EntityDamageByEntityEvent && ((EntityDamageByEntityEvent) event).getDamager() instanceof Wolf)
- {
- EntityDamageByEntityEvent eventb = (EntityDamageByEntityEvent) event;
- Wolf theWolf = (Wolf) eventb.getDamager();
- if(theWolf.isTamed() && Taming.ownerOnline(theWolf, pluginx))
- {
- if(Taming.getOwner(theWolf, pluginx) == null)
- return;
- Player master = Taming.getOwner(theWolf, pluginx);
- PlayerProfile PPo = Users.getProfile(master);
-
- if(mcPermissions.getInstance().taming(master))
- {
- //Sharpened Claws
- if(PPo.getSkillLevel(SkillType.TAMING) >= 750)
- {
- event.setDamage(event.getDamage() + 2);
- }
-
- //Gore
- if(Math.random() * 1000 <= PPo.getSkillLevel(SkillType.TAMING))
- {
- event.setDamage(event.getDamage() * 2);
-
- if(event.getEntity() instanceof Player)
- {
- Player target = (Player)event.getEntity();
- target.sendMessage(mcLocale.getString("Combat.StruckByGore")); //$NON-NLS-1$
- Users.getProfile(target).setBleedTicks(2);
- }
- else
- pluginx.misc.addToBleedQue((LivingEntity) event.getEntity());
-
- master.sendMessage(mcLocale.getString("Combat.Gore")); //$NON-NLS-1$
- }
- if(!event.getEntity().isDead() && !pluginx.misc.mobSpawnerList.contains(event.getEntity()))
- {
- int xp = getXp(event.getEntity(), event);
- Users.getProfile(master).addXP(SkillType.TAMING, xp*10, master);
-
- if(event.getEntity() instanceof Player)
- {
- xp = (event.getDamage() * 2);
- Users.getProfile(master).addXP(SkillType.TAMING, (int)((xp*10)*1.5), master);
- }
- Skills.XpCheckSkill(SkillType.TAMING, master);
- }
- }
- }
- }
- //Another offensive check for Archery
- if(event instanceof EntityDamageByEntityEvent && event.getCause() == DamageCause.PROJECTILE && ((EntityDamageByEntityEvent) event).getDamager() instanceof Arrow)
- archeryCheck((EntityDamageByEntityEvent)event, pluginx);
-
- /*
- * DEFENSIVE CHECKS
- */
- if(event instanceof EntityDamageByEntityEvent && event.getEntity() instanceof Player)
- {
- Swords.counterAttackChecks((EntityDamageByEntityEvent)event);
- Acrobatics.dodgeChecks((EntityDamageByEntityEvent)event);
- }
- /*
- * DEFENSIVE CHECKS FOR WOLVES
- */
-
- if(event.getEntity() instanceof Wolf)
- {
- Wolf theWolf = (Wolf) event.getEntity();
-
- if(theWolf.isTamed() && Taming.ownerOnline(theWolf, pluginx))
- {
- if(Taming.getOwner(theWolf, pluginx) == null)
- return;
-
- Player master = Taming.getOwner(theWolf, pluginx);
- PlayerProfile PPo = Users.getProfile(master);
- if(mcPermissions.getInstance().taming(master))
- {
- //Shock-Proof
- if((event.getCause() == DamageCause.ENTITY_EXPLOSION || event.getCause() == DamageCause.BLOCK_EXPLOSION) && PPo.getSkillLevel(SkillType.TAMING) >= 500)
- {
- event.setDamage(2);
- }
-
- //Thick Fur
- if(PPo.getSkillLevel(SkillType.TAMING) >= 250)
- event.setDamage(event.getDamage() / 2);
- }
- }
- }
- }
-
- public static void combatAbilityChecks(Player attacker, PlayerProfile PPa, Plugin pluginx)
- {
- //Check to see if any abilities need to be activated
- if(PPa.getAxePreparationMode())
- Axes.skullSplitterCheck(attacker);
- if(PPa.getSwordsPreparationMode())
- Swords.serratedStrikesActivationCheck(attacker);
- if(PPa.getFistsPreparationMode())
- Unarmed.berserkActivationCheck(attacker);
- }
- public static void archeryCheck(EntityDamageByEntityEvent event, mcMMO pluginx)
- {
- Arrow arrow = (Arrow)event.getDamager();
- Entity y = arrow.getShooter();
- Entity x = event.getEntity();
- if(x instanceof Player)
- {
- Player defender = (Player)x;
- PlayerProfile PPd = Users.getProfile(defender);
- if(PPd == null)
- Users.addUser(defender);
- if(mcPermissions.getInstance().unarmed(defender) && defender.getItemInHand().getTypeId() == 0)
- {
- if(defender != null && PPd.getSkillLevel(SkillType.UNARMED) >= 1000)
- {
- if(Math.random() * 1000 <= 500)
- {
- event.setCancelled(true);
- defender.sendMessage(mcLocale.getString("Combat.ArrowDeflect")); //$NON-NLS-1$
- return;
- }
- } else if(defender != null && Math.random() * 1000 <= (PPd.getSkillLevel(SkillType.UNARMED) / 2))
- {
- event.setCancelled(true);
- defender.sendMessage(mcLocale.getString("Combat.ArrowDeflect")); //$NON-NLS-1$
- return;
- }
- }
- }
- /*
- * If attacker is player
- */
- if(y instanceof Player)
- {
- Player attacker = (Player)y;
- PlayerProfile PPa = Users.getProfile(attacker);
- if(mcPermissions.getInstance().archery(attacker))
- {
- Archery.trackArrows(pluginx, x, event, attacker);
-
- /*
- * IGNITION
- */
- Archery.ignitionCheck(x, event, attacker);
- /*
- * Defender is Monster
- */
- if(!pluginx.misc.mobSpawnerList.contains(x))
- {
- int xp = getXp(event.getEntity(), event);
- PPa.addXP(SkillType.ARCHERY, xp*10, attacker);
- }
- /*
- * Attacker is Player
- */
- if(x instanceof Player){
- Player defender = (Player)x;
- PlayerProfile PPd = Users.getProfile(defender);
- /*
- * Stuff for the daze proc
- */
- if(PPa.inParty() && PPd.inParty())
- {
- if(Party.getInstance().inSameParty(defender, attacker))
- {
- event.setCancelled(true);
- return;
- }
- }
- /*
- * PVP XP
- */
- if(LoadProperties.pvpxp && !Party.getInstance().inSameParty(attacker, defender)
- && ((PPd.getLastLogin()+5)*1000) < System.currentTimeMillis() && !attacker.getName().equals(defender.getName()))
- {
- int xp = (int) ((event.getDamage() * 2) * 10);
- PPa.addXP(SkillType.ARCHERY, xp, attacker);
- }
- /*
- * DAZE PROC
- */
- Archery.dazeCheck(defender, attacker);
- }
- }
- Skills.XpCheckSkill(SkillType.ARCHERY, attacker);
- }
- }
-
- /**
- * Attempt to damage target for value dmg with reason CUSTOM
- *
- * @param target LivingEntity which to attempt to damage
- * @param dmg Amount of damage to attempt to do
- */
- public static void dealDamage(LivingEntity target, int dmg){
- EntityDamageEvent ede = new EntityDamageEvent(target, EntityDamageEvent.DamageCause.CUSTOM, dmg);
- Bukkit.getPluginManager().callEvent(ede);
- }
-
- /**
- * Attempt to damage target for value dmg with reason cause
- *
- * @param target LivingEntity which to attempt to damage
- * @param dmg Amount of damage to attempt to do
- * @param cause DamageCause to pass to damage event
- */
- public static void dealDamage(LivingEntity target, int dmg, DamageCause cause) {
- EntityDamageEvent ede = new EntityDamageEvent(target, cause, dmg);
- Bukkit.getPluginManager().callEvent(ede);
- }
-
- /**
- * Attempt to damage target for value dmg with reason ENTITY_ATTACK with damager attacker
- *
- * @param target LivingEntity which to attempt to damage
- * @param dmg Amount of damage to attempt to do
- * @param attacker Player to pass to event as damager
- */
- public static void dealDamage(LivingEntity target, int dmg, Player attacker) {
- EntityDamageEvent ede = new EntityDamageByEntityEvent(attacker, target, EntityDamageEvent.DamageCause.ENTITY_ATTACK, dmg);
- Bukkit.getPluginManager().callEvent(ede);
- }
-
- public static boolean pvpAllowed(EntityDamageByEntityEvent event, World world)
- {
- if(!event.getEntity().getWorld().getPVP())
- return false;
- //If it made it this far, pvp is enabled
- return true;
- }
- public static int getXp(Entity entity, EntityDamageEvent event)
- {
- int xp = 0;
- if(entity instanceof LivingEntity)
- {
- LivingEntity le = (LivingEntity)entity;
- //Prevent a ridiculous amount of XP being granted by capping it at the remaining health of the entity
- int hpLeft = le.getHealth(), xpinc = 0;
-
- if(hpLeft < event.getDamage())
- xpinc = hpLeft;
- else
- xpinc = event.getDamage();
-
- if(entity instanceof Animals)
- {
- xp = (int) (xpinc * 1);
- } else
- {
- if(entity instanceof Enderman)
- xp = (xpinc * 2);
- else if(entity instanceof Creeper)
- xp = (xpinc * 4);
- else if(entity instanceof Silverfish)
- xp = (xpinc * 3);
- else if(entity instanceof CaveSpider)
- xp = (xpinc * 3);
- else if(entity instanceof Spider)
- xp = (xpinc * 3);
- else if(entity instanceof Skeleton)
- xp = (xpinc * 2);
- else if(entity instanceof Zombie)
- xp = (xpinc * 2);
- else if(entity instanceof PigZombie)
- xp = (xpinc * 3);
- else if(entity instanceof Slime)
- xp = (xpinc * 2);
- else if(entity instanceof Ghast)
- xp = (xpinc * 3);
- else if(entity instanceof Blaze)
- xp = (xpinc * 3);
- else if(entity instanceof EnderDragon)
- xp = (xpinc * 8);
- }
- }
- return xp;
- }
- }
|