Jump to content

Recommended Posts

Posted

hello

i was playing with some skills stats like 

 

PVP_PHYSICAL_DMG("pvpPhysDmg"),
PVP_MAGICAL_DMG("pvpMagicalDmg"),
PVP_PHYS_SKILL_DMG("pvpPhysSkillsDmg"),
 
and i saw a guy asking somewhere for pvpPhysicalDef stats so i tryed to make em.. its based on l2jfrozen also.
 
com.l2jfrozen.gameserver.skills.stats

find this

PVP_PHYS_SKILL_DMG("pvpPhysSkillsDmg"),

and below add these

 

PVP_PHYSICAL_DEF("pvpPhysDef"),
PVP_MAGICAL_DEF("pvpMagicalDef"),
PVP_PHYS_SKILL_DEF("pvpPhysSkillsDef"),

now go to 

com.l2jfrozen.gameserver.skills.formulas

find always the first line and add the +

if((attacker instanceof L2PcInstance || attacker instanceof L2Summon) && (target instanceof L2PcInstance || target instanceof L2Summon))
{
if(skill == null)
{
damage *= attacker.calcStat(Stats.PVP_PHYSICAL_DMG, 1, null, null);
+damage /= target.calcStat(Stats.PVP_PHYSICAL_DEF, 1, null, null);
}
else
{
damage *= attacker.calcStat(Stats.PVP_PHYS_SKILL_DMG, 1, null, null);
+damage /= target.calcStat(Stats.PVP_PHYS_SKILL_DEF, 1, null, null);
}
}
// Pvp bonusses for dmg
if((attacker instanceof L2PcInstance || attacker instanceof L2Summon) && (target instanceof L2PcInstance || target instanceof L2Summon))
{
if(skill.isMagic())
{
damage *= attacker.calcStat(Stats.PVP_MAGICAL_DMG, 1, null, null);
+damage /= target.calcStat(Stats.PVP_MAGICAL_DEF, 1, null, null);
}
else
{
damage *= attacker.calcStat(Stats.PVP_PHYS_SKILL_DMG, 1, null, null);
+damage /= target.calcStat(Stats.PVP_PHYS_SKILL_DEF, 1, null, null);
}
}
// Dmg bonusses in PvP fight
if(isPvP)
{
if(skill == null)
{
damage *= attacker.calcStat(Stats.PVP_PHYSICAL_DMG, 1, null, null);
+damage /= target.calcStat(Stats.PVP_PHYSICAL_DEF, 1, null, null);
}
else
{
damage *= attacker.calcStat(Stats.PVP_PHYS_SKILL_DMG, 1, null, null);
damage /= target.calcStat(Stats.PVP_PHYS_SKILL_DMG, 1, null, null);
}
}

so you can go ingame and use as stats "pvpPhysDef" , "pvpMagicalDef" , "pvpPhysSkillsDef"

its tested and works fine.

 

also something else to make a better balance with the mages. Its exactly the same with the critical damage that fighters got. this is for mages magical critical damage in a better way than it is.

com.l2jfrozen.gameserver.skills.stats

find

CRITICAL_DAMAGE_ADD("cAtkAdd"),

and below add 

MAGICAL_CRITICAL_DAMAGE("mcAtk"),
MCRITICAL_DAMAGE_ADD("mAtkAdd"),
MCRIT_VULN("mCritVuln"),

now go to 

com.l2jfrozen.gameserver.model.actor.stats.CharStat

find

public final double getCriticalDmg(L2Character target, double init)
{
return calcStat(Stats.CRITICAL_DAMAGE, init, target, null);
}

and below add

/**
* Return the MCritical Damage rate (base+modifier) of the L2Character.
*
* @param target the target
* @param init the init
* @return the critical dmg
*/
public final double getMagicalCriticalDmg(L2Character target, double init)
{
return calcStat(Stats.MAGICAL_CRITICAL_DAMAGE, init, target, null);
}

now go to 

com.l2jfrozen.gameserver.datatables.xml.AugmentationData

find and delete this line

if(as.getStat() == Stats.CRITICAL_DAMAGE)

and add this one

if(as.getStat() == Stats.CRITICAL_DAMAGE || as.getStat() == Stats.MAGICAL_CRITICAL_DAMAGE)

finally go to 

com.l2jfrozen.gameserver.skills.formulas

find 

else if(mcrit)
{
//damage *= 4;
damage *= Config.MAGIC_CRITICAL_POWER;
}and replace it with 
else if (mcrit)
{
//Finally retail like formula
double mAtkMultiplied = damage + attacker.calcStat(Stats.MAGICAL_CRITICAL_DAMAGE, damage, target, skill);
double mAtkVuln = target.calcStat(Stats.MCRIT_VULN, 1, target, null);
double improvedDamageBymriticalMulAndVuln = mAtkMultiplied * mAtkVuln;
double improvedDamageBymriticalMulAndAdd = improvedDamageBymriticalMulAndVuln + attacker.calcStat(Stats.MCRITICAL_DAMAGE_ADD, 0, target, skill);


damage = improvedDamageBymriticalMulAndAdd;


}

now you will have stats "mcAtk" , "mAtkAdd", "mCritVuln".

 

also i've got a cp drain and mp drain on attack. its like "absorbDam"

com.l2jfrozen.gameserver.skills.stats

find

ABSORB_DAMAGE_PERCENT("absorbDam"),

and below add

ABSORB_CP_PERCENT("absorbCp"),
ABSORB_MP_PERCENT("absorbMp"),

now go to 

com.l2jfrozen.gameserver.model.L2Characters

find

double absorbPercent = getStat().calcStat(Stats.ABSORB_DAMAGE_PERCENT, 0, null, null);


if (absorbPercent > 0)
{
int maxCanAbsorb = (int) (getMaxHp() - getCurrentHp());
int absorbDamage = (int) (absorbPercent / 100. * damage);


if (absorbDamage > maxCanAbsorb)
{
absorbDamage = maxCanAbsorb; // Can't absord more than max hp
}


if (absorbDamage > 0)
{
setCurrentHp(getCurrentHp() + absorbDamage);


// Custom messages - nice but also more network load
// Custom messages - nice but also more network load
if (Config.CUSTOM_MSG)
{
if (this instanceof L2PcInstance)
((L2PcInstance) this).sendMessage("You absorbed " + absorbDamage + " Hp.");
}
}
}

and below add

// Absorb CP from the damage inflicted
double absorbCPPercent = getStat().calcStat(Stats.ABSORB_CP_PERCENT, 0, null, null);


if (absorbCPPercent > 0)
{
int maxCanAbsorb = (int) (getMaxCp() - getCurrentCp());
int absorbDamage = (int) (absorbCPPercent / 100. * damage);


if (absorbDamage > maxCanAbsorb)
{
absorbDamage = maxCanAbsorb; // Can't absord more than max hp
}


if (absorbDamage > 0)
{
setCurrentCp(getCurrentCp() + absorbDamage);


// Custom messages - nice but also more network load
// Custom messages - nice but also more network load
if (Config.CUSTOM_MSG)
{
if (this instanceof L2PcInstance)
((L2PcInstance) this).sendMessage("You absorbed " + absorbDamage + " Cp.");
}
}
}


// Absorb HP from the damage inflicted
double absorbMPPercent = getStat().calcStat(Stats.ABSORB_MP_PERCENT, 0, null, null);


if (absorbMPPercent > 0)
{
int maxCanAbsorb = (int) (getMaxMp() - getCurrentMp());
int absorbDamage = (int) (absorbMPPercent / 100. * damage);


if (absorbDamage > maxCanAbsorb)
{
absorbDamage = maxCanAbsorb; // Can't absord more than max hp
}


if (absorbDamage > 0)
{
setCurrentMp(getCurrentMp() + absorbDamage);


// Custom messages - nice but also more network load


// Custom messages - nice but also more network load
if (Config.CUSTOM_MSG)
{
if (this instanceof L2PcInstance)
((L2PcInstance) this).sendMessage("You absorbed " + absorbDamage + " Mp.");
}
}
}

so u can use "absorbCp", "absorbMp"

 

well thats all ;D its nothing special but it can help 
 

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • I think that solves the freeze thing, anyway great share! 
    • Introducing: Daily & Weekly Missions!   I've released a major panel update with a new Missions system and expanded language support.   Players can now complete daily and weekly missions directly through the panel and claim rewards such as balance or items. Mission progress is tied to in-game activity and supported panel actions, and the update also adds a dedicated Missions page, dashboard mission previews, claimable mission indicators, and full admin tools for creating and managing missions.   The Roll page now shows the potential reward drops below the roll container.   Alongside this, I’ve expanded the panel’s language support with new locale options, including Bulgarian, Czech, Georgian, Lithuanian, Polish, Romanian, Japanese, Simplified Chinese, and Traditional Chinese.     The Demo is now updated with the new features for you to try out!
    • I sell complete packs. If you want to add an item, NPC, etc., you have to do that yourselves. Your friend bought the pack; he's the one who needs to configure his server type. He received what he bought as agreed, and I'm saying this without knowing who you're talking about, because anyone who buys something receives what was agreed upon.   Regards. mmmmm L2Velmore ????   If that's the one, I see everything went well... if I remember correctly you were crying over $100, I gave you a better price, and I suppose you made thousands with that... And you're still coming back to complain? :=)
    • I know many people have struggled with this specific issue and had trouble setting up the correct behavior for Toggle skills in aCis. By default, toggles interrupt the player's movement (retail-like), which often feels clunky to players who prefer a smoother, more modern experience. I've prepared a clean solution that eliminates this "freeze" and allows for fluid movement while toggling your auras. Below is the code on how to achieve this. Hope it helps! Changes in PlayerAI.java: Modified doActiveIntention to properly update the active state without stalling. Removed the forced stop() during toggle casting. Added a MoveToLocation broadcast to ensure other players see your movement correctly (prevents visual "teleporting" or desync). Best regards 😃 diff --git a/aCis_gameserver/java/net/sf/l2j/gameserver/model/actor/ai/type/PlayerAI.java b/aCis_gameserver/java/net/sf/l2j/gameserver/model/actor/ai/type/PlayerAI.java index ba0425a..1b2658d 100644 --- a/aCis_gameserver/java/net/sf/l2j/gameserver/model/actor/ai/type/PlayerAI.java +++ b/aCis_gameserver/java/net/sf/l2j/gameserver/model/actor/ai/type/PlayerAI.java @@ -28,6 +28,7 @@  import net.sf.l2j.gameserver.network.serverpackets.ActionFailed;  import net.sf.l2j.gameserver.network.serverpackets.AutoAttackStart;  import net.sf.l2j.gameserver.network.serverpackets.ChairSit; +import net.sf.l2j.gameserver.network.serverpackets.MoveToLocation;  import net.sf.l2j.gameserver.network.serverpackets.MoveToLocationInVehicle;  import net.sf.l2j.gameserver.network.serverpackets.MoveToPawn;  import net.sf.l2j.gameserver.network.serverpackets.StopMove; @@ -159,7 +160,10 @@      @Override      public synchronized void doActiveIntention()      { -        doIdleIntention(); +        prepareIntention(); +        _currentIntention.updateAsActive(); +        if (!getActor().isMoving()) +            thinkIdle();      }            @Override @@ -280,8 +284,9 @@                    if (skill.isToggle())          { -            getActor().getMove().stop();              getActor().getCast().doToggleCast(skill, target); +            if (getActor().isMoving()) +                getActor().broadcastPacket(new MoveToLocation(getActor()));          }          else          { https://pastebin.com/twZujZ3Y
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..