9
0
mirror of https://github.com/Auxilor/EcoMobs.git synced 2025-12-21 16:09:24 +00:00

Added top damager tracking

This commit is contained in:
Auxilor
2021-03-13 13:13:08 +00:00
parent 29958973ae
commit 8e6232496b
8 changed files with 290 additions and 15 deletions

View File

@@ -119,8 +119,8 @@ public class EcoBossesPlugin extends AbstractEcoPlugin {
@Override
public List<Listener> getListeners() {
return Arrays.asList(
new AttackListeners(),
new DeathListeners(),
new AttackListeners(this),
new DeathListeners(this),
new SpawnListeners(this)
);
}

View File

@@ -2,6 +2,7 @@ package com.willfp.ecobosses.bosses;
import com.willfp.eco.internal.config.AbstractUndefinedConfig;
import com.willfp.eco.util.NumberUtils;
import com.willfp.eco.util.StringUtils;
import com.willfp.eco.util.internal.PluginDependent;
import com.willfp.eco.util.plugin.AbstractEcoPlugin;
import com.willfp.ecobosses.bosses.util.bosstype.BossEntityUtils;
@@ -36,14 +37,17 @@ import org.bukkit.inventory.ItemStack;
import org.bukkit.persistence.PersistentDataType;
import org.bukkit.potion.PotionEffect;
import org.bukkit.potion.PotionEffectType;
import org.bukkit.util.StringUtil;
import org.jetbrains.annotations.NotNull;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Base64;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
@@ -117,7 +121,7 @@ public class EcoBoss extends PluginDependent {
* The drops.
*/
@Getter
private final List<ItemStack> drops;
private final Map<Double, ItemStack> drops;
/**
* The exp to drop.
@@ -185,6 +189,18 @@ public class EcoBoss extends PluginDependent {
@Getter
private final TeleportOptions teleportOptions;
/**
* Spawn messages.
*/
@Getter
private final List<String> spawnMessages;
/**
* Death messages.
*/
@Getter
private final List<String> deathMessages;
/**
* Create a new Boss.
*
@@ -224,9 +240,15 @@ public class EcoBoss extends PluginDependent {
);
// Rewards
this.drops = new ArrayList<>();
this.drops = new HashMap<>();
for (String string : this.getConfig().getStrings("rewards.drops")) {
YamlConfiguration tempConfig = new YamlConfiguration();
double chance = 100;
if (string.contains("::")) {
String[] split = string.split("::");
chance = Double.parseDouble(split[0]);
string = split[1];
}
String tempConfigString = new String(Base64.getDecoder().decode(string));
try {
tempConfig.load(tempConfigString);
@@ -234,7 +256,7 @@ public class EcoBoss extends PluginDependent {
e.printStackTrace();
}
ItemStack itemStack = tempConfig.getItemStack("drop-key");
this.drops.add(itemStack);
this.drops.put(chance, itemStack);
}
this.experienceOptions = new ExperienceOptions(
this.getConfig().getInt("rewards.xp.minimum"),
@@ -339,6 +361,16 @@ public class EcoBoss extends PluginDependent {
*/
// Messages
this.spawnMessages = new ArrayList<>();
for (String string : this.getConfig().getStrings("broadcast.spawn")) {
this.spawnMessages.add(StringUtils.translate(string));
}
this.deathMessages = new ArrayList<>();
for (String string : this.getConfig().getStrings("broadcast.death")) {
this.deathMessages.add(StringUtils.translate(string));
}
// Teleportation
this.teleportationEnabled = this.getConfig().getBool("defence.teleport.enabled");
this.teleportOptions = new TeleportOptions(
@@ -361,6 +393,9 @@ public class EcoBoss extends PluginDependent {
entity.getPersistentDataContainer().set(this.getPlugin().getNamespacedKeyFactory().create("boss"), PersistentDataType.STRING, name);
entity.setPersistent(true);
entity.setCustomName(this.getDisplayName());
entity.setCustomNameVisible(true);
AttributeInstance maxHealth = entity.getAttribute(Attribute.GENERIC_MAX_HEALTH);
assert maxHealth != null;
maxHealth.setBaseValue(this.getMaxHealth());
@@ -375,6 +410,14 @@ public class EcoBoss extends PluginDependent {
location.getWorld().playSound(location, sound.getSound(), sound.getVolume(), sound.getPitch());
}
for (String spawnMessage : this.getSpawnMessages()) {
Bukkit.broadcastMessage(spawnMessage
.replace("%x%", StringUtils.internalToString(location.getBlockX()))
.replace("%y%", StringUtils.internalToString(location.getBlockY()))
.replace("%z%", StringUtils.internalToString(location.getBlockZ()))
);
}
if (this.isBossbarEnabled()) {
createBossBar(entity);
}
@@ -382,7 +425,7 @@ public class EcoBoss extends PluginDependent {
private void createBossBar(@NotNull final LivingEntity entity) {
BossBar bossBar = Bukkit.getServer().createBossBar(
this.getDisplayName(),
entity.getCustomName(),
this.getBossbarProperties().getColor(),
this.getBossbarProperties().getStyle(),
(BarFlag) null

View File

@@ -1,8 +1,12 @@
package com.willfp.ecobosses.bosses.listeners;
import com.willfp.eco.util.NumberUtils;
import com.willfp.eco.util.internal.PluginDependent;
import com.willfp.eco.util.plugin.AbstractEcoPlugin;
import com.willfp.ecobosses.EcoBossesPlugin;
import com.willfp.ecobosses.bosses.EcoBoss;
import com.willfp.ecobosses.bosses.util.BossUtils;
import com.willfp.ecobosses.bosses.util.obj.DamagerProperty;
import com.willfp.ecobosses.bosses.util.obj.ImmunityOptions;
import org.bukkit.Location;
import org.bukkit.Material;
@@ -10,17 +14,35 @@ import org.bukkit.block.Block;
import org.bukkit.block.BlockFace;
import org.bukkit.entity.LivingEntity;
import org.bukkit.entity.Player;
import org.bukkit.entity.Projectile;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDamageByEntityEvent;
import org.bukkit.event.entity.EntityDamageEvent;
import org.jetbrains.annotations.NotNull;
import javax.swing.tree.TreeNode;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.SortedMap;
import java.util.TreeMap;
import java.util.UUID;
public class AttackListeners extends PluginDependent implements Listener {
/**
* Create new attack listeners.
*
* @param plugin Instance of EcoBosses.
*/
public AttackListeners(@NotNull final AbstractEcoPlugin plugin) {
super(plugin);
}
public class AttackListeners implements Listener {
/**
* Called when a player attacks a boss.
*
@@ -28,17 +50,25 @@ public class AttackListeners implements Listener {
*/
@EventHandler(ignoreCancelled = true)
public void onAttackBoss(@NotNull final EntityDamageByEntityEvent event) {
if (!(event.getDamager() instanceof Player)) {
return;
}
if (!(event.getEntity() instanceof LivingEntity)) {
return;
}
LivingEntity entity = (LivingEntity) event.getEntity();
Player player = (Player) event.getDamager();
Player player = null;
if (event.getDamager() instanceof Player) {
player = (Player) event.getDamager();
} else if (event.getDamager() instanceof Projectile) {
if (((Projectile) event.getDamager()).getShooter() instanceof Player) {
player = (Player) ((Projectile) event.getDamager()).getShooter();
}
}
if (player == null) {
return;
}
EcoBoss boss = BossUtils.getBoss(entity);
@@ -51,6 +81,56 @@ public class AttackListeners implements Listener {
}
}
/**
* Track top damage players.
*
* @param event The event to listen for.
*/
@EventHandler(ignoreCancelled = true, priority = EventPriority.MONITOR)
public void topDamageTracker(@NotNull final EntityDamageByEntityEvent event) {
if (!(event.getEntity() instanceof LivingEntity)) {
return;
}
LivingEntity entity = (LivingEntity) event.getEntity();
Player temp = null;
if (event.getDamager() instanceof Player) {
temp = (Player) event.getDamager();
} else if (event.getDamager() instanceof Projectile) {
if (((Projectile) event.getDamager()).getShooter() instanceof Player) {
temp = (Player) ((Projectile) event.getDamager()).getShooter();
}
}
if (temp == null) {
return;
}
Player player = temp;
EcoBoss boss = BossUtils.getBoss(entity);
if (boss == null) {
return;
}
List<DamagerProperty> topDamagers = BossUtils.getTopDamagers(entity);
double playerDamage;
Optional<DamagerProperty> damager = topDamagers.stream().filter(damagerProperty -> damagerProperty.getPlayer().equals(player)).findFirst();
playerDamage = damager.map(DamagerProperty::getDamage).orElse(0.0);
playerDamage += event.getFinalDamage();
topDamagers.removeIf(damagerProperty -> damagerProperty.getPlayer().equals(player));
topDamagers.add(new DamagerProperty(player, playerDamage));
entity.removeMetadata("ecobosses-top-damagers", this.getPlugin());
entity.setMetadata("ecobosses-top-damagers", this.getPlugin().getMetadataValueFactory().create(topDamagers));
}
/**
* Called when a boss attacks a player.
*

View File

@@ -1,18 +1,47 @@
package com.willfp.ecobosses.bosses.listeners;
import com.willfp.eco.util.NumberUtils;
import com.willfp.eco.util.StringUtils;
import com.willfp.eco.util.events.entitydeathbyentity.EntityDeathByEntityEvent;
import com.willfp.eco.util.internal.PluginDependent;
import com.willfp.eco.util.plugin.AbstractEcoPlugin;
import com.willfp.ecobosses.bosses.EcoBoss;
import com.willfp.ecobosses.bosses.util.BossUtils;
import com.willfp.ecobosses.bosses.util.obj.DamagerProperty;
import com.willfp.ecobosses.bosses.util.obj.OptionedSound;
import org.bukkit.Bukkit;
import org.bukkit.entity.LivingEntity;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDeathEvent;
import org.bukkit.inventory.ItemStack;
import org.jetbrains.annotations.NotNull;
import sun.reflect.generics.tree.Tree;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.SortedMap;
import java.util.TreeMap;
import java.util.UUID;
import java.util.stream.Collectors;
public class DeathListeners extends PluginDependent implements Listener {
/**
* Create new death listeners.
*
* @param plugin Instance of EcoBosses.
*/
public DeathListeners(@NotNull final AbstractEcoPlugin plugin) {
super(plugin);
}
public class DeathListeners implements Listener {
/**
* Called when a boss dies.
*
@@ -48,7 +77,52 @@ public class DeathListeners implements Listener {
return;
}
event.getDrops().addAll(boss.getDrops());
List<DamagerProperty> topDamagers = BossUtils.getTopDamagers(entity);
DamagerProperty top = null;
DamagerProperty second = null;
DamagerProperty third = null;
if (topDamagers.size() >= 1) {
top = topDamagers.get(0);
}
if (topDamagers.size() >= 2) {
second = topDamagers.get(1);
}
if (topDamagers.size() >= 3) {
third = topDamagers.get(2);
}
String na = this.getPlugin().getLangYml().getString("na");
String topDamager = top == null ? na : top.getPlayer().getDisplayName();
String topDamage = top == null ? na : StringUtils.internalToString(top.getDamage());
String secondDamager = second == null ? na : second.getPlayer().getDisplayName();
String secondDamage = second == null ? na : StringUtils.internalToString(second.getDamage());
String thirdDamager = third == null ? na : third.getPlayer().getDisplayName();
String thirdDamage = third == null ? na : StringUtils.internalToString(third.getDamage());
for (String spawnMessage : boss.getDeathMessages()) {
Bukkit.broadcastMessage(spawnMessage
.replace("%top%", topDamager)
.replace("%top_damage%", topDamage)
.replace("%second%", secondDamager)
.replace("%second_damage%", secondDamage)
.replace("%third%", thirdDamager)
.replace("%third_damage%", thirdDamage)
);
}
List<ItemStack> drops = new ArrayList<>();
boss.getDrops().forEach((aDouble, itemStack) -> {
if (NumberUtils.randFloat(0, 100) < aDouble) {
drops.add(itemStack);
}
});
event.getDrops().addAll(drops);
event.setDroppedExp(boss.getExperienceOptions().generateXp());
}
}

View File

@@ -3,13 +3,20 @@ package com.willfp.ecobosses.bosses.util;
import com.willfp.ecobosses.EcoBossesPlugin;
import com.willfp.ecobosses.bosses.EcoBoss;
import com.willfp.ecobosses.bosses.EcoBosses;
import com.willfp.ecobosses.bosses.util.obj.DamagerProperty;
import lombok.experimental.UtilityClass;
import org.bukkit.entity.LivingEntity;
import org.bukkit.persistence.PersistentDataType;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
@UtilityClass
@SuppressWarnings("unchecked")
public class BossUtils {
/**
* Instance of EcoBosses.
@@ -36,4 +43,29 @@ public class BossUtils {
return EcoBosses.getByName(bossName);
}
/**
* Get top damagers for a boss.
*
* @param entity The boss entity.
* @return A list of the top damagers, sorted.
*/
public List<DamagerProperty> getTopDamagers(@NotNull final LivingEntity entity) {
if (getBoss(entity) == null) {
return new ArrayList<>();
}
List<DamagerProperty> topDamagers;
if (entity.hasMetadata("ecobosses-top-damagers")) {
topDamagers = (List<DamagerProperty>) entity.getMetadata("ecobosses-top-damagers").get(0).value();
} else {
topDamagers = new ArrayList<>();
}
assert topDamagers != null;
topDamagers.sort(Comparator.comparingDouble(DamagerProperty::getDamage));
Collections.reverse(topDamagers);
return topDamagers;
}
}

View File

@@ -0,0 +1,17 @@
package com.willfp.ecobosses.bosses.util.obj;
import lombok.Data;
import org.bukkit.entity.Player;
@Data
public class DamagerProperty {
/**
* The player.
*/
private final Player player;
/**
* The damage.
*/
private final double damage;
}

View File

@@ -21,8 +21,35 @@ rewards:
xp:
minimum: 20000
maximum: 25000
top-damager-commands:
1:
- "40::give %player% diamond_block"
2:
- "25::give %player% emerald_block"
3:
- "10::give %player% iron_block"
nearby-player-commands:
radius: 10
commands: []
drops:
# Get items to add here by copying the console output for /ebdrop
# To set the chance for a drop, put <chance>::<base64>
broadcast:
spawn:
- ""
- "&9The &9&lIllusioner&r&9 has been spawned!"
- "&9Come fight it at &b%x%&9, &b%y%&9, &b%z%&9!"
- ""
death:
- ""
- "&9The &9&lIllusioner&r&9 has been killed!"
- "&9Most Damage:"
- "&9 - &b%top%&9: &b%top_damage% &9Damage"
- "&9 - &b%second%&9: &b%second_damage% &9Damage"
- "&9 - &b%third%&9: &b%third_damage% &9Damage"
- ""
defence:
immunities:

View File

@@ -6,4 +6,6 @@ messages:
sent-drop: "Check console for the drop!"
specify-boss: "&cYou must specify a valid boss!"
invalid-location: "&cInvalid location!"
spawned: "Spawned a boss!"
spawned: "Spawned a boss!"
na: "N/A"