Jump to content

Question

Posted

Hey guys I have a problem with my server iam using l2f pack every things is OK but some time players die in olympiad and he get reviv request to town like he dead in pvp it's not happen every day may be 3 -4 times per week .

Server doesn't show any error at log .

Hop you help me to solve it .

Sorry for my bad english .

12 answers to this question

Recommended Posts

  • 0
Posted


protected void onReduceCurrentHp(double damage, Creature attacker, Skill skill, boolean awake, boolean standUp, boolean directHp)

{

if(standUp && !isInTvT())

{

standUp();

if(isFakeDeath())

{

breakFakeDeath();

}

}

 

lastAttacker = attacker;

lastAttackDate = System.currentTimeMillis();

 

if(attacker.isPlayable())

{

if(!directHp && (getCurrentCp() > 0))

{

double cp = getCurrentCp();

if(isInOlympiadMode())

{

addDamageOnOlympiad(attacker, skill, damage, cp);

}

 

if(cp >= damage)

{

cp -= damage;

damage = 0;

}

else

{

damage -= cp;

cp = 0;

}

 

setCurrentCp(cp);

}

}

 

double hp = getCurrentHp();

 

DuelEvent duelEvent = getEvent(DuelEvent.class);

if(duelEvent != null)

{

if(hp <= damage)

{

setCurrentHp(1, true);

duelEvent.onDie(this);

return;

}

}

 

if((getPvPTeam() != 0) && (_event != null))

{

if(hp <= damage) // if x <= 1 - killed

{

setCurrentHp(1, true);

_event.doDie(attacker, this);

return;

}

}

 

if(isInOlympiadMode())

{

addDamageOnOlympiad(attacker, skill, damage, hp);

 

if(hp + 0.5 <= damage)

{

if(_olympiadGame.getType() != CompType.TEAM)

{

setCurrentHp(1, true);

_olympiadGame.setWinner(getOlympiadSide() == 1 ? 2 : 1);

_olympiadGame.endGame(20000, false);

attacker.getAI().setIntention(CtrlIntention.AI_INTENTION_ACTIVE);

attacker.sendActionFailed();

return;

}

else if(_olympiadGame.doDie(this))

{

 

_olympiadGame.setWinner(getOlympiadSide() == 1 ? 2 : 1);

_olympiadGame.endGame(20000, false);

}

}

}

 

super.onReduceCurrentHp(damage, attacker, skill, awake, standUp, directHp);

}

 

  • 0
Posted

This line:

if(hp + 0.5 <= damage)

should be:

if(hp - damage < 0.5)

Actually it took me a while to figure this out. I think this line is the only cause, not 100% sure though.

  • 0
Posted (edited)
if(standUp && !isInTvT()){
	standUp();
	...
}

Can someone explain me this?

He is standUp() already ,so whats the point of it?

 

Also

if(isFakeDeath()){
	breakFakeDeath();
}

Since u standUp(),why do u check if he has fakeDeath?

Being is fakeDeath means that he isnt standUp,and the first if confirmed that he is standUp +u used standUp above,which means its always false..

 

Any explaination?

Edited by bravetobe
  • 0
Posted
if(standUp && !isInTvT()){
	standUp();
	...
}

Can someone explain me this?

He is standUp() already ,so whats the point of it?

 

Also

if(isFakeDeath()){
	breakFakeDeath();
}

Since u standUp(),why do u check if he has fakeDeath?

Being is fakeDeath means that he isnt standUp,and the first if confirmed that he is standUp +u used standUp above,which means its always false..

 

Any explaination?

 

Because guy who was adding events to this pack, didnt do it carefuly. Maybe fandc is still using them, but I dont really know.

 

 

thank you for your help i will try ti change it but can you till me or explain to me what happen in this line ?

Player is considered dead if he has < 0.5 hp. In your code if he have got 1 HP and gets 0.7 damage, then condition will be: if(1 + 0.5 <= 0.7) - that's false

  • 0
Posted (edited)
if(standUp && !isInTvT()){
	standUp();
	...
}

Can someone explain me this?

He is standUp() already ,so whats the point of it?

 

Also

if(isFakeDeath()){
	breakFakeDeath();
}

Since u standUp(),why do u check if he has fakeDeath?

Being is fakeDeath means that he isnt standUp,and the first if confirmed that he is standUp +u used standUp above,which means its always false..

 

Any explaination?

 

as i can read the arguments from the function

(double damage, Creature attacker, Skill skill, boolean awake, boolean standUp, boolean directHp)

standUp doesnt mean that is stand up already, its just true/false

otherwise should be if(standUp() && !isInTvt) ...

 

so if standup setted true and not in tvt -> stand up and if is fakedeath, stop this

Edited by ⏇Melron⏇℠Abs

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

    • New user panel SOURCE $ 200 for source code. R$ 1000,00 BRL for source code.    
    • Hello everyone, we are one of the top gaming currency stores. We work exclusively with top projects. If you are interested in anything like Adena, Coins, Equip, write to us Discord - pchelacoin Telegram - https://t.me/ipchelacoin BOHPTS, KETRAWARS, EURO-PVP, L2REBORN, E-GLOBAL, LA2DREAM TOP PRICE !!!!!!!
    • L2Elixir – Patch 4 Is Live!   We’re working non-stop, day and night, to deliver the best possible quality and bring back what made L2Elixir special. This project is built with passion, not shortcuts — for the old-school players who remember, and the new ones who want to experience it properly. Thank you for being part of the journey. Together, we’re making L2Elixir great again ❤️ The legends never fade.    ⚙️ General Enabled Class Change service (same class type only) ALT + B → Services → Character Development Enabled Shift + Click on Treasure Chests Players can now identify real chests (Adena, scroll drops) and use Key / Unlock Event deaths now cancel only debuffs, All self buffs are preserved, fixes issues with Root and similar effects Bladedancer class can now log in even when Max Clients (2) is reached. Since an active Bladedancer is not available for every damage dealer and some players tried to abuse this via VPN or a second PC, this feature was added to keep things fair. protections applies, requires testing!    🎒 Items Crystallizing enchanted items now gives the correct increased crystal amount (retail-like behavior) Removed Agathion Seal Bracelet: Rudolph from Santa rewards (Gracia Final item) Added Dualsword Craft Stamp into Milestone Exchange list    🧙 Skills Fixed Banish Undead lethal chance Hot Springs Malaria and similar effects now level up faster while being attacked
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock