mirror of
https://gitlab.com/phoenix-dvpmt/mmoitems.git
synced 2025-01-22 09:31:20 +01:00
Stats update
This commit is contained in:
parent
a09292e642
commit
421467b954
@ -1,7 +1,10 @@
|
|||||||
package net.Indyuce.mmoitems.comp.inventory;
|
package net.Indyuce.mmoitems.comp.inventory;
|
||||||
|
|
||||||
import io.lumine.mythic.lib.api.player.EquipmentSlot;
|
import io.lumine.mythic.lib.api.player.EquipmentSlot;
|
||||||
|
import io.lumine.mythic.lib.api.stat.StatInstance;
|
||||||
|
import io.lumine.mythic.lib.api.stat.modifier.StatModifier;
|
||||||
import io.lumine.mythic.lib.player.modifier.ModifierSource;
|
import io.lumine.mythic.lib.player.modifier.ModifierSource;
|
||||||
|
import io.lumine.mythic.lib.player.modifier.ModifierType;
|
||||||
import io.lumine.mythic.lib.player.skill.PassiveSkill;
|
import io.lumine.mythic.lib.player.skill.PassiveSkill;
|
||||||
import net.Indyuce.mmoitems.ItemStats;
|
import net.Indyuce.mmoitems.ItemStats;
|
||||||
import net.Indyuce.mmoitems.MMOItems;
|
import net.Indyuce.mmoitems.MMOItems;
|
||||||
@ -9,12 +12,12 @@ import net.Indyuce.mmoitems.api.ItemSet;
|
|||||||
import net.Indyuce.mmoitems.api.event.inventory.MMOInventoryRefreshEvent;
|
import net.Indyuce.mmoitems.api.event.inventory.MMOInventoryRefreshEvent;
|
||||||
import net.Indyuce.mmoitems.api.item.mmoitem.VolatileMMOItem;
|
import net.Indyuce.mmoitems.api.item.mmoitem.VolatileMMOItem;
|
||||||
import net.Indyuce.mmoitems.api.player.PlayerData;
|
import net.Indyuce.mmoitems.api.player.PlayerData;
|
||||||
import net.Indyuce.mmoitems.api.player.PlayerStats;
|
|
||||||
import net.Indyuce.mmoitems.api.player.inventory.EquippedItem;
|
import net.Indyuce.mmoitems.api.player.inventory.EquippedItem;
|
||||||
import net.Indyuce.mmoitems.comp.inventory.model.PlayerInventoryImage;
|
import net.Indyuce.mmoitems.comp.inventory.model.PlayerInventoryImage;
|
||||||
import net.Indyuce.mmoitems.comp.inventory.model.PlayerMMOInventory;
|
import net.Indyuce.mmoitems.comp.inventory.model.PlayerMMOInventory;
|
||||||
import net.Indyuce.mmoitems.comp.inventory.model.SlotEquippedItem;
|
import net.Indyuce.mmoitems.comp.inventory.model.SlotEquippedItem;
|
||||||
import net.Indyuce.mmoitems.stat.data.*;
|
import net.Indyuce.mmoitems.stat.data.*;
|
||||||
|
import net.Indyuce.mmoitems.stat.type.AttackWeaponStat;
|
||||||
import net.milkbowl.vault.permission.Permission;
|
import net.milkbowl.vault.permission.Permission;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
@ -93,7 +96,8 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Calculate player stats
|
// Calculate player stats
|
||||||
this.data.getStats().updateStats();
|
// this.data.getStats().updateStats();
|
||||||
|
//this.updateStats(newImage);
|
||||||
|
|
||||||
// Update stats from external plugins
|
// Update stats from external plugins
|
||||||
MMOItems.plugin.getRPG().refreshStats(this.data);
|
MMOItems.plugin.getRPG().refreshStats(this.data);
|
||||||
@ -141,7 +145,15 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
this.image.setAbilities().forEach(uuid -> this.data.getMMOPlayerData().getPassiveSkillMap().removeModifier(uuid));
|
this.image.setAbilities().forEach(uuid -> this.data.getMMOPlayerData().getPassiveSkillMap().removeModifier(uuid));
|
||||||
|
|
||||||
// Particles
|
// Particles
|
||||||
bonuses.getParticles().forEach(particleData -> this.data.getItemParticles().removeIf(particleRunnable -> particleRunnable.getParticleData().equals(particleData)));
|
bonuses.getParticles()
|
||||||
|
.forEach(particleData -> this.data.getItemParticles()
|
||||||
|
.stream()
|
||||||
|
.filter(particleRunnable -> particleRunnable.getParticleData().equals(particleData))
|
||||||
|
.findFirst()
|
||||||
|
.ifPresent(particleRunnable -> {
|
||||||
|
particleRunnable.cancel();
|
||||||
|
this.data.getItemParticles().remove(particleRunnable);
|
||||||
|
}));
|
||||||
|
|
||||||
// Potion effects
|
// Potion effects
|
||||||
bonuses.getPotionEffects()
|
bonuses.getPotionEffects()
|
||||||
@ -152,8 +164,6 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void processNewItemSets(@NotNull PlayerInventoryImage newImage) {
|
private void processNewItemSets(@NotNull PlayerInventoryImage newImage) {
|
||||||
MMOItems.log("Processing new item sets...");
|
|
||||||
|
|
||||||
// Count the number of items in each set
|
// Count the number of items in each set
|
||||||
final Map<ItemSet, Integer> itemSetCount = new HashMap<>();
|
final Map<ItemSet, Integer> itemSetCount = new HashMap<>();
|
||||||
for (EquippedItem equipped : inventory.equipped()) {
|
for (EquippedItem equipped : inventory.equipped()) {
|
||||||
@ -165,10 +175,7 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Add item sets to the image
|
// Add item sets to the image
|
||||||
itemSetCount.forEach((itemSet, integer) -> {
|
itemSetCount.forEach((itemSet, integer) -> newImage.itemSets().put(itemSet.getId(), integer));
|
||||||
newImage.itemSets().put(itemSet.getId(), integer);
|
|
||||||
MMOItems.log("Added item set " + itemSet.getId() + " with " + integer + " items.");
|
|
||||||
});
|
|
||||||
// Determine the bonuses to apply
|
// Determine the bonuses to apply
|
||||||
ItemSet.SetBonuses bonuses = null;
|
ItemSet.SetBonuses bonuses = null;
|
||||||
for (Map.Entry<ItemSet, Integer> equippedSetBonus : itemSetCount.entrySet()) {
|
for (Map.Entry<ItemSet, Integer> equippedSetBonus : itemSetCount.entrySet()) {
|
||||||
@ -179,10 +186,8 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Apply the bonuses
|
// Apply the bonuses
|
||||||
if (bonuses == null) {
|
if (bonuses == null)
|
||||||
MMOItems.log("No bonuses to apply.");
|
|
||||||
return;
|
return;
|
||||||
}
|
|
||||||
MMOItems.log("Applying bonuses... Abilities: " + bonuses.getAbilities().size() + " Particles: " + bonuses.getParticles().size() + " Potion effects: " + bonuses.getPotionEffects().size() + " Permissions: " + bonuses.getPermissions().size());
|
MMOItems.log("Applying bonuses... Abilities: " + bonuses.getAbilities().size() + " Particles: " + bonuses.getParticles().size() + " Potion effects: " + bonuses.getPotionEffects().size() + " Permissions: " + bonuses.getPermissions().size());
|
||||||
|
|
||||||
if (MMOItems.plugin.hasPermissions()) {
|
if (MMOItems.plugin.hasPermissions()) {
|
||||||
@ -194,7 +199,6 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
|
|
||||||
// Abilities
|
// Abilities
|
||||||
for (AbilityData ability : bonuses.getAbilities()) {
|
for (AbilityData ability : bonuses.getAbilities()) {
|
||||||
MMOItems.log("Adding ability: " + ability.getAbility().getName());
|
|
||||||
PassiveSkill skill = this.data.getMMOPlayerData().getPassiveSkillMap().addModifier(new PassiveSkill("MMOItemsItem", ability, EquipmentSlot.OTHER, ModifierSource.OTHER));
|
PassiveSkill skill = this.data.getMMOPlayerData().getPassiveSkillMap().addModifier(new PassiveSkill("MMOItemsItem", ability, EquipmentSlot.OTHER, ModifierSource.OTHER));
|
||||||
if (skill != null)
|
if (skill != null)
|
||||||
newImage.setAbilities().add(skill.getUniqueId());
|
newImage.setAbilities().add(skill.getUniqueId());
|
||||||
@ -206,7 +210,6 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
|
|
||||||
// Potion effects
|
// Potion effects
|
||||||
for (PotionEffect effect : bonuses.getPotionEffects()) {
|
for (PotionEffect effect : bonuses.getPotionEffects()) {
|
||||||
MMOItems.log("Adding potion effect: " + effect.getType().getName());
|
|
||||||
if (this.data.getPermanentPotionEffectAmplifier(effect.getType()) < effect.getAmplifier())
|
if (this.data.getPermanentPotionEffectAmplifier(effect.getType()) < effect.getAmplifier())
|
||||||
this.data.getPermanentPotionEffectsMap().put(effect.getType(), effect);
|
this.data.getPermanentPotionEffectsMap().put(effect.getType(), effect);
|
||||||
}
|
}
|
||||||
@ -216,12 +219,14 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
private void processOldItem(int slot, @Nullable VolatileMMOItem oldItem) {
|
private void processOldItem(int slot, @Nullable VolatileMMOItem oldItem) {
|
||||||
if (oldItem == null)
|
if (oldItem == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Potion effects
|
// Potion effects
|
||||||
if (oldItem.hasData(ItemStats.PERM_EFFECTS))
|
if (oldItem.hasData(ItemStats.PERM_EFFECTS))
|
||||||
((PotionEffectListData) oldItem.getData(ItemStats.PERM_EFFECTS)).getEffects()
|
((PotionEffectListData) oldItem.getData(ItemStats.PERM_EFFECTS)).getEffects()
|
||||||
.stream()
|
.stream()
|
||||||
.filter(e -> this.data.getPermanentPotionEffectAmplifier(e.getType()) == e.getLevel() - 1)
|
.filter(e -> this.data.getPermanentPotionEffectAmplifier(e.getType()) == e.getLevel() - 1)
|
||||||
.peek(potionEffectData -> this.player.removePotionEffect(potionEffectData.getType()))
|
.peek(potionEffectData -> this.player.removePotionEffect(potionEffectData.getType()))
|
||||||
|
|
||||||
.forEach(e -> this.data.getPermanentPotionEffectsMap().remove(e.getType(), e.toEffect()));
|
.forEach(e -> this.data.getPermanentPotionEffectsMap().remove(e.getType(), e.toEffect()));
|
||||||
|
|
||||||
// Abilities
|
// Abilities
|
||||||
@ -235,8 +240,16 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
ParticleData particleData = (ParticleData) oldItem.getData(ItemStats.ITEM_PARTICLES);
|
ParticleData particleData = (ParticleData) oldItem.getData(ItemStats.ITEM_PARTICLES);
|
||||||
if (particleData.getType().hasPriority())
|
if (particleData.getType().hasPriority())
|
||||||
this.data.resetOverridingItemParticles();
|
this.data.resetOverridingItemParticles();
|
||||||
else
|
else {
|
||||||
this.data.getItemParticles().removeIf(particleRunnable -> particleRunnable.getParticleData().equals(particleData));
|
this.data.getItemParticles()
|
||||||
|
.stream()
|
||||||
|
.filter(particleRunnable -> particleRunnable.getParticleData().equals(particleData))
|
||||||
|
.findFirst()
|
||||||
|
.ifPresent(particleRunnable -> {
|
||||||
|
particleRunnable.cancel();
|
||||||
|
this.data.getItemParticles().remove(particleRunnable);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Permissions
|
// Permissions
|
||||||
@ -249,6 +262,17 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Stats
|
||||||
|
MMOItems.plugin.getStats()
|
||||||
|
.getNumericStats()
|
||||||
|
.stream()
|
||||||
|
.filter(doubleStat -> oldItem.getNBT().getStat(doubleStat.getId()) > 0)
|
||||||
|
.forEach(stat -> {
|
||||||
|
final StatInstance.ModifierPacket packet = this.data.getStats().getInstance(stat).newPacket();
|
||||||
|
packet.remove("MMOItem-" + slot);
|
||||||
|
packet.runUpdate();
|
||||||
|
});
|
||||||
|
|
||||||
// Remove the item from the inventory
|
// Remove the item from the inventory
|
||||||
this.inventory.remove(slot);
|
this.inventory.remove(slot);
|
||||||
}
|
}
|
||||||
@ -263,6 +287,25 @@ public class PlayerInventoryHandler implements Runnable {
|
|||||||
item.cacheItem();
|
item.cacheItem();
|
||||||
this.inventory.addItem(item);
|
this.inventory.addItem(item);
|
||||||
|
|
||||||
|
// Stats
|
||||||
|
MMOItems.plugin.getStats()
|
||||||
|
.getNumericStats()
|
||||||
|
.stream()
|
||||||
|
.filter(doubleStat -> item.getNBT().getStat(doubleStat.getId()) > 0)
|
||||||
|
.forEach(stat -> {
|
||||||
|
final StatInstance.ModifierPacket packet = this.data.getStats().getInstance(stat).newPacket();
|
||||||
|
final ModifierSource source = item.getCached().getType().getModifierSource();
|
||||||
|
|
||||||
|
double value = item.getNBT().getStat(stat.getId());
|
||||||
|
|
||||||
|
// Apply hand weapon stat offset
|
||||||
|
if (source.isWeapon() && stat instanceof AttackWeaponStat)
|
||||||
|
value -= ((AttackWeaponStat) stat).getOffset(this.data);
|
||||||
|
|
||||||
|
packet.addModifier(new StatModifier("MMOItem-" + item.getSlotNumber(), stat.getId(), value, ModifierType.FLAT, item.getSlot(), source));
|
||||||
|
packet.runUpdate();
|
||||||
|
});
|
||||||
|
|
||||||
// Abilities
|
// Abilities
|
||||||
if (newItem.hasData(ItemStats.ABILITIES)) {
|
if (newItem.hasData(ItemStats.ABILITIES)) {
|
||||||
List<UUID> uuids = new ArrayList<>();
|
List<UUID> uuids = new ArrayList<>();
|
||||||
|
@ -3,6 +3,8 @@ package net.Indyuce.mmoitems.comp.inventory.model;
|
|||||||
import net.Indyuce.mmoitems.MMOItems;
|
import net.Indyuce.mmoitems.MMOItems;
|
||||||
import net.Indyuce.mmoitems.api.item.mmoitem.VolatileMMOItem;
|
import net.Indyuce.mmoitems.api.item.mmoitem.VolatileMMOItem;
|
||||||
import net.Indyuce.mmoitems.api.player.PlayerData;
|
import net.Indyuce.mmoitems.api.player.PlayerData;
|
||||||
|
import net.Indyuce.mmoitems.stat.type.ItemStat;
|
||||||
|
import net.Indyuce.mmoitems.util.Pair;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
@ -24,6 +26,7 @@ public class PlayerInventoryImage {
|
|||||||
private final Map<String, Integer> itemSets;
|
private final Map<String, Integer> itemSets;
|
||||||
private final Map<Integer, List<UUID>> itemAbilities;
|
private final Map<Integer, List<UUID>> itemAbilities;
|
||||||
private final List<UUID> setAbilities;
|
private final List<UUID> setAbilities;
|
||||||
|
private final Map<Integer, List<Pair<ItemStat, Double>>> stats;
|
||||||
private final long timestamp;
|
private final long timestamp;
|
||||||
|
|
||||||
public PlayerInventoryImage(@NotNull PlayerData data) {
|
public PlayerInventoryImage(@NotNull PlayerData data) {
|
||||||
@ -35,6 +38,7 @@ public class PlayerInventoryImage {
|
|||||||
this.cache = new HashMap<>();
|
this.cache = new HashMap<>();
|
||||||
this.itemAbilities = new HashMap<>();
|
this.itemAbilities = new HashMap<>();
|
||||||
this.setAbilities = new ArrayList<>();
|
this.setAbilities = new ArrayList<>();
|
||||||
|
this.stats = new HashMap<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public @NotNull PlayerData data() {
|
public @NotNull PlayerData data() {
|
||||||
@ -61,6 +65,10 @@ public class PlayerInventoryImage {
|
|||||||
return setAbilities;
|
return setAbilities;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public @NotNull Map<Integer, List<Pair<ItemStat, Double>>> stats() {
|
||||||
|
return stats;
|
||||||
|
}
|
||||||
|
|
||||||
public long timestamp() {
|
public long timestamp() {
|
||||||
return timestamp;
|
return timestamp;
|
||||||
}
|
}
|
||||||
@ -104,18 +112,26 @@ public class PlayerInventoryImage {
|
|||||||
.filter(i -> i instanceof SlotEquippedItem)
|
.filter(i -> i instanceof SlotEquippedItem)
|
||||||
.map(i -> (SlotEquippedItem) i)
|
.map(i -> (SlotEquippedItem) i)
|
||||||
.forEach(i -> {
|
.forEach(i -> {
|
||||||
|
// Hashcode
|
||||||
image.equipped.add(i);
|
image.equipped.add(i);
|
||||||
image.hashCodes.put(i.getSlotNumber(), isEmpty(i) ? -1 : i.hashCode());
|
image.hashCodes.put(i.getSlotNumber(), isEmpty(i) ? -1 : i.hashCode());
|
||||||
|
|
||||||
|
// Stats
|
||||||
|
if (!isEmpty(i))
|
||||||
|
image.stats.put(i.getSlotNumber(), new VolatileMMOItem(i.getNBT()).getStats()
|
||||||
|
.stream()
|
||||||
|
.map(itemStat -> new Pair<>(itemStat, i.getNBT().getStat(itemStat.getId())))
|
||||||
|
.collect(Collectors.toList()));
|
||||||
});
|
});
|
||||||
return image;
|
return image;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isEmpty(@Nullable SlotEquippedItem item) {
|
public static boolean isEmpty(@Nullable SlotEquippedItem item) {
|
||||||
return item == null || item.getItem() == null;
|
return item == null || item.getItem() == null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return equipped.hashCode();
|
return Objects.hash(equipped);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user