forked from Upstream/mmocore
Fixed issue #857 about progress not being properly saved for skill trees with skill modifier. (Skill modifier is now the name we will give to skill buffs. mana, delay... are now called skill parameters).
This commit is contained in:
parent
90e0c349a4
commit
72f14547d9
@ -35,7 +35,7 @@ public class DefaultMMOLoader extends MMOLoader {
|
|||||||
if (config.getKey().equals("levelup_skill"))
|
if (config.getKey().equals("levelup_skill"))
|
||||||
return new LevelUpSkillTrigger(config);
|
return new LevelUpSkillTrigger(config);
|
||||||
|
|
||||||
if (config.getKey().equals("skill_buff"))
|
if (config.getKey().equals("skill_buff")||config.getKey().equals("skill_modifier"))
|
||||||
return new SkillModifierTrigger(config);
|
return new SkillModifierTrigger(config);
|
||||||
|
|
||||||
if (config.getKey().equals("message"))
|
if (config.getKey().equals("message"))
|
||||||
|
@ -190,7 +190,7 @@ public class PlayerData extends SynchronizedDataHolder implements OfflinePlayerD
|
|||||||
// Stat triggers setup
|
// Stat triggers setup
|
||||||
for (SkillTree skillTree : MMOCore.plugin.skillTreeManager.getAll())
|
for (SkillTree skillTree : MMOCore.plugin.skillTreeManager.getAll())
|
||||||
for (SkillTreeNode node : skillTree.getNodes())
|
for (SkillTreeNode node : skillTree.getNodes())
|
||||||
node.getExperienceTable().claimStatTriggers(this, node);
|
node.getExperienceTable().claimRemovableTrigger(this, node);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getPointSpent(SkillTree skillTree) {
|
public int getPointSpent(SkillTree skillTree) {
|
||||||
|
@ -345,8 +345,8 @@ public class SavedClassInformation implements ClassDataContainer {
|
|||||||
// We claim back the stats triggers for all the skill tree nodes of the new class.
|
// We claim back the stats triggers for all the skill tree nodes of the new class.
|
||||||
for (SkillTree skillTree : profess.getSkillTrees())
|
for (SkillTree skillTree : profess.getSkillTrees())
|
||||||
for (SkillTreeNode node : skillTree.getNodes())
|
for (SkillTreeNode node : skillTree.getNodes())
|
||||||
node.getExperienceTable().claimStatTriggers(player, node);
|
node.getExperienceTable().claimRemovableTrigger(player, node);
|
||||||
profess.getExperienceTable().claimStatTriggers(player, profess);
|
profess.getExperienceTable().claimRemovableTrigger(player, profess);
|
||||||
|
|
||||||
// Unload current class information
|
// Unload current class information
|
||||||
player.unloadClassInfo(profess);
|
player.unloadClassInfo(profess);
|
||||||
|
@ -52,7 +52,7 @@ public class SkillModifierTrigger extends Trigger implements Removable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used by skill slots to apply a skillBuff
|
* Used by skill slots to apply a skill modifier.
|
||||||
* to a dynamically chosen skill handler.
|
* to a dynamically chosen skill handler.
|
||||||
*/
|
*/
|
||||||
public void apply(PlayerData playerData, SkillHandler<?> skill) {
|
public void apply(PlayerData playerData, SkillHandler<?> skill) {
|
||||||
|
@ -103,10 +103,10 @@ public class PlayerProfessions {
|
|||||||
|
|
||||||
for (Profession profession : MMOCore.plugin.professionManager.getAll()) {
|
for (Profession profession : MMOCore.plugin.professionManager.getAll()) {
|
||||||
if (profession.hasExperienceTable())
|
if (profession.hasExperienceTable())
|
||||||
profession.getExperienceTable().claimStatTriggers(playerData, profession);
|
profession.getExperienceTable().claimRemovableTrigger(playerData, profession);
|
||||||
}
|
}
|
||||||
if (playerData.getProfess().hasExperienceTable())
|
if (playerData.getProfess().hasExperienceTable())
|
||||||
playerData.getProfess().getExperienceTable().claimStatTriggers(playerData, playerData.getProfess());
|
playerData.getProfess().getExperienceTable().claimRemovableTrigger(playerData, playerData.getProfess());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +96,7 @@ public class ExperienceItem {
|
|||||||
* @param professionLevel The profession level the player just reached
|
* @param professionLevel The profession level the player just reached
|
||||||
* @param timesCollected Amount of times the exp item has already been claimed by the player
|
* @param timesCollected Amount of times the exp item has already been claimed by the player
|
||||||
* @return If the item should be claimed right now taking into
|
* @return If the item should be claimed right now taking into
|
||||||
* account the randomness factor from the 'chance' parameter
|
* account the randomness factor from the 'chance' parameter
|
||||||
*/
|
*/
|
||||||
public boolean roll(int professionLevel, int timesCollected) {
|
public boolean roll(int professionLevel, int timesCollected) {
|
||||||
|
|
||||||
@ -136,8 +136,8 @@ public class ExperienceItem {
|
|||||||
*
|
*
|
||||||
* @param playerData
|
* @param playerData
|
||||||
*/
|
*/
|
||||||
public void applyStatTriggers(PlayerData playerData) {
|
public void applyRemovableTrigger(PlayerData playerData) {
|
||||||
for (Trigger trigger : triggers)
|
for (Trigger trigger : triggers)
|
||||||
if (trigger instanceof StatTrigger statTrigger) statTrigger.apply(playerData);
|
if (trigger instanceof Removable) trigger.apply(playerData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -80,16 +80,16 @@ public class ExperienceTable {
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called when a player joins and all the statTriggers are all triggered back
|
* Called when a player joins and all the removable triggers get claimed back.
|
||||||
*
|
*
|
||||||
* @param data PlayerData
|
* @param data PlayerData
|
||||||
* @param object Either profession, skillTreeNode or class leveling up
|
* @param object Either profession, skillTreeNode or class leveling up
|
||||||
*/
|
*/
|
||||||
public void claimStatTriggers(PlayerData data, ExperienceObject object) {
|
public void claimRemovableTrigger(PlayerData data, ExperienceObject object) {
|
||||||
for (ExperienceItem item : items) {
|
for (ExperienceItem item : items) {
|
||||||
int timesClaimed = data.getClaims(object, this, item);
|
int timesClaimed = data.getClaims(object, this, item);
|
||||||
for (int i = 0; i < timesClaimed; i++)
|
for (int i = 0; i < timesClaimed; i++)
|
||||||
item.applyStatTriggers(data);
|
item.applyRemovableTrigger(data);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,9 +29,9 @@ public class BoundSkillInfo implements Closable {
|
|||||||
this.playerData = playerData;
|
this.playerData = playerData;
|
||||||
|
|
||||||
// Apply skill buffs associated to the slot
|
// Apply skill buffs associated to the slot
|
||||||
for (SkillModifierTrigger skillBuffTrigger : skillSlot.getSkillBuffTriggers())
|
for (SkillModifierTrigger skillModifierTrigger : skillSlot.getSkillModifierTriggers())
|
||||||
if (skillBuffTrigger.getTargetSkills().contains(classSkill.getSkill().getHandler()))
|
if (skillModifierTrigger.getTargetSkills().contains(classSkill.getSkill().getHandler()))
|
||||||
skillBuffTrigger.apply(playerData, classSkill.getSkill().getHandler());
|
skillModifierTrigger.apply(playerData, classSkill.getSkill().getHandler());
|
||||||
|
|
||||||
if (classSkill.getSkill().getTrigger().isPassive()) {
|
if (classSkill.getSkill().getTrigger().isPassive()) {
|
||||||
registered = classSkill.toPassive(playerData);
|
registered = classSkill.toPassive(playerData);
|
||||||
@ -67,6 +67,6 @@ public class BoundSkillInfo implements Closable {
|
|||||||
if (isPassive()) registered.unregister(playerData.getMMOPlayerData());
|
if (isPassive()) registered.unregister(playerData.getMMOPlayerData());
|
||||||
|
|
||||||
// Remove skill buffs associated to the slot
|
// Remove skill buffs associated to the slot
|
||||||
skillSlot.getSkillBuffTriggers().forEach(skillBuffTrigger -> skillBuffTrigger.remove(playerData, classSkill.getSkill().getHandler()));
|
skillSlot.getSkillModifierTriggers().forEach(skillBuffTrigger -> skillBuffTrigger.remove(playerData, classSkill.getSkill().getHandler()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,10 +22,10 @@ public class SkillSlot implements Unlockable {
|
|||||||
private final boolean isUnlockedByDefault;
|
private final boolean isUnlockedByDefault;
|
||||||
private final boolean canManuallyBind;
|
private final boolean canManuallyBind;
|
||||||
|
|
||||||
private final List<SkillModifierTrigger> skillBuffTriggers = new ArrayList<>();
|
private final List<SkillModifierTrigger> skillModifierTriggers = new ArrayList<>();
|
||||||
private final Material item;
|
private final Material item;
|
||||||
|
|
||||||
public SkillSlot(int slot, int modelData, String formula, String name, List<String> lore, boolean isUnlockedByDefault, boolean canManuallyBind, List<SkillModifierTrigger> skillBuffTriggers) {
|
public SkillSlot(int slot, int modelData, String formula, String name, List<String> lore, boolean isUnlockedByDefault, boolean canManuallyBind, List<SkillModifierTrigger> skillModifierTriggers) {
|
||||||
this.slot = slot;
|
this.slot = slot;
|
||||||
this.modelData = modelData;
|
this.modelData = modelData;
|
||||||
this.formula = formula;
|
this.formula = formula;
|
||||||
@ -34,7 +34,7 @@ public class SkillSlot implements Unlockable {
|
|||||||
this.item = null;
|
this.item = null;
|
||||||
this.canManuallyBind = canManuallyBind;
|
this.canManuallyBind = canManuallyBind;
|
||||||
this.isUnlockedByDefault = isUnlockedByDefault;
|
this.isUnlockedByDefault = isUnlockedByDefault;
|
||||||
this.skillBuffTriggers.addAll(skillBuffTriggers);
|
this.skillModifierTriggers.addAll(skillModifierTriggers);
|
||||||
}
|
}
|
||||||
|
|
||||||
public SkillSlot(ConfigurationSection section) {
|
public SkillSlot(ConfigurationSection section) {
|
||||||
@ -49,7 +49,7 @@ public class SkillSlot implements Unlockable {
|
|||||||
if (section.contains("skill-buffs"))
|
if (section.contains("skill-buffs"))
|
||||||
for (String skillBuff : section.getStringList("skill-buffs"))
|
for (String skillBuff : section.getStringList("skill-buffs"))
|
||||||
if (skillBuff.startsWith("skill_buff"))
|
if (skillBuff.startsWith("skill_buff"))
|
||||||
skillBuffTriggers.add((SkillModifierTrigger) MMOCore.plugin.loadManager.loadTrigger(new MMOLineConfig(skillBuff)));
|
skillModifierTriggers.add((SkillModifierTrigger) MMOCore.plugin.loadManager.loadTrigger(new MMOLineConfig(skillBuff)));
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getSlot() {
|
public int getSlot() {
|
||||||
@ -81,8 +81,8 @@ public class SkillSlot implements Unlockable {
|
|||||||
return isUnlockedByDefault;
|
return isUnlockedByDefault;
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<SkillModifierTrigger> getSkillBuffTriggers() {
|
public List<SkillModifierTrigger> getSkillModifierTriggers() {
|
||||||
return skillBuffTriggers;
|
return skillModifierTriggers;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canManuallyBind() {
|
public boolean canManuallyBind() {
|
||||||
|
Loading…
Reference in New Issue
Block a user