123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401 |
- package com.gmail.nossr50;
- import org.bukkit.ChatColor;
- import org.bukkit.Location;
- import org.bukkit.entity.Animals;
- import org.bukkit.entity.Creature;
- import org.bukkit.entity.Creeper;
- import org.bukkit.entity.Entity;
- import org.bukkit.entity.Monster;
- import org.bukkit.entity.PigZombie;
- import org.bukkit.entity.Player;
- import org.bukkit.entity.Skeleton;
- import org.bukkit.entity.Spider;
- import org.bukkit.entity.Squid;
- import org.bukkit.entity.Wolf;
- import org.bukkit.entity.Zombie;
- import org.bukkit.event.entity.EntityDamageByEntityEvent;
- import org.bukkit.event.entity.EntityDamageByProjectileEvent;
- import org.bukkit.event.entity.EntityDamageEvent;
- import org.bukkit.event.entity.EntityDamageEvent.DamageCause;
- import org.bukkit.inventory.ItemStack;
- import org.bukkit.plugin.Plugin;
- import com.gmail.nossr50.config.Config;
- import com.gmail.nossr50.config.LoadProperties;
- import com.gmail.nossr50.datatypes.PlayerProfile;
- import com.gmail.nossr50.party.Party;
- import com.gmail.nossr50.skills.Acrobatics;
- 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 {
- private static mcMMO plugin;
- public Combat(mcMMO instance) {
- plugin = instance;
- }
- public static void combatChecks(EntityDamageEvent event, Plugin pluginx){
- if(event.isCancelled() || event.getDamage() == 0)
- return;
- /*
- * OFFENSIVE CHECKS FOR PLAYERS VERSUS ENTITIES
- */
- if(event instanceof EntityDamageByEntityEvent && ((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) && PPa.getAxesInt() >= 500)
- event.setDamage(event.getDamage()+4);
-
- //If there are any abilities to activate
- combatAbilityChecks(attacker, PPa, pluginx);
-
- //Check for offensive procs
- if(mcPermissions.getInstance().axes(attacker))
- Axes.axeCriticalCheck(attacker, eventb, pluginx); //Axe Criticals
- if(!Config.getInstance().isBleedTracked(event.getEntity())) //Swords Bleed
- Swords.bleedCheck(attacker, 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() + 5000 && defender.getHealth() >= 1)
- {
- if(m.isAxes(attacker.getItemInHand()) && mcPermissions.getInstance().axes(attacker))
- PPa.addAxesXP((event.getDamage() * 3) * LoadProperties.pvpxprewardmodifier);
- if(m.isSwords(attacker.getItemInHand()) && mcPermissions.getInstance().swords(attacker))
- PPa.addSwordsXP((event.getDamage() * 3) * LoadProperties.pvpxprewardmodifier);
- if(attacker.getItemInHand().getTypeId() == 0 && mcPermissions.getInstance().unarmed(attacker))
- PPa.addUnarmedXP((event.getDamage() * 3) * LoadProperties.pvpxprewardmodifier);
- }
- }
- }
-
- if(event.getEntity() instanceof Monster)
- {
- int xp = 0;
- if(event.getEntity() instanceof Creeper)
- xp = (event.getDamage() * 4) * LoadProperties.xpGainMultiplier;
- if(event.getEntity() instanceof Spider)
- xp = (event.getDamage() * 3) * LoadProperties.xpGainMultiplier;
- if(event.getEntity() instanceof Skeleton)
- xp = (event.getDamage() * 2) * LoadProperties.xpGainMultiplier;
- if(event.getEntity() instanceof Zombie)
- xp = (event.getDamage() * 2) * LoadProperties.xpGainMultiplier;
- if(event.getEntity() instanceof PigZombie)
- xp = (event.getDamage() * 3) * LoadProperties.xpGainMultiplier;
-
- if(m.isSwords(attacker.getItemInHand()) && mcPermissions.getInstance().swords(attacker))
- PPa.addSwordsXP(xp);
- if(m.isAxes(attacker.getItemInHand()) && mcPermissions.getInstance().axes(attacker))
- PPa.addAxesXP(xp);
- if(attacker.getItemInHand().getTypeId() == 0 && mcPermissions.getInstance().unarmed(attacker))
- PPa.addUnarmedXP(xp);
- }
- Skills.XpCheck(attacker);
-
- //Taming Debug Stuff
- if(event.getEntity() instanceof Wolf)
- {
- if(Party.getInstance().inSameParty(attacker, Taming.getOwner(event.getEntity(), pluginx)))
- event.setCancelled(true);
- if(attacker.getItemInHand().getTypeId() == 352 && mcPermissions.getInstance().taming(attacker))
- {
- attacker.sendMessage(ChatColor.GREEN+"**You examine the Wolf using Beast Lore**");
- if(Taming.getOwnerName(event.getEntity()) != null)
- attacker.sendMessage(ChatColor.DARK_GREEN+"The Beast's Master : "+Taming.getOwnerName(event.getEntity()));
- else
- attacker.sendMessage(ChatColor.GRAY+"This Beast has no Master...");
- attacker.sendMessage(ChatColor.GREEN+"This beast has "+((Wolf)event.getEntity()).getHealth()+" Health");
- event.setCancelled(true);
- }
- }
- }
- /*
- * OFFENSIVE CHECKS FOR WOLVES VERSUS ENTITIES
- */
- if(event instanceof EntityDamageByEntityEvent && ((EntityDamageByEntityEvent) event).getDamager() instanceof Wolf)
- {
- EntityDamageByEntityEvent eventb = (EntityDamageByEntityEvent) event;
- if(Taming.hasOwner(eventb.getDamager(), pluginx))
- {
- Player master = Taming.getOwner(eventb.getDamager(), pluginx);
- PlayerProfile PPo = Users.getProfile(master);
- if(mcPermissions.getInstance().taming(master)){
- //Sharpened Claws
- if(PPo.getTamingInt() >= 750)
- {
- event.setDamage(event.getDamage() + 2);
- }
-
- //Gore
- if(Math.random() * 1000 <= PPo.getTamingInt())
- {
- event.setDamage(event.getDamage() * 2);
-
- if(event.getEntity() instanceof Player)
- {
- Player target = (Player)event.getEntity();
- target.sendMessage(ChatColor.RED+"**STRUCK BY GORE**");
- Users.getProfile(target).setBleedTicks(2);
- }
- else
- Config.getInstance().addToBleedQue(event.getEntity());
-
- master.sendMessage(ChatColor.GREEN+"**GORE**");
- }
- }
- }
- }
- //Another offensive check for Archery
- if(event instanceof EntityDamageByProjectileEvent)
- archeryCheck((EntityDamageByProjectileEvent) event);
-
- /*
- * DEFENSIVE CHECKS
- */
- if(event instanceof EntityDamageByEntityEvent && event.getEntity() instanceof Player)
- {
- Player defender = (Player)event.getEntity();
- Swords.parryCheck((EntityDamageByEntityEvent) event, defender);
- Swords.counterAttackChecks(event);
- Acrobatics.dodgeChecks((EntityDamageByEntityEvent)event);
- }
- /*
- * DEFENSIVE CHECKS FOR WOLVES
- */
- if(event.getEntity() instanceof Wolf){
- if(Taming.hasOwner(event.getEntity(), pluginx))
- {
- Player master = Taming.getOwner(event.getEntity(), pluginx);
- PlayerProfile PPo = Users.getProfile(master);
- if(mcPermissions.getInstance().taming(master))
- {
- /*
- * TEMPORARY FIX AS WOLVES AREN'T TRIGGERING DAMAGE EVENTS WHEN ATTACKING NON PLAYERS AT THE TIME OF WRITING
- */
- if(!event.isCancelled() && event.getCause() != DamageCause.LIGHTNING){
- PPo.addTamingXP(event.getDamage() * 3);
- Skills.XpCheck(master);
- }
-
- //Shock-Proof
- if((event.getCause() == DamageCause.ENTITY_EXPLOSION || event.getCause() == DamageCause.BLOCK_EXPLOSION) && PPo.getTamingInt() >= 500)
- {
- event.setDamage(2);
- }
-
- //Thick Fur
- if(PPo.getTamingInt() >= 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, pluginx);
- if(PPa.getSwordsPreparationMode())
- Swords.serratedStrikesActivationCheck(attacker, pluginx);
- if(PPa.getFistsPreparationMode())
- Unarmed.berserkActivationCheck(attacker, pluginx);
- }
- public static void archeryCheck(EntityDamageByProjectileEvent event){
- Entity y = event.getDamager();
- Entity x = event.getEntity();
- if(event.getProjectile().toString().equals("CraftArrow") && 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.getUnarmedInt() >= 1000){
- if(Math.random() * 1000 <= 500){
- event.setCancelled(true);
- defender.sendMessage(ChatColor.WHITE+"**ARROW DEFLECT**");
- return;
- }
- } else if(defender != null && Math.random() * 1000 <= (PPd.getUnarmedInt() / 2)){
- event.setCancelled(true);
- defender.sendMessage(ChatColor.WHITE+"**ARROW DEFLECT**");
- return;
- }
- }
- }
- /*
- * If attacker is player
- */
- if(y instanceof Player){
- Player attacker = (Player)y;
- PlayerProfile PPa = Users.getProfile(attacker);
- if(event.getProjectile().toString().equals("CraftArrow") && mcPermissions.getInstance().archery(attacker)){
- if(!Config.getInstance().isTracked(x) && event.getDamage() > 0){
- Config.getInstance().addArrowTrack(x, 0);
- if(attacker != null){
- if(Math.random() * 1000 <= PPa.getArcheryInt()){
- Config.getInstance().addArrowCount(x, 1);
- }
- }
- } else {
- if(event.getDamage() > 0){
- if(attacker != null){
- if(Math.random() * 1000 <= PPa.getArcheryInt()){
- Config.getInstance().addArrowCount(x, 1);
- }
- }
- }
- }
- /*
- * DAMAGE MODIFIER
- */
- if(PPa.getArcheryInt() >= 50 && PPa.getArcheryInt() < 250)
- event.setDamage(event.getDamage()+1);
- if(PPa.getArcheryInt() >= 250 && PPa.getArcheryInt() < 575)
- event.setDamage(event.getDamage()+2);
- if(PPa.getArcheryInt() >= 575 && PPa.getArcheryInt() < 725)
- event.setDamage(event.getDamage()+3);
- if(PPa.getArcheryInt() >= 725 && PPa.getArcheryInt() < 1000)
- event.setDamage(event.getDamage()+4);
- if(PPa.getArcheryInt() >= 1000)
- event.setDamage(event.getDamage()+5);
-
- /*
- * IGNITION
- */
- if(Math.random() * 100 >= 75){
-
- int ignition = 20;
- if(PPa.getArcheryInt() >= 200)
- ignition+=20;
- if(PPa.getArcheryInt() >= 400)
- ignition+=20;
- if(PPa.getArcheryInt() >= 600)
- ignition+=20;
- if(PPa.getArcheryInt() >= 800)
- ignition+=20;
- if(PPa.getArcheryInt() >= 1000)
- ignition+=20;
-
- if(x instanceof Player){
- Player Defender = (Player)x;
- if(!Party.getInstance().inSameParty(attacker, Defender)){
- event.getEntity().setFireTicks(ignition);
- attacker.sendMessage(ChatColor.RED+"**IGNITION**");
- Defender.sendMessage(ChatColor.DARK_RED+"You were struck by a burning arrow!");
- }
- } else {
- event.getEntity().setFireTicks(ignition);
- attacker.sendMessage(ChatColor.RED+"**IGNITION**");
- }
- }
- /*
- * Defender is Monster
- */
- if(x instanceof Monster){
- //XP
- if(!Config.getInstance().isMobSpawnTracked(x)){
- if(x instanceof Creeper)
- PPa.addArcheryXP((event.getDamage() * 4) * LoadProperties.xpGainMultiplier);
- if(x instanceof Spider)
- PPa.addArcheryXP((event.getDamage() * 3) * LoadProperties.xpGainMultiplier);
- if(x instanceof Skeleton)
- PPa.addArcheryXP((event.getDamage() * 2) * LoadProperties.xpGainMultiplier);
- if(x instanceof Zombie)
- PPa.addArcheryXP((event.getDamage() * 2) * LoadProperties.xpGainMultiplier);
- if(x instanceof PigZombie)
- PPa.addArcheryXP((event.getDamage() * 3) * LoadProperties.xpGainMultiplier);
- }
- }
- /*
- * Attacker is Player
- */
- if(x instanceof Player){
- if(LoadProperties.pvp == false){
- event.setCancelled(true);
- return;
- }
- 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)){
- PPa.addArcheryXP((event.getDamage() * 3) * LoadProperties.pvpxprewardmodifier);
- }
- /*
- * DAZE PROC
- */
- Location loc = defender.getLocation();
- if(Math.random() * 10 > 5){
- loc.setPitch(90);
- } else {
- loc.setPitch(-90);
- }
- if(PPa.getArcheryInt() >= 1000){
- if(Math.random() * 1000 <= 500){
- defender.teleportTo(loc);
- defender.sendMessage(ChatColor.DARK_RED+"Touched Fuzzy. Felt Dizzy.");
- attacker.sendMessage("Target was "+ChatColor.DARK_RED+"Dazed");
- }
- } else if(Math.random() * 2000 <= PPa.getArcheryInt()){
- defender.teleportTo(loc);
- defender.sendMessage(ChatColor.DARK_RED+"Touched Fuzzy. Felt Dizzy.");
- attacker.sendMessage("Target was "+ChatColor.DARK_RED+"Dazed");
- }
- }
- }
- Skills.XpCheck(attacker);
- }
- }
- public static void dealDamage(Entity target, int dmg){
- if(target instanceof Player){
- ((Player) target).damage(dmg);
- }
- if(target instanceof Animals){
- ((Animals) target).damage(dmg);
- }
- if(target instanceof Monster){
- ((Monster) target).damage(dmg);
- }
- }
- }
|