Jump to content

Question

Posted

Hi guys,

 

So recently i did a new IL server for our small group, and i noticed that there is a bug regarding speed. If the characters base runspeed is standard, and you toggle/buff with a certain buff that reduces the speed temporarily, the runspeed goes down to 0 until you cancel that skill. I recompiled my server, checked the skills settings for the runspeed reduction, checked the core settings for the formula calculations, the problem still persists. The only solution i found that works is if i increase the base runspeed by 30, but this isn't a fix. Any ideas why?

 

Here is the link to a short gif to see whats happening:

SpeedBug.gif 

7 answers to this question

Recommended Posts

  • 0
Posted

So, regarding your question I did some testing with a Human Fighter (no speed boost). Base run speed 126.

If i buff with WW lv2, thats +33 speed, totaling at 159 (ok).

Adding Quick Step passive lv2, thats +11 speed, totaling at 170.

Equipping the DC robe set that gives +7 speed, totaling at 177.

As you can see, I can increase the speed as much as I want, and its correct.

Now, with 177 speed, if i activate Parry Stance which is -10% off the basic runspeed (126-10% = 12.6)  (<mul order="0x30" stat="runSpd" val="0.9"/>)  it gives me 164 run speed which is correct again. But, after several tests, i came to the conclusion that the speed decrease is working until the runspeed reaches 115. If the value goes below, it turns to 0. 

I just don't get it why...In the SQL table at the char_templates, the MOVE_SPEED is 115.

This is one weird bug to be honest...

  • 0
Posted

So, "run to walk" toggle also triggers that 0 behavior ?

 

And if you disconnect while being 0, you get 0 at player store ?

 

Buffing you enough (ww2 + run speed totem + bers + ...) + parry stance debuff, for a run speed total higher than 115, don't trigger the behavior ?

 

----

 

You should check about custom config related to speed.

 

If you're sure "115" value triggers it, search for this value on core and  properties.

  • 0
Posted

So after a long and painful testing and searching the core what might cause this bug, i finally caught the little bastard.

My knowledge in coding is mediocre at best, but i still managed to fix the problem.

In the java file gameserver/model/actor/stat/CharStat.java is where the speed is calculated. I compared this file with an older core i have and noticed a small difference:

 

This is the bugged code:

 

	public final float getMovementSpeedMultiplier()
	{
		if (_activeChar == null)
		{
			return 1;
		}
		
		return getRunSpeed() / _activeChar.getTemplate().baseRunSpd;
	}

And this is the fixed code:

	public final float getMovementSpeedMultiplier()
	{
		if (_activeChar == null)
		{
			return 1;
		}
		
		return (getRunSpeed() * 1f) / _activeChar.getTemplate().baseRunSpd;
	}

As you can see, the getRunSpeed function was missing this character * 1f. Not sure what it does, but my guess would be it rounds up the final value. I might be wrong. Either way, its fixed now. Thanks for the advice.

 

  • 0
Posted

If both getRunSpeed() and _activeChar.getTemplate().baseRunSpd are int, then you lose the division accuracy. Introducing 1f add back the float behavior.

 

But normally those values aren't supposed to be both int. Not sure what is your getRunSpeed(), but it should return float normally.

  • 0
Posted (edited)
21 hours ago, Tryskell said:

If both getRunSpeed() and _activeChar.getTemplate().baseRunSpd are int, then you lose the division accuracy. Introducing 1f add back the float behavior.

 

But normally those values aren't supposed to be both int. Not sure what is your getRunSpeed(), but it should return float normally.

Actually, L2J has been using both as integers until Freya (in the case of getRunSpeed, it's probably because packets write speed stats as integers and it seemed an easy solution to them).

Here is the method he's probably using.

	/**
	 * Return the RunSpeed (base+modifier) of the L2Character in function of the Armour Expertise Penalty.
	 */
	public int getRunSpeed()
	{
		if (_activeChar == null)
		{
			return 1;
		}
		
		// err we should be adding TO the persons run speed
		// not making it a constant
		double baseRunSpd = _activeChar.getTemplate().baseRunSpd;
		
		if (baseRunSpd == 0)
		{
			return 0;
		}
		
		return (int) Math.round(calcStat(Stats.RUN_SPEED, baseRunSpd, null, null));
	}

They even preferred rounding value and casting it to int instead of returning it as it is.

Edited by DnR
  • 0
Posted

The first example was not returning a float result as the second one seems like it's the correct one however when you want to do a division between 2 floats and you want the exact result you have to type something like "2/.1f”

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

    • WIPE ! NEW SEASON GRAND OPENING FROM TODAY ! - 23/01/2026, FRIDAY, 20:00 +3 GMT !
    • https://vpslab.cloud/ Premium DDoS Protection now included with every server.
    • # Changelog - Public Updates   This changelog tracks user-facing updates and improvements to Top.MaxCheaters.com.   ---   ## [1.2.0] - 2026-01-XX   ### ⚡ Performance Improvements - **Faster Page Loads**: Implemented intelligent caching system that makes pages load significantly faster - **My Servers Page**: Now loads instantly when revisiting (no more loading delays) - **Main Page**: Server listings and filters now load faster on repeat visits - **Premium Ads**: Pricing information loads instantly - **Overall Performance**: Site now loads 60-80% faster with reduced server load   ### 🔄 Improvements - Pages now remember recent data, reducing wait times when navigating - Automatic cache refresh ensures you always see up-to-date information - Better user experience with instant page loads on repeat visits   ---   ## [1.1.1] - 2026-01-XX   ### 🐛 Bug Fixes - **VIP Server Filter**: Fixed "VIP L2 Servers" filter to correctly show all premium tier servers (VIP, Gold VIP, and Pinned) - **Ad Pricing Display**: Fixed ad pricing on Premium Ads page to automatically update when changed in admin panel   ### 🔄 Improvements - Ad pricing now syncs automatically across all pages - More accurate server filtering by tier   ---   ## [1.1.0] - 2026-01-XX   ### ✨ New Features - **Complete Chronicle List**: All chronicle options are now available in server forms and filters, including the latest Lineage 2 chronicles - **Improved Chronicle Display**: Server rows now show cleaner, shorter chronicle names for better readability   ### 🐛 Bug Fixes - **Chronicle Filter**: Fixed issue where "Infinite Odyssey" chronicle filter was not working correctly - **Missing Chronicles**: Fixed missing chronicle options in server creation and editing forms   ### 🔄 Improvements - Chronicle filters and dropdowns now stay in sync with the latest available chronicles - Better chronicle name formatting in server listings for improved visual clarity   ---   ## [1.0.0] - Initial Release   ### Features - 🎮 Server listings with multiple tiers (Normal, VIP, Gold VIP, Pinned) - 📊 Click tracking and server statistics - 🌍 Multi-language support (English, Spanish, Portuguese, Greek, Russian) - 💳 Payment system for premium server features - 🔐 Secure authentication system - 👑 Admin panel for server management - 📱 Fully responsive design for all devices - 🔍 Advanced filtering system (by chronicle, rate, server type, date) - 📅 Server opening date tracking - 🎯 Two viewing modes: By Date and By Votes (coming soon for all users)   ---   ## About This Changelog   This changelog focuses on updates that directly impact the user experience. Internal development changes and technical improvements are not included here.   For questions or feedback, please contact support.v
  • 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..