mirror of
https://git.do.srb2.org/KartKrew/Kart-Public.git
synced 2025-01-27 11:40:52 +00:00
Merge branch 'no-aprox-dist' into 'next'
Use R_PointToDist2 over FixedHypot, and FixedHypot over P_AproxDistance See merge request KartKrew/Kart-Public!243
This commit is contained in:
commit
4c5d69b714
5 changed files with 32 additions and 50 deletions
|
@ -238,7 +238,8 @@ static int lib_pAproxDistance(lua_State *L)
|
||||||
fixed_t dx = luaL_checkfixed(L, 1);
|
fixed_t dx = luaL_checkfixed(L, 1);
|
||||||
fixed_t dy = luaL_checkfixed(L, 2);
|
fixed_t dy = luaL_checkfixed(L, 2);
|
||||||
//HUDSAFE
|
//HUDSAFE
|
||||||
lua_pushfixed(L, P_AproxDistance(dx, dy));
|
LUA_Deprecated(L, "P_AproxDistance", "FixedHypot");
|
||||||
|
lua_pushfixed(L, FixedHypot(dx, dy));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,8 +18,10 @@
|
||||||
#define HAVE_SQRTF
|
#define HAVE_SQRTF
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "doomdef.h"
|
#include "doomdef.h"
|
||||||
#include "m_fixed.h"
|
#include "m_fixed.h"
|
||||||
|
#include "tables.h" // ANGLETOFINESHIFT
|
||||||
|
|
||||||
#ifdef __USE_C_FIXEDMUL__
|
#ifdef __USE_C_FIXEDMUL__
|
||||||
|
|
||||||
|
@ -105,20 +107,34 @@ fixed_t FixedSqrt(fixed_t x)
|
||||||
|
|
||||||
fixed_t FixedHypot(fixed_t x, fixed_t y)
|
fixed_t FixedHypot(fixed_t x, fixed_t y)
|
||||||
{
|
{
|
||||||
fixed_t ax, yx, yx2, yx1;
|
// Moved the code from R_PointToDist2 to here,
|
||||||
if (abs(y) > abs(x)) // |y|>|x|
|
// since R_PointToDist2 did the same thing,
|
||||||
|
// except less prone to overflowing.
|
||||||
|
|
||||||
|
angle_t angle;
|
||||||
|
fixed_t dist;
|
||||||
|
|
||||||
|
x = abs(x);
|
||||||
|
y = abs(y);
|
||||||
|
|
||||||
|
if (y > x)
|
||||||
{
|
{
|
||||||
ax = abs(y); // |y| => ax
|
fixed_t temp;
|
||||||
yx = FixedDiv(x, y); // (x/y)
|
|
||||||
|
temp = x;
|
||||||
|
x = y;
|
||||||
|
y = temp;
|
||||||
}
|
}
|
||||||
else // |x|>|y|
|
|
||||||
{
|
if (!y)
|
||||||
ax = abs(x); // |x| => ax
|
return x;
|
||||||
yx = FixedDiv(y, x); // (x/y)
|
|
||||||
}
|
angle = (tantoangle[FixedDiv(y, x)>>DBITS] + ANGLE_90) >> ANGLETOFINESHIFT;
|
||||||
yx2 = FixedMul(yx, yx); // (x/y)^2
|
|
||||||
yx1 = FixedSqrt(1 * FRACUNIT + yx2); // (1 + (x/y)^2)^1/2
|
// use as cosine
|
||||||
return FixedMul(ax, yx1); // |x|*((1 + (x/y)^2)^1/2)
|
dist = FixedDiv(x, FINESINE(angle));
|
||||||
|
|
||||||
|
return dist;
|
||||||
}
|
}
|
||||||
|
|
||||||
vector2_t *FV2_Load(vector2_t *vec, fixed_t x, fixed_t y)
|
vector2_t *FV2_Load(vector2_t *vec, fixed_t x, fixed_t y)
|
||||||
|
|
|
@ -23,19 +23,6 @@
|
||||||
#include "p_slopes.h"
|
#include "p_slopes.h"
|
||||||
#include "z_zone.h"
|
#include "z_zone.h"
|
||||||
|
|
||||||
//
|
|
||||||
// P_AproxDistance
|
|
||||||
// Gives an estimation of distance (not exact)
|
|
||||||
//
|
|
||||||
fixed_t P_AproxDistance(fixed_t dx, fixed_t dy)
|
|
||||||
{
|
|
||||||
dx = abs(dx);
|
|
||||||
dy = abs(dy);
|
|
||||||
if (dx < dy)
|
|
||||||
return dx + dy - (dx>>1);
|
|
||||||
return dx + dy - (dy>>1);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// P_ClosestPointOnLine
|
// P_ClosestPointOnLine
|
||||||
// Finds the closest point on a given line to the supplied point
|
// Finds the closest point on a given line to the supplied point
|
||||||
|
|
|
@ -41,7 +41,7 @@ typedef boolean (*traverser_t)(intercept_t *in);
|
||||||
boolean P_PathTraverse(fixed_t px1, fixed_t py1, fixed_t px2, fixed_t py2,
|
boolean P_PathTraverse(fixed_t px1, fixed_t py1, fixed_t px2, fixed_t py2,
|
||||||
INT32 pflags, traverser_t ptrav);
|
INT32 pflags, traverser_t ptrav);
|
||||||
|
|
||||||
FUNCMATH fixed_t P_AproxDistance(fixed_t dx, fixed_t dy);
|
#define P_AproxDistance(dx, dy) FixedHypot(dx, dy)
|
||||||
void P_ClosestPointOnLine(fixed_t x, fixed_t y, line_t *line, vertex_t *result);
|
void P_ClosestPointOnLine(fixed_t x, fixed_t y, line_t *line, vertex_t *result);
|
||||||
void P_ClosestPointOnLine3D(fixed_t x, fixed_t y, fixed_t z, line_t *line, vertex_t *result);
|
void P_ClosestPointOnLine3D(fixed_t x, fixed_t y, fixed_t z, line_t *line, vertex_t *result);
|
||||||
INT32 P_PointOnLineSide(fixed_t x, fixed_t y, line_t *line);
|
INT32 P_PointOnLineSide(fixed_t x, fixed_t y, line_t *line);
|
||||||
|
|
24
src/r_main.c
24
src/r_main.c
|
@ -393,29 +393,7 @@ angle_t R_PointToAngle2(fixed_t pviewx, fixed_t pviewy, fixed_t x, fixed_t y)
|
||||||
|
|
||||||
fixed_t R_PointToDist2(fixed_t px2, fixed_t py2, fixed_t px1, fixed_t py1)
|
fixed_t R_PointToDist2(fixed_t px2, fixed_t py2, fixed_t px1, fixed_t py1)
|
||||||
{
|
{
|
||||||
angle_t angle;
|
return FixedHypot(px1 - px2, py1 - py2);
|
||||||
fixed_t dx, dy, dist;
|
|
||||||
|
|
||||||
dx = abs(px1 - px2);
|
|
||||||
dy = abs(py1 - py2);
|
|
||||||
|
|
||||||
if (dy > dx)
|
|
||||||
{
|
|
||||||
fixed_t temp;
|
|
||||||
|
|
||||||
temp = dx;
|
|
||||||
dx = dy;
|
|
||||||
dy = temp;
|
|
||||||
}
|
|
||||||
if (!dy)
|
|
||||||
return dx;
|
|
||||||
|
|
||||||
angle = (tantoangle[FixedDiv(dy, dx)>>DBITS] + ANGLE_90) >> ANGLETOFINESHIFT;
|
|
||||||
|
|
||||||
// use as cosine
|
|
||||||
dist = FixedDiv(dx, FINESINE(angle));
|
|
||||||
|
|
||||||
return dist;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Little extra utility. Works in the same way as R_PointToAngle2
|
// Little extra utility. Works in the same way as R_PointToAngle2
|
||||||
|
|
Loading…
Reference in a new issue