1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
|
package tim.prune.data;
import tim.prune.config.Config;
/**
* Class to provide distance constants and functions
*/
public abstract class Distance
{
// Geographical constants
/** Earth radius in metres */
private static final double EARTH_RADIUS_M = 6372795.0;
/**
* Convert the given angle in radians into a distance
* @param inAngDist angular distance in radians
* @return distance in currently configured distance units
*/
public static double convertRadiansToDistance(double inAngDist)
{
return convertRadiansToDistance(inAngDist, Config.getUnitSet().getDistanceUnit());
}
/**
* Convert the given angle in radians into a distance
* @param inAngDist angular distance in radians
* @param inUnit distance units
* @return distance in specified distance units
*/
public static double convertRadiansToDistance(double inAngDist, Unit inUnit)
{
// Multiply by appropriate factor
return inAngDist * EARTH_RADIUS_M * inUnit.getMultFactorFromStd();
}
/**
* Convert the given distance into an angle in radians
* @param inDist distance to convert in the current distance units
* @return angular distance in radians
*/
public static double convertDistanceToRadians(double inDist)
{
return convertDistanceToRadians(inDist, Config.getUnitSet().getDistanceUnit());
}
/**
* Convert the given distance into an angle in radians
* @param inDist distance to convert in the current distance units
* @param inUnit distance unit
* @return angular distance in radians
*/
public static double convertDistanceToRadians(double inDist, Unit inUnit)
{
// Divide by appropriate factor
return inDist / EARTH_RADIUS_M / inUnit.getMultFactorFromStd();
}
}
|