Jump to content

  •  

Bug Tracker Migration

June 3rd
Good news everyone! The staff has decided that it is time to slowly kill off this Bug Tracker. We will begin the process of slowly migrating from this Bug Tracker over to our Github Issues which can be found here: https://github.com/HerculesWS/Hercules/issues

Over the next couple of days, I will be closing off any opportunity to create new reports. However, I still will keep the opportunity to reply to existing Bug Reports. Doing this will allow us to slowly fix any bug reports we have listed here so that we can easily migrate over to our Issue Tracker.

Update - June 7th 2015: Creating new bug posts has been disabled. Please use our https://github.com/HerculesWS/Hercules/issues tracker to post bugs. Users are still able to reply to existing bug posts.

- Administration

Issue Information

  • #003452

  • 3 - Medium

  • Fixed

Issue Confirmations

  • Yes (3)No (0)
Photo

player range is circular?!

Posted by Hercules Bot on 31 July 2009 - 07:42 PM

Originally posted by theultramage
http://www.eathena.w...er&showbug=3452


[rev=13944]: "Range for players' attacks and skills should always check for a circular area."
This change was based on a random baseless side-note ([bug=3339]) by Playtester:

I'm not sure how it is interpreted by eA or if we have already implemented that the range for monsters is square while for players it's circular.


Now where the heck did this come from? Aegis never uses circles anywhere, we proved that a few thousand revisions ago when eA was changed to not use circular distance checks. The abovementioned commit is a game-breaking regression wtf and should be removed.

(will be done as part of the charmerge mergeback)

Originally posted by Brian
(the rest of the replies from the original bug report)

he always bases on Doddler and so does he this time.

according to him, Aegis did use square for all distance check at the first time and then changed to use circular distance check to prevent some exploits(he didn't explain what).


It is not circular for attacks or skills on episode 11.3 aegis. If it was changed (and I did not read about it in the ragnarok news section), then it has to be something fairly recent. I think it's fake though.


Simple test conducted on cRO(EP13.1) shows range for player is denfinitely NOT square.

Player A and B

A1 A2 A3 A4 A5 A6 A7 A8 A9
o
o
o
o
o
o
o
o
o
o
o
o
o
B1
B2

B can attack A without moving when A is on cell A1 and B is on cell B1
B will have to move half a cell before starting to attack when A is on cell A1 and B is on cell B2
B can attack A without moving when A is on cell A2 and B is on cell B1
B can attack A without moving when A is on cell A3 and B is on cell B1
B can attack A without moving when A is on cell A4 and B is on cell B1
B can attack A without moving when A is on cell A5 and B is on cell B1
B can attack A without moving when A is on cell A6 and B is on cell B1
B can attack A without moving when A is on cell A7 and B is on cell B1
B can attack A without moving when A is on cell A8 and B is on cell B1
B will have to move half a cell before starting to attack when A is on cell A9 and B is on cell B1

(well, by move half a cell, i just wanted to describe the appearance and to say that the max range has been reached.)


Hm, this is a problem then.



It indeed is a circle (a rather imprecise parody of a circle, but whatever).
So now come the questions: does this apply to everything, or just client-controlled skill usage? What was that about mobs using square? Was that tested?



Originally posted by Rytech
I found this hard to believe, but after doing a test based on the test results in the pic I learned that this circle thing has to be real. Without it a physical range exploit is possible. Take a look at the pic I made from the test results.

In the pic you see I made a full circle using his data and then marked some white lines across it to mark each 45 degrees angle and also help with the white circle measurement. The white circle shows the green area which is castable on without moving is physically equal all around in distance (talking about in actural measured distance, not cell distance). Then I finally placed some numbers to mark cell ranges to show how far your really casting when targeting straight up or down, straight left or right, and at a direct 45 degrees angle.

Whats interesting here is while it looks normal to cast + or - 10 cells X or Y on the grid, you can clearly see how much further you can physically cast when targeting 10 cells with X and Y combined. 3 cells of physical distance. This extra distance is likely part of the exploit and also the reason Gravity switched the casting range to a circle. Imagine using that extra distance in some way like....like in WoE for example, or to kill MVP's more easily.

Now what if we combined this with ground AoE's? Most AoE's are known to follow the square shape layout which will cause the corners to physically stretch out more. So lets imagine a 9x9 AoE magic skill with a 9 cell range. Casted up, down, or all the way to the side, your AoE will be placed 9 cells away from you and the sides of the AoE will stretch out 4 cells all around. So you can hit something 13 cells away.

But what if we casted that same skill at a 45 degree angle at something thats standing on that line of cells? You can already cast physically further like that, but that AoE will also have its corners physically stretching out further then the sides of the AoE. So thats even a greater reach.

I dont know if its a illusion im seeing here honestly, but the pic is clearly speaking to me on whats going on. If the cast range thing is true, then keep it or have a config to enable/disable it. As for AoE's the day I see Land Protector change into a circle shape AoE is the day ill learn if they made AoE's follow circle forums.

Hope I explained this in a understandable way.

Originally posted by Angezerus
I can confirm that on rA mobs use sqare range, and players have somewhat of a bugged sqare circle. The first is a bit annoying because you can easilly walk into the corner of the monster's range even if it is far away, but you can't hit it from the same distance on a diagonal position. The second problem is with player attacks and skills. It seems that it's mixed up a bit because it's not really smooth, as you can see in my similar post:
http://rathena.org/b...2-position-bug/

When casting or attacking from outside of range, the player moves closer, but the movement is a bit buggy, and sometimes you cant attack from the position you moved onto, or when you cast a skill from outside, you move closer, but the skill interrupts and there is no cast. It looks like if it is using a larger area for position check, than attack range check, and when it moves to the calculated pos, you skill can't attack sometimes.

Please do something about this. It's very annoying, both the monster and the player version of the bug.

Edited by Angezerus, 06 April 2012 - 07:56 AM.


Originally posted by Angezerus
/panic

Originally posted by Angezerus
I have noticed some odd thing. Skills that's area is "full screen" uses a curcular area as well. This way they don't affect the whole screen. So based on this, everything has to be either circular, or sqare, because this mixed state is only a source of problems.

This includes: view range (currently sqare), attack range (currently circular), monster attack range (currently square), cast range (currently circular), monster cast range (currently sqare).

And movement is still bugged when attacking from outside of range.

Originally posted by Ind
I reproduced this on an official server, however I noticed our calculation is wrong somewhere, as i was testing vs a geographer in both rathena and official server I noticed when attacking from diagonal rathena makes the player move much closer than official server does, as I'm not a good math person I don't think I'm able to find out whats the actual formula.

Originally posted by Ind


this is the broken part:
{ // Range for players' attacks and skills should always have a circular check. [Inkfish]
  int dx = src->x - bl->x, dy = src->y - bl->y;
  if( !check_distance(dx*dx + dy*dy, 0, range*range+(dx&&dy?1:0)) )
   return false;
}
i'm not sure what can be broken there however.

Originally posted by Angezerus


this is the broken part:
{ // Range for players' attacks and skills should always have a circular check. [Inkfish]
  int dx = src->x - bl->x, dy = src->y - bl->y;
  if( !check_distance(dx*dx + dy*dy, 0, range*range+(dx&&dy?1:0)) )
   return false;
}
i'm not sure what can be broken there however.


I checked this function:
int check_distance(int dx, int dy, int distance)
{
#ifdef CIRCULAR_AREA
//In this case, we just do a square comparison. Add 1 tile grace for diagonal range checks.
return (dx*dx + dy*dy <= distance*distance + (dx&&dy?1:0));
#else
if (dx < 0) dx = -dx;
if (dy < 0) dy = -dy;
return ((dx<dy?dy:dx) <= distance);
#endif
}

It seems a little bit odd to me that this:
!check_distance(dx*dx + dy*dy, 0, range*range+(dx&&dy?1:0))
always gives 0 as the second argument to the function. Why is that? Isn't something mixed up there? The other parameters seems to be wrong for me as well.

It seems to me that someone made this function for distance check, but forgot to remove the old calculation and replace it with the parameters in the code when you call it.

I believe this is how it should look like:
{ // Range for players' attacks and skills should always have a circular check. [Inkfish]
  int dx = src->x - bl->x, dy = src->y - bl->y;
  if( !check_distance(dx, dy, range) )
   return false;
}

Edited by Angezerus, 02 May 2012 - 08:54 AM.


Originally posted by Ind
Angezerus thank you very much. I compared the distance official servers move in a diagonal vs geographer and in rathena with your modified version of the range and it matches perfectly. I'll apply to the svn and credit you.

Originally posted by Ind
Fixed in [rev=16054]