根据Latitude/Longitude 计算方位,距离等

里面有详细的说明 http://www.movable-type.co.uk/scripts/latlong.html
比如计算距离
方法一,
double dist = 0.0; 
             double deltaLat = Math.toRadians(latVal2 - latVal1); 
             double deltaLon = Math.toRadians(lonVal2 - lonVal1); 
             latVal1 = Math.toRadians(latVal1); 
             latVal2 = Math.toRadians(latVal2); 
             lonVal1 = Math.toRadians(lonVal1); 
             lonVal2 = Math.toRadians(lonVal2); 
                double earthRadius = 6371; 
                double a = Math.sin(deltaLat/2) * Math.sin(deltaLat/2) + 
Math.cos(latVal1) * Math.cos(latVal2) * Math.sin(deltaLon/2) * Math.sin 
(deltaLon/2); 
                double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
                dist = earthRadius * c;

方法二,
public static double calculateHaversineMI(double lat1, double long1, double lat2,double long2) {
	    double dlong = (long2 - long1) * (Math.PI / 180.0f);
	    double dlat = (lat2 - lat1) * (Math.PI / 180.0f);
	    double a = Math.pow(Math.sin(dlat / 2.0), 2)
	        + Math.cos(lat1 * (Math.PI / 180.0f))
	        * Math.cos(lat2 * (Math.PI / 180.0f))
	        * Math.pow(Math.sin(dlong / 2.0), 2);
	    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
	    double d = 6367* c;

	    return d;
	}


还有计算方位
double dLong = picLongitude - mLongitude; 
double y =  (Math.sin(dLong) * Math.cos(picLatitude)); 
double x =  (Math.cos(mLatitude) * Math.sin(picLatitude) - 
Math.sin(mLatitude)*Math.cos(picLatitude)*Math.cos(dLong)); 
double angleDegreesWrongRange = Math.abs(Math.toDegrees(Math.atan2(y, 
x))); 
float angleDegrees = (float) ((angleDegreesWrongRange+360) % 360); 

	public static String getDirection(float baseAzimuth){
		String bearingText = "";
	    if ( (360 >= baseAzimuth && baseAzimuth >= 337.5) || (0 <= baseAzimuth && baseAzimuth <= 22.5) ) bearingText = "N";
	    else if (baseAzimuth > 22.5 && baseAzimuth < 67.5) bearingText = "NE";
	    else if (baseAzimuth >= 67.5 && baseAzimuth <= 112.5) bearingText = "E";
	    else if (baseAzimuth > 112.5 && baseAzimuth < 157.5) bearingText = "SE";
	    else if (baseAzimuth >= 157.5 && baseAzimuth <= 202.5) bearingText = "S";
	    else if (baseAzimuth > 202.5 && baseAzimuth < 247.5) bearingText = "SW";
	    else if (baseAzimuth >= 247.5 && baseAzimuth <= 292.5) bearingText = "W";
	    else if (baseAzimuth > 292.5 && baseAzimuth < 337.5) bearingText = "NW";
	    
	    return bearingText;
	}


都可以在里面找到答案

你可能感兴趣的:(long)