From 07f6247235448ea476a6931c6c534f85603f2676 Mon Sep 17 00:00:00 2001 From: Indyuce Date: Sat, 19 Feb 2022 11:23:31 +0100 Subject: [PATCH] Fixed an issue with custom arrows --- .../projectile/ArrowParticles.java | 5 +++ .../weapon/untargeted/Crossbow.java | 2 +- .../mmoitems/listener/PlayerListener.java | 2 +- .../mmoitems/manager/EntityManager.java | 36 ++++++++----------- 4 files changed, 21 insertions(+), 24 deletions(-) diff --git a/src/main/java/net/Indyuce/mmoitems/api/interaction/projectile/ArrowParticles.java b/src/main/java/net/Indyuce/mmoitems/api/interaction/projectile/ArrowParticles.java index 49bfa38b..2c89f999 100644 --- a/src/main/java/net/Indyuce/mmoitems/api/interaction/projectile/ArrowParticles.java +++ b/src/main/java/net/Indyuce/mmoitems/api/interaction/projectile/ArrowParticles.java @@ -2,6 +2,7 @@ package net.Indyuce.mmoitems.api.interaction.projectile; import com.google.gson.JsonObject; import com.google.gson.JsonParser; +import io.lumine.mythic.lib.player.particle.ParticleInformation; import net.Indyuce.mmoitems.MMOItems; import io.lumine.mythic.lib.api.item.NBTItem; @@ -10,6 +11,10 @@ import org.bukkit.Particle; import org.bukkit.entity.Arrow; import org.bukkit.scheduler.BukkitRunnable; +/** + * @deprecated Merge with {@link ParticleInformation} + */ +@Deprecated public class ArrowParticles extends BukkitRunnable { private final Arrow arrow; diff --git a/src/main/java/net/Indyuce/mmoitems/api/interaction/weapon/untargeted/Crossbow.java b/src/main/java/net/Indyuce/mmoitems/api/interaction/weapon/untargeted/Crossbow.java index 7ddf8c44..a1cae78b 100644 --- a/src/main/java/net/Indyuce/mmoitems/api/interaction/weapon/untargeted/Crossbow.java +++ b/src/main/java/net/Indyuce/mmoitems/api/interaction/weapon/untargeted/Crossbow.java @@ -49,6 +49,6 @@ public class Crossbow extends UntargetedWeapon { getPlayer().getEyeLocation().getDirection().multiply(3 * getValue(getNBTItem().getStat(ItemStats.ARROW_VELOCITY.getId()), 1))); getPlayer().setVelocity(getPlayer().getVelocity().setX(0).setZ(0)); - MMOItems.plugin.getEntities().registerCustomProjectile(getNBTItem(), stats, arrow, true); + MMOItems.plugin.getEntities().registerCustomProjectile(getNBTItem(), stats, arrow, true, 1); } } diff --git a/src/main/java/net/Indyuce/mmoitems/listener/PlayerListener.java b/src/main/java/net/Indyuce/mmoitems/listener/PlayerListener.java index b5651aea..784cfbe2 100644 --- a/src/main/java/net/Indyuce/mmoitems/listener/PlayerListener.java +++ b/src/main/java/net/Indyuce/mmoitems/listener/PlayerListener.java @@ -286,7 +286,7 @@ public class PlayerListener implements Listener { } } - MMOItems.plugin.getEntities().registerCustomProjectile(nbtItem, playerData.getStats().newTemporary(EquipmentSlot.fromBukkit(item.getSlot())), event.getEntity(), type != null); + MMOItems.plugin.getEntities().registerCustomProjectile(nbtItem, playerData.getStats().newTemporary(EquipmentSlot.fromBukkit(item.getSlot())), event.getEntity(), type != null, 1); } /** diff --git a/src/main/java/net/Indyuce/mmoitems/manager/EntityManager.java b/src/main/java/net/Indyuce/mmoitems/manager/EntityManager.java index 66cb3461..598268f0 100644 --- a/src/main/java/net/Indyuce/mmoitems/manager/EntityManager.java +++ b/src/main/java/net/Indyuce/mmoitems/manager/EntityManager.java @@ -32,12 +32,7 @@ public class EntityManager implements Listener { */ private final Map entities = new HashMap<>(); - private final WeakHashMap projectiles = new WeakHashMap<>(); - - @Deprecated - public void registerCustomProjectile(NBTItem sourceItem, PlayerMetadata attacker, Entity entity, boolean customWeapon) { - registerCustomProjectile(sourceItem, attacker, entity, customWeapon, 1); - } + private final Map projectiles = new WeakHashMap<>(); /** * Registers a custom projectile. This is used for bows, crossbows and tridents. @@ -53,18 +48,19 @@ public class EntityManager implements Listener { */ public void registerCustomProjectile(@NotNull NBTItem sourceItem, @NotNull PlayerMetadata attacker, @NotNull Entity entity, boolean customWeapon, double damageMultiplicator) { + // Initialize projectile data + ProjectileData projectileData = new ProjectileData(attacker, sourceItem, customWeapon); + /* * For bows, MC default value is 7. When using custom bows, the attack * damage stats returns the correct amount of damage. When using a vanilla * bow, attack damage is set to 2 because it's the default fist damage value. * Therefore MMOItems adds 5 to match the vanilla bow damage which is 7. * - * Damage coefficient is how much you pull the bow. It's something between 0 - * and 1 for bows, and it's always 1 for tridents or crossbows. + * Damage coefficient is how much you pull the bow. It's a float between + * 0 and 1 for bows, and it is always 1 for tridents or crossbows. */ - double damage = attacker.getStat("ATTACK_DAMAGE"); - damage = (customWeapon ? damage : 5 + damage) * damageMultiplicator; - attacker.setStat("ATTACK_DAMAGE", damage); + projectileData.setDamage((attacker.getStat("ATTACK_DAMAGE") + (customWeapon ? 0 : 5)) * damageMultiplicator); /* * Load arrow particles if the entity is an arrow and if the item has @@ -74,7 +70,7 @@ public class EntityManager implements Listener { if (entity instanceof Arrow && sourceItem.hasTag("MMOITEMS_ARROW_PARTICLES")) new ArrowParticles((Arrow) entity, sourceItem); - projectiles.put(entity.getEntityId(), new ProjectileData(attacker, sourceItem, customWeapon)); + projectiles.put(entity.getEntityId(), projectileData); } public void registerCustomEntity(Entity entity, EntityData data) { @@ -106,13 +102,13 @@ public class EntityManager implements Listener { } @EventHandler(priority = EventPriority.HIGHEST) - public void a(EntityDeathEvent event) { + public void unregisterEntityData(EntityDeathEvent event) { Bukkit.getScheduler().scheduleSyncDelayedTask(MMOItems.plugin, () -> unregisterCustomEntity(event.getEntity())); } // Projectile damage and effects @EventHandler(ignoreCancelled = true) - public void b(EntityDamageByEntityEvent event) { + public void applyOnHitEffects(EntityDamageByEntityEvent event) { if (!(event.getDamager() instanceof Projectile) || !(event.getEntity() instanceof LivingEntity) || event.getEntity().hasMetadata("NPC")) return; @@ -145,17 +141,13 @@ public class EntityManager implements Listener { // Unregister custom projectiles from the map @EventHandler(priority = EventPriority.HIGHEST) - public void c(EntityDamageByEntityEvent event) { - projectiles.remove(event.getEntity().getEntityId()); + public void unregisterOnBlockHit(ProjectileHitEvent event) { + if (event.getHitBlock() != null) + projectiles.remove(event.getEntity().getEntityId()); } @EventHandler(priority = EventPriority.HIGHEST) - public void d(ProjectileHitEvent event) { - projectiles.remove(event.getEntity().getEntityId()); - } - - @EventHandler(priority = EventPriority.HIGHEST) - public void e(EntityDeathEvent event) { + public void unregisterOnEntityHit(EntityDeathEvent event) { projectiles.remove(event.getEntity().getEntityId()); } } \ No newline at end of file