123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596 |
- package com.gmail.nossr50.skills.utilities;
- import org.bukkit.Material;
- import org.bukkit.enchantments.Enchantment;
- import org.bukkit.entity.Animals;
- import org.bukkit.entity.Arrow;
- import org.bukkit.entity.Entity;
- import org.bukkit.entity.EntityType;
- import org.bukkit.entity.IronGolem;
- import org.bukkit.entity.LightningStrike;
- import org.bukkit.entity.LivingEntity;
- import org.bukkit.entity.Player;
- import org.bukkit.entity.Skeleton;
- import org.bukkit.entity.Tameable;
- import org.bukkit.entity.Wolf;
- import org.bukkit.event.entity.EntityDamageByEntityEvent;
- import org.bukkit.event.entity.EntityDamageEvent;
- import org.bukkit.event.entity.EntityDamageEvent.DamageCause;
- import org.bukkit.event.player.PlayerAnimationEvent;
- import org.bukkit.inventory.ItemStack;
- import com.gmail.nossr50.mcMMO;
- import com.gmail.nossr50.config.Config;
- import com.gmail.nossr50.datatypes.McMMOPlayer;
- import com.gmail.nossr50.datatypes.PlayerProfile;
- import com.gmail.nossr50.events.fake.FakeEntityDamageByEntityEvent;
- import com.gmail.nossr50.events.fake.FakeEntityDamageEvent;
- import com.gmail.nossr50.locale.LocaleLoader;
- import com.gmail.nossr50.party.PartyManager;
- import com.gmail.nossr50.skills.acrobatics.Acrobatics;
- import com.gmail.nossr50.skills.acrobatics.AcrobaticsManager;
- import com.gmail.nossr50.skills.archery.Archery;
- import com.gmail.nossr50.skills.archery.ArcheryManager;
- import com.gmail.nossr50.skills.axes.AxeManager;
- import com.gmail.nossr50.skills.axes.Axes;
- import com.gmail.nossr50.skills.runnables.BleedTimer;
- import com.gmail.nossr50.skills.runnables.CombatXpGiver;
- import com.gmail.nossr50.skills.swords.Swords;
- import com.gmail.nossr50.skills.swords.SwordsManager;
- import com.gmail.nossr50.skills.taming.Taming;
- import com.gmail.nossr50.skills.taming.TamingManager;
- import com.gmail.nossr50.skills.unarmed.Unarmed;
- import com.gmail.nossr50.skills.unarmed.UnarmedManager;
- import com.gmail.nossr50.util.ItemChecks;
- import com.gmail.nossr50.util.Misc;
- import com.gmail.nossr50.util.Permissions;
- import com.gmail.nossr50.util.Users;
- public final class CombatTools {
- private static Config configInstance = Config.getInstance();
- private CombatTools() {}
- /**
- * Apply combat modifiers and process and XP gain.
- *
- * @param event The event to run the combat checks on.
- */
- public static void combatChecks(EntityDamageByEntityEvent event, Entity attacker, LivingEntity target) {
- boolean targetIsPlayer = (target.getType() == EntityType.PLAYER);
- boolean targetIsTamedPet = (target instanceof Tameable) ? ((Tameable) target).isTamed() : false;
- if (attacker instanceof Player) {
- Player player = (Player) attacker;
- if (Misc.isNPCPlayer(player)) {
- return;
- }
- ItemStack heldItem = player.getItemInHand();
- Material heldItemType = heldItem.getType();
- if (ItemChecks.isSword(heldItem)) {
- if (targetIsPlayer || targetIsTamedPet) {
- if (!Swords.pvpEnabled) {
- return;
- }
- }
- else if (!Swords.pveEnabled) {
- return;
- }
- if (Permissions.swords(player)) {
- McMMOPlayer mcMMOPlayer = Users.getPlayer(player);
- PlayerProfile profile = mcMMOPlayer.getProfile();
- SwordsManager swordsManager = new SwordsManager(mcMMOPlayer);
- boolean canSerratedStrike = Permissions.serratedStrikes(player); //So we don't have to check the same permission twice
- if (profile.getToolPreparationMode(ToolType.SWORD) && canSerratedStrike) {
- SkillTools.abilityCheck(player, SkillType.SWORDS);
- }
- if (Permissions.swordsBleed(player) && shouldBeAffected(player, target)) {
- swordsManager.bleedCheck(target);
- }
- if (profile.getAbilityMode(AbilityType.SERRATED_STRIKES) && canSerratedStrike) {
- swordsManager.serratedStrikes(target, event.getDamage());
- }
- startGainXp(mcMMOPlayer, target, SkillType.SWORDS);
- }
- }
- else if (ItemChecks.isAxe(heldItem)) {
- if (targetIsPlayer || targetIsTamedPet) {
- if (!Axes.pvpEnabled) {
- return;
- }
- }
- else if (!Axes.pveEnabled) {
- return;
- }
- if (Permissions.axes(player)) {
- McMMOPlayer mcMMOPlayer = Users.getPlayer(player);
- PlayerProfile profile = mcMMOPlayer.getProfile();
- AxeManager axeManager = new AxeManager(mcMMOPlayer);
- boolean canSkullSplit = Permissions.skullSplitter(player); //So we don't have to check the same permission twice
- if (profile.getToolPreparationMode(ToolType.AXE) && canSkullSplit) {
- SkillTools.abilityCheck(player, SkillType.AXES);
- }
- if (Permissions.axeBonus(player)) {
- axeManager.bonusDamage(event);
- }
- if (!target.isDead() && Permissions.criticalHit(player) && shouldBeAffected(player, target)) {
- axeManager.criticalHitCheck(event, target);
- }
- if (!target.isDead() && Permissions.impact(player)) {
- axeManager.impact(event, target);
- }
- if (!target.isDead() && profile.getAbilityMode(AbilityType.SKULL_SPLIITER) && canSkullSplit) {
- axeManager.skullSplitter(target, event.getDamage());
- }
- startGainXp(mcMMOPlayer, target, SkillType.AXES);
- }
- }
- else if (heldItemType == Material.AIR) {
- if (targetIsPlayer || targetIsTamedPet) {
- if (!configInstance.getUnarmedPVP()) {
- return;
- }
- }
- else if (!configInstance.getUnarmedPVE()) {
- return;
- }
- if (Permissions.unarmed(player)) {
- McMMOPlayer mcMMOPlayer = Users.getPlayer(player);
- PlayerProfile profile = mcMMOPlayer.getProfile();
- UnarmedManager unarmedManager = new UnarmedManager(mcMMOPlayer);
- boolean canBerserk = Permissions.berserk(player); //So we don't have to check the same permission twice
- if (profile.getToolPreparationMode(ToolType.FISTS) && canBerserk) {
- SkillTools.abilityCheck(player, SkillType.UNARMED);
- }
- if (Permissions.unarmedBonus(player)) {
- unarmedManager.bonusDamage(event);
- }
- if (profile.getAbilityMode(AbilityType.BERSERK) && canBerserk) {
- unarmedManager.berserkDamage(event);
- }
- if (target instanceof Player && Permissions.disarm(player)) {
- unarmedManager.disarmCheck(target);
- }
- startGainXp(mcMMOPlayer, target, SkillType.UNARMED);
- }
- }
- else if (heldItemType == Material.BONE && target instanceof Tameable && Permissions.beastLore(player)) {
- TamingManager tamingManager = new TamingManager(Users.getPlayer(player));
- tamingManager.beastLore(target);
- event.setCancelled(true);
- }
- }
- Entity damager = event.getDamager();
- switch (damager.getType()) {
- case WOLF:
- Wolf wolf = (Wolf) damager;
- if (wolf.isTamed() && wolf.getOwner() instanceof Player) {
- Player master = (Player) wolf.getOwner();
- if (Misc.isNPCPlayer(master)) {
- return;
- }
- if (targetIsPlayer || targetIsTamedPet) {
- if (!Taming.pvpEnabled) {
- return;
- }
- }
- else if (!Taming.pveEnabled) {
- return;
- }
- if (Permissions.taming(master)) {
- McMMOPlayer mcMMOPlayer = Users.getPlayer(master);
- TamingManager tamingManager = new TamingManager(mcMMOPlayer);
- int skillLevel = tamingManager.getSkillLevel();
- if (skillLevel >= Taming.fastFoodServiceUnlockLevel && Permissions.fastFoodService(master)) {
- tamingManager.fastFoodService(wolf, event.getDamage());
- }
- if (skillLevel >= Taming.sharpenedClawsUnlockLevel && Permissions.sharpenedClaws(master)) {
- tamingManager.sharpenedClaws(event);
- }
- if (Permissions.gore(master)) {
- tamingManager.gore(event);
- }
- if (target != master) {
- startGainXp(mcMMOPlayer, target, SkillType.TAMING);
- }
- }
- }
- break;
- case ARROW:
- LivingEntity shooter = ((Arrow) damager).getShooter();
- /* Break instead of return due to Dodge/Counter/Deflect abilities */
- if (shooter == null || !(shooter instanceof Player)) {
- break;
- }
- if (targetIsPlayer || targetIsTamedPet) {
- if (!Archery.pvpEnabled) {
- return;
- }
- }
- else if (!Archery.pveEnabled) {
- return;
- }
- archeryCheck((Player) shooter, target, event);
- break;
- default:
- break;
- }
- if (targetIsPlayer) {
- Player player = (Player) target;
- if (Misc.isNPCPlayer(player)) {
- return;
- }
- ItemStack heldItem = player.getItemInHand();
- if (damager instanceof Player) {
- if (Swords.pvpEnabled && ItemChecks.isSword(heldItem) && Permissions.counterAttack(player)) {
- SwordsManager swordsManager = new SwordsManager(Users.getPlayer(player));
- swordsManager.counterAttackChecks((LivingEntity) damager, event.getDamage());
- }
- if (Acrobatics.pvpEnabled && Permissions.dodge(player)) {
- AcrobaticsManager acrobaticsManager = new AcrobaticsManager(Users.getPlayer(player));
- acrobaticsManager.dodgeCheck(event);
- }
- }
- else {
- if (Swords.pveEnabled && damager instanceof LivingEntity && ItemChecks.isSword(heldItem) && Permissions.counterAttack(player)) {
- SwordsManager swordsManager = new SwordsManager(Users.getPlayer(player));
- swordsManager.counterAttackChecks((LivingEntity) damager, event.getDamage());
- }
- if (Acrobatics.pveEnabled && !(damager instanceof LightningStrike && Acrobatics.dodgeLightningDisabled) && Permissions.dodge(player)) {
- AcrobaticsManager acrobaticsManager = new AcrobaticsManager(Users.getPlayer(player));
- acrobaticsManager.dodgeCheck(event);
- }
- }
- }
- }
- /**
- * Process archery abilities.
- *
- * @param shooter The player shooting
- * @param target The defending entity
- * @param event The event to run the archery checks on.
- */
- private static void archeryCheck(Player shooter, LivingEntity target, EntityDamageByEntityEvent event) {
- if (Misc.isNPCPlayer(shooter)) {
- return;
- }
- if (Permissions.archery(shooter)) {
- McMMOPlayer mcMMOPlayer = Users.getPlayer(shooter);
- ArcheryManager archeryManager = new ArcheryManager(mcMMOPlayer);
- archeryManager.skillShot(event);
- if (target instanceof Player) {
- if (Unarmed.pvpEnabled && ((Player) target).getItemInHand().getType() == Material.AIR && Permissions.deflect((Player) target)) {
- UnarmedManager unarmedManager = new UnarmedManager(Users.getPlayer((Player) target));
- unarmedManager.deflectCheck(event);
- }
- if (Permissions.daze(shooter)) {
- archeryManager.dazeCheck((Player) target, event);
- }
- }
- if (!(shooter.getItemInHand().containsEnchantment(Enchantment.ARROW_INFINITE)) && Permissions.trackArrows(shooter)) {
- archeryManager.trackArrows(target);
- }
- if (target != shooter) {
- archeryManager.distanceXpBonus(target);
- startGainXp(mcMMOPlayer, target, SkillType.ARCHERY);
- }
- }
- }
- /**
- * 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) {
- dealDamage(target, dmg, EntityDamageEvent.DamageCause.CUSTOM);
- }
- /**
- * 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
- */
- private static void dealDamage(LivingEntity target, int dmg, DamageCause cause) {
- if (configInstance.getEventCallbackEnabled()) {
- EntityDamageEvent ede = new FakeEntityDamageEvent(target, cause, dmg);
- mcMMO.p.getServer().getPluginManager().callEvent(ede);
- if (ede.isCancelled()) {
- return;
- }
- target.damage(ede.getDamage());
- }
- else {
- target.damage(dmg);
- }
- }
- /**
- * 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
- */
- private static void dealDamage(LivingEntity target, int dmg, Player attacker) {
- if (configInstance.getEventCallbackEnabled()) {
- EntityDamageEvent ede = new FakeEntityDamageByEntityEvent(attacker, target, EntityDamageEvent.DamageCause.ENTITY_ATTACK, dmg);
- mcMMO.p.getServer().getPluginManager().callEvent(ede);
- if (ede.isCancelled()) {
- return;
- }
- target.damage(ede.getDamage());
- }
- else {
- target.damage(dmg);
- }
- }
- /**
- * Apply Area-of-Effect ability actions.
- *
- * @param attacker The attacking player
- * @param target The defending entity
- * @param damage The initial damage amount
- * @param type The type of skill being used
- */
- public static void applyAbilityAoE(Player attacker, LivingEntity target, int damage, SkillType type) {
- int numberOfTargets = Misc.getTier(attacker.getItemInHand()); //The higher the weapon tier, the more targets you hit
- int damageAmount = damage;
- if (damageAmount < 1) {
- damageAmount = 1;
- }
- for (Entity entity : target.getNearbyEntities(2.5, 2.5, 2.5)) {
- if ((entity instanceof Player && Misc.isNPCPlayer((Player) entity)) || !(entity instanceof LivingEntity) || !shouldBeAffected(attacker, entity)) {
- continue;
- }
- if (numberOfTargets <= 0) {
- break;
- }
- PlayerAnimationEvent armswing = new PlayerAnimationEvent(attacker);
- mcMMO.p.getServer().getPluginManager().callEvent(armswing);
- switch (type) {
- case SWORDS:
- if (entity instanceof Player) {
- ((Player) entity).sendMessage(LocaleLoader.getString("Swords.Combat.SS.Struck"));
- }
- BleedTimer.add((LivingEntity) entity, Swords.serratedStrikesBleedTicks);
- break;
- case AXES:
- if (entity instanceof Player) {
- ((Player) entity).sendMessage(LocaleLoader.getString("Axes.Combat.Cleave.Struck"));
- }
- break;
- default:
- break;
- }
- dealDamage((LivingEntity) entity, damageAmount, attacker);
- numberOfTargets--;
- }
- }
- /**
- * Start the task that gives combat XP.
- *
- * @param mcMMOPlayer The attacking player
- * @param target The defending entity
- * @param skillType The skill being used
- */
- public static void startGainXp(McMMOPlayer mcMMOPlayer, LivingEntity target, SkillType skillType) {
- double baseXP = 0;
- if (target instanceof Player) {
- if (!configInstance.getExperienceGainsPlayerVersusPlayerEnabled()) {
- return;
- }
- Player defender = (Player) target;
- if (System.currentTimeMillis() >= Users.getPlayer(defender).getProfile().getRespawnATS() + 5) {
- baseXP = 20 * configInstance.getPlayerVersusPlayerXP();
- }
- }
- else if (!mcMMO.placeStore.isSpawnedMob(target)) {
- if (target instanceof Animals && !mcMMO.placeStore.isSpawnedPet(target)) {
- baseXP = configInstance.getAnimalsXP();
- }
- else {
- EntityType type = target.getType();
- switch (type) {
- case BAT:
- baseXP = configInstance.getAnimalsXP();
- break;
- case BLAZE:
- baseXP = configInstance.getBlazeXP();
- break;
- case CAVE_SPIDER:
- baseXP = configInstance.getCaveSpiderXP();
- break;
- case CREEPER:
- baseXP = configInstance.getCreeperXP();
- break;
- case ENDER_DRAGON:
- baseXP = configInstance.getEnderDragonXP();
- break;
- case ENDERMAN:
- baseXP = configInstance.getEndermanXP();
- break;
- case GHAST:
- baseXP = configInstance.getGhastXP();
- break;
- case GIANT:
- baseXP = configInstance.getGiantXP();
- break;
- case MAGMA_CUBE:
- baseXP = configInstance.getMagmaCubeXP();
- break;
- case IRON_GOLEM:
- if (!((IronGolem) target).isPlayerCreated()) {
- baseXP = configInstance.getIronGolemXP();
- }
- break;
- case PIG_ZOMBIE:
- baseXP = configInstance.getPigZombieXP();
- break;
- case SILVERFISH:
- baseXP = configInstance.getSilverfishXP();
- break;
- case SKELETON:
- switch(((Skeleton) target).getSkeletonType()) {
- case WITHER:
- baseXP = configInstance.getWitherSkeletonXP();
- break;
- default:
- baseXP = configInstance.getSkeletonXP();
- break;
- }
- case SLIME:
- baseXP = configInstance.getSlimeXP();
- break;
- case SPIDER:
- baseXP = configInstance.getSpiderXP();
- break;
- case WITCH:
- baseXP = configInstance.getWitchXP();
- break;
- case WITHER:
- baseXP = configInstance.getWitherXP();
- break;
- case ZOMBIE:
- baseXP = configInstance.getZombieXP();
- break;
- default:
- break;
- }
- }
- baseXP *= 10;
- }
- if (baseXP != 0) {
- mcMMO.p.getServer().getScheduler().scheduleSyncDelayedTask(mcMMO.p, new CombatXpGiver(mcMMOPlayer, skillType, baseXP, target), 0);
- }
- }
- /**
- * Check to see if the given LivingEntity should be affected by a combat ability.
- *
- * @param player The attacking Player
- * @param entity The defending Entity
- * @return true if the Entity should be damaged, false otherwise.
- */
- public static boolean shouldBeAffected(Player player, Entity entity) {
- if (entity instanceof Player) {
- Player defender = (Player) entity;
- if (!defender.getWorld().getPVP() || defender == player || Users.getPlayer(defender).getProfile().getGodMode()) {
- return false;
- }
- if (PartyManager.inSameParty(player, defender) && !Config.getInstance().getPartyFriendlyFire()) {
- return false;
- }
- //It may seem a bit redundant but we need a check here to prevent bleed from being applied in applyAbilityAoE()
- EntityDamageEvent ede = new FakeEntityDamageByEntityEvent(player, entity, EntityDamageEvent.DamageCause.ENTITY_ATTACK, 1);
- mcMMO.p.getServer().getPluginManager().callEvent(ede);
- if (ede.isCancelled()) {
- return false;
- }
- }
- else if (entity instanceof Tameable) {
- if (Misc.isFriendlyPet(player, (Tameable) entity) && !Config.getInstance().getPartyFriendlyFire()) {
- return false;
- }
- }
- return true;
- }
- }
|