Added a player message when trying to cast a locked skill

Fixed players being able to bind locked skills
This commit is contained in:
Indyuce 2020-05-02 14:05:06 +02:00
parent 726d21cc7f
commit b1bead79bb
12 changed files with 105 additions and 77 deletions

View File

@ -572,22 +572,23 @@ public class PlayerData extends OfflinePlayerData {
player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message)); player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message));
} }
@Deprecated
public void setAttribute(PlayerAttribute attribute, int value) { public void setAttribute(PlayerAttribute attribute, int value) {
setAttribute(attribute.getId(), value); setAttribute(attribute.getId(), value);
} }
@Deprecated
public void setAttribute(String id, int value) { public void setAttribute(String id, int value) {
attributes.setBaseAttribute(id, value); attributes.setBaseAttribute(id, value);
} }
public void clearAttributePoints() { @Deprecated
attributes.getAttributeInstances().forEach(ins -> ins.setBase(0)); public Map<String, Integer> mapAttributePoints() {
return getAttributes().mapPoints();
} }
public Map<String, Integer> mapAttributePoints() { public int getSkillLevel(Skill skill) {
Map<String, Integer> ap = new HashMap<String, Integer>(); return skills.getOrDefault(skill.getId(), 1);
attributes.getAttributeInstances().forEach(ins -> ap.put(ins.getId(), ins.getBase()));
return ap;
} }
public void setSkillLevel(Skill skill, int level) { public void setSkillLevel(Skill skill, int level) {
@ -598,26 +599,32 @@ public class PlayerData extends OfflinePlayerData {
skills.put(skill, level); skills.put(skill, level);
} }
public void lockSkill(Skill skill) { public void resetSkillLevel(String skill) {
skills.remove(skill.getId()); skills.remove(skill);
} }
/*
* better use getProfess().findSkill(skill).isPresent()
*/
@Deprecated
public boolean hasSkillUnlocked(Skill skill) { public boolean hasSkillUnlocked(Skill skill) {
return skills.containsKey(skill.getId()); return getProfess().hasSkill(skill.getId()) && hasSkillUnlocked(getProfess().getSkill(skill.getId()));
} }
public int getSkillLevel(Skill skill) { /*
return skills.containsKey(skill.getId()) ? skills.get(skill.getId()) : 1; * (bug fix) any skill, when the player has the right level is instantly
* unlocked, therefore one must NOT check if the player has unlocked the
* skill by checking if the skills map contains the skill id as key. this
* only checks if the player has spent any skill point.
*/
public boolean hasSkillUnlocked(SkillInfo info) {
return getLevel() >= info.getUnlockLevel();
} }
public Map<String, Integer> mapSkillLevels() { public Map<String, Integer> mapSkillLevels() {
return new HashMap<>(skills); return new HashMap<>(skills);
} }
public void clearSkillLevels() {
skills.clear();
}
public void giveClassPoints(int value) { public void giveClassPoints(int value) {
setClassPoints(classPoints + value); setClassPoints(classPoints + value);
} }
@ -713,6 +720,9 @@ public class PlayerData extends OfflinePlayerData {
SkillResult cast = skill.getSkill().whenCast(this, skill); SkillResult cast = skill.getSkill().whenCast(this, skill);
if (!cast.isSuccessful()) { if (!cast.isSuccessful()) {
if (!skill.getSkill().isPassive()) { if (!skill.getSkill().isPassive()) {
if (cast.getCancelReason() == CancelReason.LOCKED)
MMOCore.plugin.configManager.getSimpleMessage("not-unlocked-skill").send(player);
if (cast.getCancelReason() == CancelReason.MANA) if (cast.getCancelReason() == CancelReason.MANA)
MMOCore.plugin.configManager.getSimpleMessage("casting.no-mana").send(player); MMOCore.plugin.configManager.getSimpleMessage("casting.no-mana").send(player);

View File

@ -22,7 +22,7 @@ import net.mmogroup.mmolib.api.stat.modifier.StatModifier;
public class PlayerAttributes { public class PlayerAttributes {
private final PlayerData data; private final PlayerData data;
private final Map<String, AttributeInstance> extra = new HashMap<>(); private final Map<String, AttributeInstance> instances = new HashMap<>();
public PlayerAttributes(PlayerData data) { public PlayerAttributes(PlayerData data) {
this.data = data; this.data = data;
@ -37,19 +37,19 @@ public class PlayerAttributes {
PlayerAttribute attribute = MMOCore.plugin.attributeManager.get(id); PlayerAttribute attribute = MMOCore.plugin.attributeManager.get(id);
AttributeInstance ins = new AttributeInstance(attribute); AttributeInstance ins = new AttributeInstance(attribute);
ins.setBase(config.getInt(key)); ins.setBase(config.getInt(key));
extra.put(id, ins); instances.put(id, ins);
} catch (IllegalArgumentException exception) { } catch (IllegalArgumentException exception) {
data.log(Level.WARNING, exception.getMessage()); data.log(Level.WARNING, exception.getMessage());
} }
} }
public void save(ConfigurationSection config) { public void save(ConfigurationSection config) {
extra.values().forEach(ins -> config.set(ins.id, ins.getBase())); instances.values().forEach(ins -> config.set(ins.id, ins.getBase()));
} }
public String toJsonString() { public String toJsonString() {
JsonObject json = new JsonObject(); JsonObject json = new JsonObject();
for (AttributeInstance ins : extra.values()) for (AttributeInstance ins : instances.values())
json.addProperty(ins.getId(), ins.getBase()); json.addProperty(ins.getId(), ins.getBase());
return json.toString(); return json.toString();
} }
@ -65,7 +65,7 @@ public class PlayerAttributes {
PlayerAttribute attribute = MMOCore.plugin.attributeManager.get(id); PlayerAttribute attribute = MMOCore.plugin.attributeManager.get(id);
AttributeInstance ins = new AttributeInstance(attribute); AttributeInstance ins = new AttributeInstance(attribute);
ins.setBase(entry.getValue().getAsInt()); ins.setBase(entry.getValue().getAsInt());
extra.put(id, ins); instances.put(id, ins);
} catch (IllegalArgumentException exception) { } catch (IllegalArgumentException exception) {
data.log(Level.WARNING, exception.getMessage()); data.log(Level.WARNING, exception.getMessage());
} }
@ -80,22 +80,28 @@ public class PlayerAttributes {
return getInstance(attribute).getTotal(); return getInstance(attribute).getTotal();
} }
public Collection<AttributeInstance> getAttributeInstances() { public Collection<AttributeInstance> getInstances() {
return extra.values(); return instances.values();
}
public Map<String, Integer> mapPoints() {
Map<String, Integer> map = new HashMap<>();
instances.values().forEach(ins -> map.put(ins.id, ins.spent));
return map;
} }
public AttributeInstance getInstance(PlayerAttribute attribute) { public AttributeInstance getInstance(PlayerAttribute attribute) {
if (extra.containsKey(attribute.getId())) if (instances.containsKey(attribute.getId()))
return extra.get(attribute.getId()); return instances.get(attribute.getId());
AttributeInstance ins = new AttributeInstance(attribute); AttributeInstance ins = new AttributeInstance(attribute);
extra.put(attribute.getId(), ins); instances.put(attribute.getId(), ins);
return ins; return ins;
} }
public int countSkillPoints() { public int countSkillPoints() {
int n = 0; int n = 0;
for (AttributeInstance ins : extra.values()) for (AttributeInstance ins : instances.values())
n += ins.getBase(); n += ins.getBase();
return n; return n;
} }
@ -129,7 +135,7 @@ public class PlayerAttributes {
* and relative attributes which add X% and which must be applied * and relative attributes which add X% and which must be applied
* afterwards 2) the 'd' parameter lets you choose if the relative * afterwards 2) the 'd' parameter lets you choose if the relative
* attributes also apply on the base stat, or if they only apply on the * attributes also apply on the base stat, or if they only apply on the
* extra stat value * instances stat value
*/ */
public int getTotal() { public int getTotal() {
double d = spent; double d = spent;
@ -197,7 +203,7 @@ public class PlayerAttributes {
} }
public void setBaseAttribute(String id, int value) { public void setBaseAttribute(String id, int value) {
getAttributeInstances().forEach(ins -> { getInstances().forEach(ins -> {
if (ins.getId().equals(id)) if (ins.getId().equals(id))
ins.setBase(value); ins.setBase(value);
}); });

View File

@ -7,6 +7,7 @@ import java.util.HashMap;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Optional;
import java.util.Set; import java.util.Set;
import java.util.UUID; import java.util.UUID;
import java.util.logging.Level; import java.util.logging.Level;
@ -274,8 +275,16 @@ public class PlayerClass extends PostLoadObject {
return getSkill(skill.getId()); return getSkill(skill.getId());
} }
/*
* reduces map checkups when skills are being checked on events that are
* commonly called like EntityDamageEvent or regen events.
*/
public Optional<SkillInfo> findSkill(Skill skill) {
return skills.containsKey(skill.getId()) ? Optional.of(skills.get(skill.getId())) : Optional.empty();
}
public SkillInfo getSkill(String id) { public SkillInfo getSkill(String id) {
return skills.get(id.toUpperCase()); return skills.get(id);
} }
public Set<String> getEventTriggers() { public Set<String> getEventTriggers() {

View File

@ -57,7 +57,7 @@ public class SavedClassInformation {
skillPoints = player.getSkillPoints(); skillPoints = player.getSkillPoints();
experience = player.getExperience(); experience = player.getExperience();
skills = player.mapSkillLevels(); skills = player.mapSkillLevels();
attributes = player.mapAttributePoints(); attributes = player.getAttributes().mapPoints();
attributePoints = player.getAttributePoints(); attributePoints = player.getAttributePoints();
attributeReallocationPoints = player.getAttributeReallocationPoints(); attributeReallocationPoints = player.getAttributeReallocationPoints();
} }
@ -112,7 +112,6 @@ public class SavedClassInformation {
skills.put(attribute, level); skills.put(attribute, level);
} }
public Set<String> getAttributeKeys() { public Set<String> getAttributeKeys() {
return attributes.keySet(); return attributes.keySet();
} }
@ -145,10 +144,10 @@ public class SavedClassInformation {
/* /*
* resets information which much be reset after everything is saved. * resets information which much be reset after everything is saved.
*/ */
player.clearSkillLevels(); player.mapSkillLevels().forEach((skill, level) -> player.resetSkillLevel(skill));
while (player.hasSkillBound(0)) while (player.hasSkillBound(0))
player.unbindSkill(0); player.unbindSkill(0);
player.clearAttributePoints(); player.getAttributes().getInstances().forEach(ins -> ins.setBase(0));
/* /*
* reads this class info, applies it to the player. set class after * reads this class info, applies it to the player. set class after
@ -160,8 +159,8 @@ public class SavedClassInformation {
player.setSkillPoints(skillPoints); player.setSkillPoints(skillPoints);
player.setAttributePoints(attributePoints); player.setAttributePoints(attributePoints);
player.setAttributeReallocationPoints(attributeReallocationPoints); player.setAttributeReallocationPoints(attributeReallocationPoints);
skills.keySet().forEach(id -> player.setSkillLevel(id, skills.get(id))); skills.forEach((id, level) -> player.setSkillLevel(id, level));
attributes.keySet().forEach(id -> player.setAttribute(id, attributes.get(id))); attributes.forEach((id, pts) -> player.getAttributes().setBaseAttribute(id, pts));
/* /*
* unload current class information and set the new profess once * unload current class information and set the new profess once

View File

@ -194,10 +194,6 @@ public abstract class Skill {
return modifiers.get(modifier).calculate(level); return modifiers.get(modifier).calculate(level);
} }
public boolean isUnlocked(PlayerData profess) {
return profess.getLevel() >= level;
}
public List<String> calculateLore(PlayerData data) { public List<String> calculateLore(PlayerData data) {
return calculateLore(data, data.getSkillLevel(skill)); return calculateLore(data, data.getSkillLevel(skill));
} }

View File

@ -16,7 +16,7 @@ public class SkillResult {
level = data.getSkillLevel(skill.getSkill()); level = data.getSkillLevel(skill.getSkill());
cooldown = (skill.getSkill().hasModifier("cooldown") ? data.getSkillData().getCooldown(skill) : 0); cooldown = (skill.getSkill().hasModifier("cooldown") ? data.getSkillData().getCooldown(skill) : 0);
mana = (skill.getSkill().hasModifier("mana") ? skill.getModifier("mana", level) : 0); mana = (skill.getSkill().hasModifier("mana") ? skill.getModifier("mana", level) : 0);
cancelReason = !data.hasSkillUnlocked(skill.getSkill()) ? CancelReason.LOCKED cancelReason = !data.hasSkillUnlocked(skill) ? CancelReason.LOCKED
: cooldown > 0 ? CancelReason.COOLDOWN : mana > data.getMana() ? CancelReason.MANA : null; : cooldown > 0 ? CancelReason.COOLDOWN : mana > data.getMana() ? CancelReason.MANA : null;
} }

View File

@ -16,14 +16,17 @@ public class TargetSkillResult extends SkillResult {
super(data, skill); super(data, skill);
if (isSuccessful()) { if (isSuccessful()) {
MMORayTraceResult result = MMOLib.plugin.getVersion().getWrapper().rayTrace(data.getPlayer(), range, entity -> MMOCoreUtils.canTarget(data, entity)); MMORayTraceResult result = MMOLib.plugin.getVersion().getWrapper().rayTrace(data.getPlayer(), range,
entity -> MMOCoreUtils.canTarget(data, entity));
if (!result.hasHit()) if (!result.hasHit())
abort(CancelReason.OTHER); abort();
else else
target = (LivingEntity) result.getHit(); target = (LivingEntity) result.getHit();
} }
} }
// check skill result abort reason instead
@Deprecated
public boolean hasTarget() { public boolean hasTarget() {
return target != null; return target != null;
} }

View File

@ -8,7 +8,6 @@ import org.bukkit.entity.Player;
import net.Indyuce.mmocore.MMOCore; import net.Indyuce.mmocore.MMOCore;
import net.Indyuce.mmocore.api.experience.Profession; import net.Indyuce.mmocore.api.experience.Profession;
import net.Indyuce.mmocore.api.player.PlayerData; import net.Indyuce.mmocore.api.player.PlayerData;
import net.Indyuce.mmocore.api.player.attribute.PlayerAttribute;
import net.Indyuce.mmocore.api.player.attribute.PlayerAttributes.AttributeInstance; import net.Indyuce.mmocore.api.player.attribute.PlayerAttributes.AttributeInstance;
import net.Indyuce.mmocore.command.api.CommandEnd; import net.Indyuce.mmocore.command.api.CommandEnd;
import net.Indyuce.mmocore.command.api.CommandMap; import net.Indyuce.mmocore.command.api.CommandMap;
@ -61,10 +60,9 @@ public class ResetCommandMap extends CommandMap {
data.setAttributePoints(0); data.setAttributePoints(0);
data.setAttributeReallocationPoints(0); data.setAttributeReallocationPoints(0);
for (PlayerAttribute att : MMOCore.plugin.attributeManager.getAll()) data.getAttributes().getInstances().forEach(ins -> ins.setBase(0));
data.setAttribute(att, 0);
MMOCore.plugin.skillManager.getAll().forEach(skill -> data.lockSkill(skill)); data.mapSkillLevels().forEach((skill, level) -> data.resetSkillLevel(skill));
while (data.hasSkillBound(0)) while (data.hasSkillBound(0))
data.unbindSkill(0); data.unbindSkill(0);
data.getQuestData().resetFinishedQuests(); data.getQuestData().resetFinishedQuests();
@ -144,7 +142,7 @@ public class ResetCommandMap extends CommandMap {
} }
PlayerData data = PlayerData.get(player); PlayerData data = PlayerData.get(player);
MMOCore.plugin.skillManager.getAll().forEach(skill -> data.lockSkill(skill)); data.mapSkillLevels().forEach((skill, level) -> data.resetSkillLevel(skill));
while (data.hasSkillBound(0)) while (data.hasSkillBound(0))
data.unbindSkill(0); data.unbindSkill(0);
sender.sendMessage(ChatColor.GOLD + player.getName() + ChatColor.YELLOW + "'s skill data was succesfully reset."); sender.sendMessage(ChatColor.GOLD + player.getName() + ChatColor.YELLOW + "'s skill data was succesfully reset.");
@ -179,7 +177,7 @@ public class ResetCommandMap extends CommandMap {
if (args.length > 4 && args[4].equalsIgnoreCase("-reallocate")) { if (args.length > 4 && args[4].equalsIgnoreCase("-reallocate")) {
int points = 0; int points = 0;
for (AttributeInstance ins : data.getAttributes().getAttributeInstances()) { for (AttributeInstance ins : data.getAttributes().getInstances()) {
points += ins.getBase(); points += ins.getBase();
ins.setBase(0); ins.setBase(0);
} }
@ -189,8 +187,7 @@ public class ResetCommandMap extends CommandMap {
return CommandResult.SUCCESS; return CommandResult.SUCCESS;
} }
for (PlayerAttribute att : MMOCore.plugin.attributeManager.getAll()) data.getAttributes().getInstances().forEach(ins -> ins.setBase(0));
data.setAttribute(att, 0);
sender.sendMessage(ChatColor.GOLD + player.getName() + ChatColor.YELLOW + "'s attributes were succesfully reset."); sender.sendMessage(ChatColor.GOLD + player.getName() + ChatColor.YELLOW + "'s attributes were succesfully reset.");
return CommandResult.SUCCESS; return CommandResult.SUCCESS;
} }

View File

@ -101,7 +101,7 @@ public class AttributeView extends EditableInventory {
return; return;
} }
playerData.getAttributes().getAttributeInstances().forEach(ins -> ins.setBase(0)); playerData.getAttributes().getInstances().forEach(ins -> ins.setBase(0));
playerData.giveAttributePoints(spent); playerData.giveAttributePoints(spent);
playerData.giveAttributeReallocationPoints(-1); playerData.giveAttributeReallocationPoints(-1);
MMOCore.plugin.configManager.getSimpleMessage("attribute-points-reallocated", "points", "" + playerData.getAttributePoints()).send(player); MMOCore.plugin.configManager.getSimpleMessage("attribute-points-reallocated", "points", "" + playerData.getAttributePoints()).send(player);

View File

@ -71,7 +71,8 @@ public class SkillList extends EditableInventory {
if (function.equals("slot")) if (function.equals("slot"))
return new InventoryPlaceholderItem(config) { return new InventoryPlaceholderItem(config) {
private final String none = ChatColor.translateAlternateColorCodes('&', config.getString("no-skill")); private final String none = ChatColor.translateAlternateColorCodes('&', config.getString("no-skill"));
private final Material emptyMaterial = Material.valueOf(config.getString("empty-item").toUpperCase().replace("-", "_").replace(" ", "_")); private final Material emptyMaterial = Material
.valueOf(config.getString("empty-item").toUpperCase().replace("-", "_").replace(" ", "_"));
@Override @Override
public Placeholders getPlaceholders(PluginInventory inv, int n) { public Placeholders getPlaceholders(PluginInventory inv, int n) {
@ -172,7 +173,8 @@ public class SkillList extends EditableInventory {
ItemStack item = cloneItem(); ItemStack item = cloneItem();
ItemMeta meta = item.getItemMeta(); ItemMeta meta = item.getItemMeta();
meta.setDisplayName(ChatColor.translateAlternateColorCodes('&', getName().replace("{skill}", skill.getSkill().getName()).replace("{roman}", MMOCoreUtils.intToRoman(skillLevel)).replace("{level}", "" + skillLevel))); meta.setDisplayName(ChatColor.translateAlternateColorCodes('&', getName().replace("{skill}", skill.getSkill().getName())
.replace("{roman}", MMOCoreUtils.intToRoman(skillLevel)).replace("{level}", "" + skillLevel)));
meta.addItemFlags(ItemFlag.values()); meta.addItemFlags(ItemFlag.values());
meta.setLore(lore); meta.setLore(lore);
item.setItemMeta(meta); item.setItemMeta(meta);
@ -227,7 +229,8 @@ public class SkillList extends EditableInventory {
for (Iterator<String> iterator = lore.iterator(); iterator.hasNext();) { for (Iterator<String> iterator = lore.iterator(); iterator.hasNext();) {
String next = iterator.next(); String next = iterator.next();
if ((next.startsWith("{unlocked}") && !unlocked) || (next.startsWith("{locked}") && unlocked) || (next.startsWith("{max_level}") && (!skill.hasMaxLevel() || skill.getMaxLevel() > inv.getPlayerData().getSkillLevel(skill.getSkill())))) if ((next.startsWith("{unlocked}") && !unlocked) || (next.startsWith("{locked}") && unlocked) || (next.startsWith("{max_level}")
&& (!skill.hasMaxLevel() || skill.getMaxLevel() > inv.getPlayerData().getSkillLevel(skill.getSkill()))))
iterator.remove(); iterator.remove();
} }
@ -297,7 +300,8 @@ public class SkillList extends EditableInventory {
@Override @Override
public void whenClicked(InventoryClickEvent event, InventoryItem item) { public void whenClicked(InventoryClickEvent event, InventoryItem item) {
if (skillSlots.contains(event.getRawSlot()) && event.getRawSlot() != ((SkillItem) getEditable().getByFunction("skill")).selectedSkillSlot) { if (skillSlots.contains(event.getRawSlot())
&& event.getRawSlot() != ((SkillItem) getEditable().getByFunction("skill")).selectedSkillSlot) {
player.playSound(player.getLocation(), Sound.UI_BUTTON_CLICK, 1, 2); player.playSound(player.getLocation(), Sound.UI_BUTTON_CLICK, 1, 2);
playerData.skillGuiDisplayOffset = (playerData.skillGuiDisplayOffset + (event.getRawSlot() - 13)) % skills.size(); playerData.skillGuiDisplayOffset = (playerData.skillGuiDisplayOffset + (event.getRawSlot() - 13)) % skills.size();
open(); open();
@ -356,20 +360,12 @@ public class SkillList extends EditableInventory {
return; return;
} }
if (!selected.isUnlocked(playerData)) { if (!playerData.hasSkillUnlocked(selected)) {
MMOCore.plugin.configManager.getSimpleMessage("not-unlocked-skill").send(player); MMOCore.plugin.configManager.getSimpleMessage("not-unlocked-skill").send(player);
player.playSound(player.getLocation(), Sound.ENTITY_VILLAGER_NO, 1, 2); player.playSound(player.getLocation(), Sound.ENTITY_VILLAGER_NO, 1, 2);
return; return;
} }
// if (playerData.getSkillLevel(selected.getSkill()) <
// 1) {
// player.sendMessage(MMOCore.plugin.configManager.getSimpleMessage("not-unlocked-skill"));
// player.playSound(player.getLocation(),
// Sound.ENTITY_VILLAGER_NO, 1, 2);
// return;
// }
player.playSound(player.getLocation(), Sound.ENTITY_EXPERIENCE_ORB_PICKUP, 1, 2); player.playSound(player.getLocation(), Sound.ENTITY_EXPERIENCE_ORB_PICKUP, 1, 2);
playerData.setBoundSkill(index, selected); playerData.setBoundSkill(index, selected);
open(); open();
@ -381,7 +377,7 @@ public class SkillList extends EditableInventory {
* upgrading a player skill * upgrading a player skill
*/ */
} else if (item.getFunction().equals("upgrade")) { } else if (item.getFunction().equals("upgrade")) {
if (!selected.isUnlocked(playerData)) { if (!playerData.hasSkillUnlocked(selected)) {
MMOCore.plugin.configManager.getSimpleMessage("not-unlocked-skill").send(player); MMOCore.plugin.configManager.getSimpleMessage("not-unlocked-skill").send(player);
player.playSound(player.getLocation(), Sound.ENTITY_VILLAGER_NO, 1, 2); player.playSound(player.getLocation(), Sound.ENTITY_VILLAGER_NO, 1, 2);
return; return;
@ -401,7 +397,8 @@ public class SkillList extends EditableInventory {
playerData.giveSkillPoints(-1); playerData.giveSkillPoints(-1);
playerData.setSkillLevel(selected.getSkill(), playerData.getSkillLevel(selected.getSkill()) + 1); playerData.setSkillLevel(selected.getSkill(), playerData.getSkillLevel(selected.getSkill()) + 1);
MMOCore.plugin.configManager.getSimpleMessage("upgrade-skill", "skill", selected.getSkill().getName(), "level", "" + playerData.getSkillLevel(selected.getSkill())).send(player); MMOCore.plugin.configManager.getSimpleMessage("upgrade-skill", "skill", selected.getSkill().getName(), "level",
"" + playerData.getSkillLevel(selected.getSkill())).send(player);
player.playSound(player.getLocation(), Sound.ENTITY_PLAYER_LEVELUP, 1, 2); player.playSound(player.getLocation(), Sound.ENTITY_PLAYER_LEVELUP, 1, 2);
open(); open();
} }

View File

@ -1,8 +1,11 @@
package net.Indyuce.mmocore.skill; package net.Indyuce.mmocore.skill;
import java.util.Optional;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import net.Indyuce.mmocore.MMOCore; import net.Indyuce.mmocore.MMOCore;
@ -25,10 +28,13 @@ public class Fire_Berserker extends Skill implements Listener {
Bukkit.getPluginManager().registerEvents(this, MMOCore.plugin); Bukkit.getPluginManager().registerEvents(this, MMOCore.plugin);
} }
@EventHandler @EventHandler(priority = EventPriority.HIGH, ignoreCancelled = true)
public void a(PlayerAttackEvent event) { public void a(PlayerAttackEvent event) {
PlayerData data = event.getData().getMMOCore(); PlayerData data = event.getData().getMMOCore();
if (event.getPlayer().getFireTicks() > 0 && data.hasSkillUnlocked(this)) if (event.getPlayer().getFireTicks() > 0) {
event.getAttack().multiplyDamage(1 + data.getProfess().getSkill(this).getModifier("extra", data.getSkillLevel(this)) / 100); Optional<SkillInfo> skill = data.getProfess().findSkill(this);
if (skill.isPresent())
event.getAttack().multiplyDamage(1 + skill.get().getModifier("extra", data.getSkillLevel(this)) / 100);
}
} }
} }

View File

@ -1,5 +1,7 @@
package net.Indyuce.mmocore.skill; package net.Indyuce.mmocore.skill;
import java.util.Optional;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
@ -29,7 +31,10 @@ public class Neptune_Gift extends Skill implements Listener {
@EventHandler @EventHandler
public void a(PlayerRegenResourceEvent event) { public void a(PlayerRegenResourceEvent event) {
PlayerData data = event.getData(); PlayerData data = event.getData();
if (event.getPlayer().getLocation().getBlock().getType() == Material.WATER && data.hasSkillUnlocked(this)) if (event.getPlayer().getLocation().getBlock().getType() == Material.WATER) {
event.setAmount(event.getAmount() * (1 + data.getProfess().getSkill(this).getModifier("extra", data.getSkillLevel(this)) / 100)); Optional<SkillInfo> skill = data.getProfess().findSkill(this);
if (skill.isPresent())
event.setAmount(event.getAmount() * (1 + skill.get().getModifier("extra", data.getSkillLevel(this)) / 100));
}
} }
} }