Addition of SkillPowerAdd effect.

This commit is contained in:
MobiusDevelopment
2019-05-23 06:30:47 +00:00
parent d4318dc9ad
commit e4475af103
146 changed files with 640 additions and 604 deletions

View File

@@ -301,6 +301,7 @@ public final class EffectMasterHandler
EffectHandler.getInstance().registerHandler("SkillCriticalDamage", SkillCriticalDamage::new);
EffectHandler.getInstance().registerHandler("SkillCriticalProbability", SkillCriticalProbability::new);
EffectHandler.getInstance().registerHandler("SkillEvasion", SkillEvasion::new);
EffectHandler.getInstance().registerHandler("SkillPowerAdd", SkillPowerAdd::new);
EffectHandler.getInstance().registerHandler("SkillTurning", SkillTurning::new);
EffectHandler.getInstance().registerHandler("SkillTurningOverTime", SkillTurningOverTime::new);
EffectHandler.getInstance().registerHandler("SoulBlow", SoulBlow::new);

View File

@@ -122,9 +122,6 @@ public final class EnergyAttack extends AbstractEffect
if (defence != -1)
{
// TODO: Find proper defence formula.
defence = effector.isPlayable() && (effected.getLevel() > 99) ? defence / 10 : defence;
// Trait, elements
final double weaponTraitMod = Formulas.calcWeaponTraitBonus(attacker, effected);
final double generalTraitMod = Formulas.calcGeneralTraitBonus(attacker, effected, skill.getTraitType(), true);
@@ -150,9 +147,8 @@ public final class EnergyAttack extends AbstractEffect
// ...................________Initial Damage_________...__Charges Additional Damage__...____________________________________
// ATTACK CALCULATION ((77 * ((pAtk * lvlMod) + power) * (1 + (0.1 * chargesConsumed)) / pdef) * skillPower) + skillPowerAdd
// ```````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^```^^^^^^^^^^^^^^^^^^^^^^^^^^^^^```^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
final double baseMod = (77 * ((attacker.getPAtk() * attacker.getLevelMod()) + _power)) / defence;
final double baseMod = (77 * ((attacker.getPAtk() * attacker.getLevelMod()) + (_power * effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 1)) + effector.getStat().getValue(Stats.SKILL_POWER_ADD, 0))) / defence;
damage = baseMod * ssmod * critMod * weaponTraitMod * generalTraitMod * attributeMod * energyChargesBoost * pvpPveMod;
damage += attacker.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 0);
}
damage = Math.max(0, damage);

View File

@@ -138,9 +138,6 @@ public final class PhysicalAttack extends AbstractEffect
if (defence != -1)
{
// TODO: Find proper defence formula.
defence = effector.isPlayable() && (effected.getLevel() > 99) ? defence / 10 : defence;
// Trait, elements
final double weaponTraitMod = Formulas.calcWeaponTraitBonus(effector, effected);
final double generalTraitMod = Formulas.calcGeneralTraitBonus(effector, effected, skill.getTraitType(), true);
@@ -169,9 +166,8 @@ public final class PhysicalAttack extends AbstractEffect
// ...................____________Melee Damage_____________......................................___________________Ranged Damage____________________
// ATTACK CALCULATION 77 * ((pAtk * lvlMod) + power) / pdef            RANGED ATTACK CALCULATION 70 * ((pAtk * lvlMod) + power + patk + power) / pdef
// ```````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^``````````````````````````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + _power + rangedBonus)) / defence;
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + (_power * effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 1)) + effector.getStat().getValue(Stats.SKILL_POWER_ADD, 0) + rangedBonus)) / defence;
damage = baseMod * abnormalMod * ssmod * critMod * weaponTraitMod * generalTraitMod * attributeMod * pvpPveMod * randomMod;
damage += effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 0);
}
effector.doAttack(damage, effected, skill, false, false, critical, false);

View File

@@ -77,7 +77,6 @@ public final class PhysicalAttackHpLink extends AbstractEffect
}
final double attack = effector.getPAtk();
final double power = _power;
double defence = effected.getPDef();
switch (Formulas.calcShldUse(effector, effected))
@@ -99,9 +98,6 @@ public final class PhysicalAttackHpLink extends AbstractEffect
if (defence != -1)
{
// TODO: Find proper defence formula.
defence = effector.isPlayable() && (effected.getLevel() > 99) ? defence / 10 : defence;
// Trait, elements
final double weaponTraitMod = Formulas.calcWeaponTraitBonus(effector, effected);
final double generalTraitMod = Formulas.calcGeneralTraitBonus(effector, effected, skill.getTraitType(), true);
@@ -129,9 +125,8 @@ public final class PhysicalAttackHpLink extends AbstractEffect
// ...................____________Melee Damage_____________......................................___________________Ranged Damage____________________
// ATTACK CALCULATION 77 * ((pAtk * lvlMod) + power) / pdef            RANGED ATTACK CALCULATION 70 * ((pAtk * lvlMod) + power + patk + power) / pdef
// ```````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^``````````````````````````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + power + rangedBonus)) / defence;
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + (_power * effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 1)) + effector.getStat().getValue(Stats.SKILL_POWER_ADD, 0) + rangedBonus)) / defence;
damage = baseMod * ssmod * critMod * weaponTraitMod * generalTraitMod * attributeMod * pvpPveMod * randomMod;
damage += effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 0);
damage *= -((effector.getCurrentHp() * 2) / effector.getMaxHp()) + 2;
}

View File

@@ -111,9 +111,6 @@ public final class PhysicalAttackSaveHp extends AbstractEffect
if (defence != -1)
{
// TODO: Find proper defence formula.
defence = effector.isPlayable() && (effected.getLevel() > 99) ? defence / 10 : defence;
// Trait, elements
final double weaponTraitMod = Formulas.calcWeaponTraitBonus(effector, effected);
final double generalTraitMod = Formulas.calcGeneralTraitBonus(effector, effected, skill.getTraitType(), true);
@@ -141,9 +138,8 @@ public final class PhysicalAttackSaveHp extends AbstractEffect
// ...................____________Melee Damage_____________......................................___________________Ranged Damage____________________
// ATTACK CALCULATION 77 * ((pAtk * lvlMod) + power) / pdef            RANGED ATTACK CALCULATION 70 * ((pAtk * lvlMod) + power + patk + power) / pdef
// ```````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^``````````````````````````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + _power + rangedBonus)) / defence;
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + (_power * effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 1)) + effector.getStat().getValue(Stats.SKILL_POWER_ADD, 0) + rangedBonus)) / defence;
damage = baseMod * ssmod * critMod * weaponTraitMod * generalTraitMod * attributeMod * pvpPveMod * randomMod;
damage += effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 0);
}
final double minHp = (effected.getMaxHp() * _saveHp) / 100;

View File

@@ -131,9 +131,6 @@ public final class PhysicalAttackWeaponBonus extends AbstractEffect
if (defence != -1)
{
// TODO: Find proper defence formula.
defence = effector.isPlayable() && (effected.getLevel() > 99) ? defence / 10 : defence;
// Trait, elements
final double weaponTraitMod = Formulas.calcWeaponTraitBonus(effector, effected);
final double generalTraitMod = Formulas.calcGeneralTraitBonus(effector, effected, skill.getTraitType(), true);
@@ -162,9 +159,8 @@ public final class PhysicalAttackWeaponBonus extends AbstractEffect
// ...................____________Melee Damage_____________......................................___________________Ranged Damage____________________
// ATTACK CALCULATION 77 * ((pAtk * lvlMod) + power) / pdef            RANGED ATTACK CALCULATION 70 * ((pAtk * lvlMod) + power + patk + power) / pdef
// ```````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^``````````````````````````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + _power + rangedBonus)) / defence;
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + (_power * effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 1)) + effector.getStat().getValue(Stats.SKILL_POWER_ADD, 0) + rangedBonus)) / defence;
damage = baseMod * ssmod * critMod * weaponBonus * weaponTraitMod * generalTraitMod * attributeMod * pvpPveMod * randomMod;
damage += effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 0);
}
effector.doAttack(damage, effected, skill, false, false, critical, false);

View File

@@ -125,9 +125,6 @@ public final class PhysicalSoulAttack extends AbstractEffect
if (defence != -1)
{
// TODO: Find proper defence formula.
defence = effector.isPlayable() && (effected.getLevel() > 99) ? defence / 10 : defence;
// Trait, elements
final double weaponTraitMod = Formulas.calcWeaponTraitBonus(effector, effected);
final double generalTraitMod = Formulas.calcGeneralTraitBonus(effector, effected, skill.getTraitType(), true);
@@ -156,9 +153,8 @@ public final class PhysicalSoulAttack extends AbstractEffect
// ...................____________Melee Damage_____________......................................___________________Ranged Damage____________________
// ATTACK CALCULATION 77 * ((pAtk * lvlMod) + power) / pdef            RANGED ATTACK CALCULATION 70 * ((pAtk * lvlMod) + power + patk + power) / pdef
// ```````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^``````````````````````````````````````^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + _power + rangedBonus)) / defence;
final double baseMod = (wpnMod * ((attack * effector.getLevelMod()) + (_power * effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 1)) + effector.getStat().getValue(Stats.SKILL_POWER_ADD, 0) + rangedBonus)) / defence;
damage = baseMod * soulsMod * ssmod * critMod * weaponTraitMod * generalTraitMod * attributeMod * pvpPveMod * randomMod;
damage += effector.getStat().getValue(Stats.PHYSICAL_SKILL_POWER, 0);
}
effector.doAttack(damage, effected, skill, false, false, critical, false);

View File

@@ -0,0 +1,31 @@
/*
* This file is part of the L2J Mobius project.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package handlers.effecthandlers;
import org.l2jmobius.gameserver.model.StatsSet;
import org.l2jmobius.gameserver.model.stats.Stats;
/**
* @author Mobius
*/
public class SkillPowerAdd extends AbstractStatEffect
{
public SkillPowerAdd(StatsSet params)
{
super(params, Stats.SKILL_POWER_ADD);
}
}

View File

@@ -1176,7 +1176,7 @@
<amount>54</amount>
<mode>DIFF</mode>
</effect>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>118</amount>
<mode>DIFF</mode>
</effect>
@@ -1194,7 +1194,7 @@
<amount>54</amount>
<mode>DIFF</mode>
</effect>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>118</amount>
<mode>DIFF</mode>
</effect>
@@ -1212,7 +1212,7 @@
<amount>54</amount>
<mode>DIFF</mode>
</effect>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>118</amount>
<mode>DIFF</mode>
</effect>
@@ -1230,7 +1230,7 @@
<amount>54</amount>
<mode>DIFF</mode>
</effect>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>118</amount>
<mode>DIFF</mode>
</effect>
@@ -1248,7 +1248,7 @@
<amount>54</amount>
<mode>DIFF</mode>
</effect>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>118</amount>
<mode>DIFF</mode>
</effect>
@@ -1512,7 +1512,7 @@
<magicLvl>1</magicLvl>
<isDebuff>false</isDebuff>
<effects>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>338</amount>
<mode>DIFF</mode>
</effect>
@@ -1526,7 +1526,7 @@
<magicLvl>1</magicLvl>
<isDebuff>false</isDebuff>
<effects>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>338</amount>
<mode>DIFF</mode>
</effect>
@@ -1540,7 +1540,7 @@
<magicLvl>1</magicLvl>
<isDebuff>false</isDebuff>
<effects>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>338</amount>
<mode>DIFF</mode>
</effect>
@@ -1554,7 +1554,7 @@
<magicLvl>1</magicLvl>
<isDebuff>false</isDebuff>
<effects>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>338</amount>
<mode>DIFF</mode>
</effect>
@@ -1568,7 +1568,7 @@
<magicLvl>1</magicLvl>
<isDebuff>false</isDebuff>
<effects>
<effect name="PhysicalSkillPower">
<effect name="SkillPowerAdd">
<amount>338</amount>
<mode>DIFF</mode>
</effect>

View File

@@ -1084,12 +1084,12 @@
<mode>PER</mode>
</effect>
<effect name="PhysicalSkillPower">
<amount>
<value level="1">15</value>
<value level="2">16</value>
<value level="3">17</value>
<value level="4">20</value>
</amount>
<amount>
<value level="1">15</value>
<value level="2">16</value>
<value level="3">17</value>
<value level="4">20</value>
</amount>
<mode>PER</mode>
</effect>
<effect name="MagicalSkillPower">

View File

@@ -167,7 +167,7 @@ MagicalAttackSpeed: Casting Spd. stat
MagicalDamOverTime: Magical attack over time.
MagicalDefence: M. Def stat.
MagicalEvasion: M. Evasion stat.
MagicalSkillPower: Magical Skill Power stat. (l2jmobius)
MagicalSkillPower: Magical Skill Power stat (use only MUL). (l2jmobius)
MagicalSoulAttack: Magical attack based on souls formula.
MagicCriticalDamage: Magical Critical Damage stat
MagicCriticalRate: Magical Critical Rate stat.
@@ -208,7 +208,7 @@ PhysicalDefence: P. Def stat.
PhysicalEvasion: P. Evasion stat.
PhysicalMute: Prevents the usage of physical skills. Shield Slam.
PhysicalShieldAngleAll: Causes the shield to block at 360 degree angle.
PhysicalSkillPower: Physical Skill Power stat.
PhysicalSkillPower: Physical Skill Power stat (use only MUL).
PhysicalSoulAttack: Physical attack depending on souls.
PkCount: Increases PK kills.
Plunder: Takes bonus item from monster. Sweep effect.
@@ -269,6 +269,7 @@ SkillCritical: Activates double debuff or cooldown reset critical based on the s
SkillCriticalDamage: Skill critical damage stat.
SkillCriticalProbability: Skill critical rate stat.
SkillEvasion: Skill evasion stat.
SkillPowerAdd: Adds set ammount of power to skills (use only DIFF). (l2jmobius)
SkillTurning: Stops target's casting.
SkillTurningOverTime: Stops target's casting at a fixed rate.
SoulBlow: Physical attack based on blow formula with bonus damage from souls.