GetAngleBetweenLocations

GetAngleBetweenLocations(location, location)
Returns a float representing the angle between Location One and Location Two

float GetAngleBetweenLocations(    location lOne,     location lTwo );

Parameters
location lOne


 * Location One

location lTwo


 * Location Two

Description
This is a convenience function that returns a float representing the angle between lOne and lTwo. This is done by extracting the positions from lOne and lTwo, then getting the distance between the two locations. Then the absolute change in the x axis is calculated and the result is applied to acos(deltaX / distance). The result is a number whoâ€™s value represents the absolute bearing (where North=0) between the two locations.

Calls
int abs( int iNum) float acos( float fNum) int FloatToInt( float fNum) float IntToFloat( int iNum) vector GetPositionFromLocation( location loc) float GetDistanceBetweenLocations( location lone, location lTwo)

Remarks
This method may suffer from round-off error, in the line: IntToFloat(abs(FloatToInt(vPos1.x - vPos2.x))) When vPos2.x is subtracted from vPos1.x and there is no guarantee that (vPos1.x > vPos2.x) is true. This author has to wonder about the absence of a fAbs function that returns the absolute value of a float, baring that why not simply write the following check: float fChangeX = vPos1.x â€“ vPos2.x; if (fChangeX < 0) fChangeX = -fChangeX;

as was done in GetChangedPosition. But this is merely this writerâ€™s opinion; the precision error however can be real.

Also remember, this requires the include file x0_i0_position.

Requirements

 * 1) include "x0_i0_position"

Version
1.61