Jump to content

Question

Posted

Hello,

 

how can i check if the player make, for example, 2 kills in 5 seconds.

 

[Algorithmic]

private date&hour time; (IDK actually the real name of this type)
private date&hour timelast;
private int cumulkill = 0; // 3 global variables in L2PcInstance

in setPvpKills() method // method that add a pvp point

setCumulKill(CumulKill()+1);
if ( cumulkill() == 1)
{
     time = current time;
     timelast = time +5 sec;
}

doublekill();


public void doublekill ()
if ( time =< timelast)
{
     if (CumulKill() >=2)
     {
     reward doublekill;
     }
}
else
{
     SetCumulKill (0);
}

public void SetCumulKill (int x)
{
     cumulkill = x;
}

public int CumulKill ()
{
     return cumulkill;
}

[/algorithmic]

 

This algo can works?

 

Cordially,

Bleadd

 

10 answers to this question

Recommended Posts

  • 0
Posted

setCumulKill(CumulKill()+1);
if ( cumulkill() == 1)
{
     time = current time;
     timelast = time +5 sec;
}

doublekill();


public void doublekill ()
if ( time =< timelast)
{
     if (CumulKill() >=2)
     {
     reward doublekill;
     }
}
else
{
     SetCumulKill (0);
}

you modify time and timelast only once, so time < timelast every moment

i will edit this post to try to write something that will work, dont have time atm

 

Edit:

long _savedTime = 0;
int _pvpStreak = 0; // not needed for only double kills
...


if (System.currentTimeMillis() - 5 sec <= _savedTime){
          _pvpStreak++;
          switch ( _pvpStreak){
                 case 2: ...
                           break;
                 case ...
          }
}
else{
           _savedTime = System.currentTimeMillis();
           _pvpStreak = 0;
}

more or less

  • 0
Posted

You verify the current time compared to registered time (which was current time when you LAUNCHED the task, if you followed... but registered in a variable, so it is fixed now and can be used to compared elapsed time) in a task launched repetitively every sec for 5sec.

 

How to stop the task ? It can be either a counter which counts until 5 and drop current task, or a check made on registered time in ms + 5000 > current time in ms.

 

Thing to use : System.currentTimeMillis(), ThreadPoolManager

  • 0
Posted

tasks for this? no for a server with a lot of ppl.

 

edit: you can update the saved time in the succeed case of if if you want to

It can be a general task, as it already exists for knownlist updates, decay task and so on.

  • 0
Posted

public void CumulKills ()
{
	this.setKillStreak(this.getKillStreak() +1);

	if (this.getKillStreak() == 1)
	{ 
		streaktime = System.currentTimeMillis();
	}

	if ((streaktime + 5000) > System.currentTimeMillis())
	{
		switch (this.getKillStreak())
		{
			case 2:
                                          break;

	                default:
		}
	}
	else
	{
		this.setKillStreak(1);
		streaktime = System.currentTimeMillis();
	}
}

 

Finally, this code works.

  • 0
Posted

couldn't you just schedule a task that will execute in 5 seconds when a player takes 1 pvp kill. and just check the other variable? ex:

 

private int k;

class check implements Runnable{
L2PcInstance p;
public check(L2PcInstance p){
if(p.k == 2){
p.k = 0;
//DONE
}
}
   public void run(){ 
   check(p);
}
}

 

and in the increasepvpkills method after setpvpkills + 1,

ThreadpoolManager.scheduleGeneral(new check(this),50000); /50000 = the time in 

milliseconds , its random

  • 0
Posted

What's different from my code?

 

 

Better to use task? I don't get the difference between tasks like your code and adenaman/mine

  • 0
Posted

What's different from my code?

 

 

Better to use task? I don't get the difference between tasks like your code and adenaman/mine

isn't it a faster way? but i don't know i just noticed it :P maybe its better but maybe and worse who knows .
  • 0
Posted

task should be used only when the problem can only be resolved with them, are much more expensive than sequential code. But it your decision, for example, Java is a lot more slower than c/c++ but its easier to use.

 

Tasks are great for synchronized events but this one is more asyncr (you get a kill when you get a kill) than syncr (the 5 sec time)

 

And i find the sequential easier

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..