Cleanup rune effect application.

This commit is contained in:
2023-03-29 15:42:32 -04:00
parent 6b2790f9c1
commit 5f6883059f
2 changed files with 49 additions and 137 deletions
+33 -121
View File
@@ -28,142 +28,55 @@ public enum NPCManager {
_bootySetMap = DbManager.ItemBaseQueries.LOAD_BOOTY_FOR_MOBS(); _bootySetMap = DbManager.ItemBaseQueries.LOAD_BOOTY_FOR_MOBS();
} }
public static void initializeStaticEffects(Mob mob) { public static void applyRuneSetEffects(Mob mob) {
EffectsBase eb = null; EffectsBase effectsBase;
for (MobBaseEffects mbe : mob.mobBase.getRaceEffectsList()) {
eb = PowersManager.getEffectByToken(mbe.getToken());
if (eb == null) {
Logger.info("EffectsBase Null for Token " + mbe.getToken());
continue;
}
//check to upgrade effects if needed.
if (mob.effects.containsKey(Integer.toString(eb.getUUID()))) {
if (mbe.getReqLvl() > (int) mob.level)
continue;
Effect eff = mob.effects.get(Integer.toString(eb.getUUID()));
if (eff == null)
continue;
if (eff.getTrains() > mbe.getRank())
continue;
//new effect is of a higher rank. remove old effect and apply new one.
eff.cancelJob();
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true);
} else {
if (mbe.getReqLvl() > (int) mob.level)
continue;
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true);
}
}
//Apply all rune effects. //Apply all rune effects.
// Only Captains have contracts
if (mob.contract != null || mob.isPlayerGuard) {
RuneBase guardRune = RuneBase.getRuneBase(252621);
for (MobBaseEffects mbe : guardRune.getEffectsList()) {
eb = PowersManager.getEffectByToken(mbe.getToken()); if (NPCManager._runeSetMap.get(mob.runeSetID).contains(252623)) {
mob.isPlayerGuard = true;
if (eb == null) { mob.setNoAggro(true);
Logger.info("Mob: " + mob.getObjectUUID() + " EffectsBase Null for Token " + mbe.getToken());
continue;
} }
//check to upgrade effects if needed. // Only captains have contracts
if (mob.effects.containsKey(Integer.toString(eb.getUUID()))) {
if (mbe.getReqLvl() > (int) mob.level) if (mob.contract != null || mob.isPlayerGuard)
continue; applyEffectsForRune(mob, 252621);
Effect eff = mob.effects.get(Integer.toString(eb.getUUID()));
if (eff == null)
continue;
//Current effect is a higher rank, dont apply.
if (eff.getTrains() > mbe.getRank())
continue;
//new effect is of a higher rank. remove old effect and apply new one.
eff.cancelJob();
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true);
} else {
if (mbe.getReqLvl() > (int) mob.level)
continue;
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true);
}
}
RuneBase WarriorRune = RuneBase.getRuneBase(2518);
for (MobBaseEffects mbe : WarriorRune.getEffectsList()) {
eb = PowersManager.getEffectByToken(mbe.getToken());
if (eb == null) {
Logger.info("EffectsBase Null for Token " + mbe.getToken());
continue;
}
//check to upgrade effects if needed.
if (mob.effects.containsKey(Integer.toString(eb.getUUID()))) {
if (mbe.getReqLvl() > (int) mob.level)
continue;
Effect eff = mob.effects.get(Integer.toString(eb.getUUID()));
if (eff == null)
continue;
//Current effect is a higher rank, dont apply.
if (eff.getTrains() > mbe.getRank())
continue;
//new effect is of a higher rank. remove old effect and apply new one.
eff.cancelJob();
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true);
} else {
if (mbe.getReqLvl() > (int) mob.level)
continue;
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true);
}
}
}
// Apply effects from RuneSet // Apply effects from RuneSet
if (mob.runeSetID != 0) if (mob.runeSetID != 0)
for (int runeID : _runeSetMap.get(mob.runeSetID)) { for (int runeID : _runeSetMap.get(mob.runeSetID))
applyEffectsForRune(mob, runeID);
RuneBase rune = RuneBase.getRuneBase(runeID); // Not sure why but apply Warrior effects for some reason?
if (rune != null) applyEffectsForRune(mob, 2518);
for (MobBaseEffects mbe : rune.getEffectsList()) { }
eb = PowersManager.getEffectByToken(mbe.getToken()); public static void applyEffectsForRune(AbstractCharacter character, int runeID) {
if (eb == null) {
Logger.info("EffectsBase Null for Token " + mbe.getToken()); EffectsBase effectsBase;
RuneBase sourceRune = RuneBase.getRuneBase(runeID);
for (MobBaseEffects mbe : sourceRune.getEffectsList()) {
effectsBase = PowersManager.getEffectByToken(mbe.getToken());
if (effectsBase == null) {
Logger.info("Mob: " + character.getObjectUUID() + " EffectsBase Null for Token " + mbe.getToken());
continue; continue;
} }
//check to upgrade effects if needed. //check to upgrade effects if needed.
if (mob.effects.containsKey(Integer.toString(eb.getUUID()))) { if (character.effects.containsKey(Integer.toString(effectsBase.getUUID()))) {
if (mbe.getReqLvl() > (int) mob.level)
if (mbe.getReqLvl() > (int) character.level)
continue; continue;
Effect eff = mob.effects.get(Integer.toString(eb.getUUID())); Effect eff = character.effects.get(Integer.toString(effectsBase.getUUID()));
if (eff == null) if (eff == null)
continue; continue;
@@ -174,16 +87,15 @@ public enum NPCManager {
//new effect is of a higher rank. remove old effect and apply new one. //new effect is of a higher rank. remove old effect and apply new one.
eff.cancelJob(); eff.cancelJob();
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true); character.addEffectNoTimer(Integer.toString(effectsBase.getUUID()), effectsBase, mbe.getRank(), true);
} else { } else {
if (mbe.getReqLvl() > (int) mob.level) if (mbe.getReqLvl() > (int) character.level)
continue; continue;
mob.addEffectNoTimer(Integer.toString(eb.getUUID()), eb, mbe.getRank(), true); character.addEffectNoTimer(Integer.toString(effectsBase.getUUID()), effectsBase, mbe.getRank(), true);
} }
}
} }
} }
} }
+2 -2
View File
@@ -1404,7 +1404,7 @@ public class Mob extends AbstractIntelligenceAgent {
this.bindLoc = this.lastBindLoc; this.bindLoc = this.lastBindLoc;
this.setLoc(this.lastBindLoc); this.setLoc(this.lastBindLoc);
this.stopMovement(this.lastBindLoc); this.stopMovement(this.lastBindLoc);
NPCManager.initializeStaticEffects(this); NPCManager.applyRuneSetEffects(this);
this.recalculateStats(); this.recalculateStats();
this.setHealth(this.healthMax); this.setHealth(this.healthMax);
@@ -2105,7 +2105,7 @@ public class Mob extends AbstractIntelligenceAgent {
} }
try { try {
NPCManager.initializeStaticEffects(this); NPCManager.applyRuneSetEffects(this);
try { try {
this.initializeSkills(); this.initializeSkills();